From d199e02a6372ef3a406eae8e23b25dc46b03d0d2 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Mon, 12 Jan 2026 12:23:49 -0800 Subject: [PATCH 01/25] Add RDMA and GPU Direct Storage support This commit adds support for RDMA (Remote Direct Memory Access) and NVIDIA GPU Direct Storage for high-performance data transfers. Features: - RDMA transport layer with AWS S3 SignV4 signing - GetObject/PutObject operations via RDMA - Multipart upload support with RDMA - NVIDIA cuFile integration for GPU Direct Storage - cuObjClient wrapper for RDMA operations (v0.7) - New examples: GetPutRDMA, GPUHostDisk Build changes: - Tests and examples built by default (MINIO_CPP_TEST=ON) - CUDA toolkit integration at /usr/local/cuda - cuObjClient library linkage The RDMA implementation uses objectPut/objectGet callbacks invoked by the cuFile RDMA layer for direct GPU-to-storage transfers. --- CLAUDE.md | 88 + CMakeLists.txt | 13 +- configure.sh | 5 +- examples/GPUHostDisk.cc | 49 + examples/GetPutRDMA.cc | 154 + examples/PutObject.cc | 34 +- include/miniocpp/args.h | 41 +- include/miniocpp/baseclient.h | 22 +- include/miniocpp/client.h | 3 + include/miniocpp/cuda.h | 25029 ++++++++++++++++++++++++ include/miniocpp/cufile.h | 740 + include/miniocpp/cufile_info.h | 22 + include/miniocpp/http.h | 7 +- include/miniocpp/nvidia-cufile.h | 593 + include/miniocpp/nvidia-cuobjclient.h | 236 + include/miniocpp/rdma-httplib.h | 10154 ++++++++++ include/miniocpp/rdma.h | 262 + include/miniocpp/response.h | 1 + include/miniocpp/utils.h | 9 +- src/args.cc | 16 + src/baseclient.cc | 270 +- src/client.cc | 1449 +- src/response.cc | 183 +- src/utils.cc | 2 +- 24 files changed, 38509 insertions(+), 873 deletions(-) create mode 100644 CLAUDE.md create mode 100644 examples/GPUHostDisk.cc create mode 100644 examples/GetPutRDMA.cc create mode 100644 include/miniocpp/cuda.h create mode 100644 include/miniocpp/cufile.h create mode 100644 include/miniocpp/cufile_info.h create mode 100644 include/miniocpp/nvidia-cufile.h create mode 100644 include/miniocpp/nvidia-cuobjclient.h create mode 100644 include/miniocpp/rdma-httplib.h create mode 100644 include/miniocpp/rdma.h diff --git a/CLAUDE.md b/CLAUDE.md new file mode 100644 index 00000000..9c3842be --- /dev/null +++ b/CLAUDE.md @@ -0,0 +1,88 @@ +# CLAUDE.md + +This file provides guidance to Claude Code (claude.ai/code) when working with code in this repository. + +## Project Overview + +MinIO C++ SDK is an S3-compatible object storage client library. This fork extends the upstream minio-cpp with RDMA (Remote Direct Memory Access) and NVIDIA GPU Direct Storage support for high-performance data transfers. + +## Build Commands + +### Prerequisites +- CMake 3.10+ +- C++17 compiler +- vcpkg package manager (set `VCPKG_ROOT` environment variable) +- NVIDIA CUDA toolkit at `/usr/local/cuda` (for RDMA/GPU features) +- cuObjClient library (for RDMA support) + +### Configure and Build + +```bash +# Configure both Debug and Release builds (recommended) +./configure.sh -DMINIO_CPP_TEST=ON + +# Or configure manually for Debug +cmake . -B build/Debug -DCMAKE_BUILD_TYPE=Debug -DMINIO_CPP_TEST=ON + +# Build +cmake --build ./build/Debug +``` + +### Build Options +- `MINIO_CPP_TEST=ON` - Build tests and examples +- `MINIO_CPP_MAKE_DOC=ON` - Build Doxygen documentation +- `BUILD_SHARED_LIBS=ON` - Build shared library (default is static) + +### Running Tests + +```bash +./build/Debug/tests +``` + +### Running Examples + +Examples are built when `MINIO_CPP_TEST=ON`. Run individual examples: +```bash +./build/Debug/MakeBucket +./build/Debug/PutObject +./build/Debug/GetPutRDMA # RDMA-specific example +./build/Debug/GPUHostDisk # GPU Direct Storage example +``` + +## Architecture + +### Core Components + +- **`minio::s3::Client`** (`include/miniocpp/client.h`, `src/client.cc`) - Main S3 client class with high-level operations (UploadObject, DownloadObject, etc.) +- **`minio::s3::BaseClient`** (`include/miniocpp/baseclient.h`, `src/baseclient.cc`) - Base class implementing low-level S3 API operations and request execution + +### Request/Response Flow + +- **`args.h`** - Argument structs for each S3 operation (e.g., `PutObjectArgs`, `GetObjectArgs`) +- **`response.h`** - Response types returned by operations +- **`request.h`** - HTTP request construction +- **`http.h`** - HTTP client abstraction using curlpp + +### Authentication + +- **`providers.h`/`credentials.h`** - Credential providers (StaticProvider, EnvProvider, etc.) +- **`signer.h`** - AWS Signature V4 request signing + +### RDMA/GPU Support (Fork-specific) + +- **`rdma.h`** - RDMA transport layer with S3 signing for GPU Direct Storage +- **`rdma-httplib.h`** - HTTP-over-RDMA implementation +- **`nvidia-cufile.h`** - NVIDIA cuFile integration headers +- **`nvidia-cuobjclient.h`** - cuObjClient wrapper for RDMA operations + +The RDMA implementation uses `objectPut`/`objectGet` callbacks that are invoked by the cuFile RDMA layer for direct GPU-to-storage transfers. + +## Dependencies (vcpkg) + +- curlpp - HTTP client +- inih - INI file parsing for config +- nlohmann-json - JSON handling +- openssl - TLS/crypto +- pugixml - XML parsing for S3 responses + +Additional system dependencies for RDMA: libcufile, libcuobjclient, libibverbs, librdmacm diff --git a/CMakeLists.txt b/CMakeLists.txt index f0660cde..49449497 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -35,11 +35,13 @@ project(miniocpp include(GNUInstallDirs) include(CheckIncludeFiles) include(CMakePackageConfigHelpers) +include("${VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake") option(MINIO_CPP_TEST "Build tests" OFF) option(MINIO_CPP_MAKE_DOC "Build documentation" OFF) set(MINIO_CPP_CFLAGS) +set(MINIO_CPP_INCLUDES) set(MINIO_CPP_LIBS) set(MINIO_CPP_STD "17") @@ -47,7 +49,9 @@ if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC" OR "x${CMAKE_CXX_COMPILER_FRONTEN # MSVC else() # GCC/Clang/AppleClang/... - LIST(APPEND MINIO_CPP_CFLAGS -Wall -Wextra -Wconversion) + list(APPEND MINIO_CPP_CFLAGS -Wall -Wextra -Wconversion) + list(APPEND MINIO_CPP_INCLUDES /usr/local/cuda/include) + list(APPEND MINIO_CPP_LIBS "-Bdynamic -L /usr/local/cuda/lib64 -lcufile -lpthread -lnuma -ldl -libverbs -lrdmacm -lrt -lcuobjclient") if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0 AND CMAKE_CXX_COMPILER_VERSION VERSION_LESS 9.0 AND NOT MINGW) list(APPEND MINIO_CPP_LIBS stdc++fs) endif() @@ -105,7 +109,11 @@ set(MINIO_CPP_HEADERS include/miniocpp/credentials.h include/miniocpp/error.h include/miniocpp/http.h + include/miniocpp/nvidia-cufile.h + include/miniocpp/nvidia-cuobjclient.h include/miniocpp/providers.h + include/miniocpp/rdma.h + include/miniocpp/rdma-httplib.h include/miniocpp/request.h include/miniocpp/response.h include/miniocpp/select.h @@ -132,6 +140,7 @@ target_compile_features(miniocpp PUBLIC cxx_std_${MINIO_CPP_STD}) target_include_directories(miniocpp PUBLIC $ $ + ${MINIO_CPP_INCLUDES} ) target_link_libraries(miniocpp PUBLIC ${MINIO_CPP_LIBS}) set_target_properties(miniocpp PROPERTIES VERSION "${MINIO_CPP_VERSION_STRING}") @@ -156,6 +165,8 @@ if (MINIO_CPP_TEST) GetObject ListObjects PutObject + GetPutRDMA + GPUHostDisk CopyObject ComposeObject RemoveObjects diff --git a/configure.sh b/configure.sh index eac8b718..21747a28 100755 --- a/configure.sh +++ b/configure.sh @@ -1,10 +1,11 @@ #!/bin/sh set -x -BUILD_OPTIONS="-DCMAKE_EXPORT_COMPILE_COMMANDS=ON" + +BUILD_OPTIONS="-DCMAKE_EXPORT_COMPILE_COMMANDS=ON -DBUILD_SHARED_LIBS=ON -DCMAKE_SHARED_LINKER_FLAGS=-L/home/harsha/go/src/github.com/miniohq/eos/cuObject-0.8.5-Linux/src/lib/" if [ -n "$VCPKG_ROOT" ]; then - BUILD_OPTIONS="${BUILD_OPTIONS} -DCMAKE_TOOLCHAIN_FILE=${VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake" + BUILD_OPTIONS="${BUILD_OPTIONS} -DVCPKG_ROOT=${VCPKG_ROOT}" fi echo "== [Configuring Build - Debug] ==" diff --git a/examples/GPUHostDisk.cc b/examples/GPUHostDisk.cc new file mode 100644 index 00000000..33500e43 --- /dev/null +++ b/examples/GPUHostDisk.cc @@ -0,0 +1,49 @@ +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include + +int main(int argc, char* argv[]) { + char *bufptr; + size_t bufsize = 10 * 1024 * 1024UL; + if (argc == 2) { + bufsize = std::atoi(argv[1]); + } + + cudaMalloc(&bufptr, bufsize); + cudaMemset(bufptr, 'A', bufsize); + cudaStreamSynchronize(0); + + char *hostptr; + hostptr = (char *) malloc(bufsize); + cudaMemcpy(hostptr, bufptr, bufsize, cudaMemcpyDeviceToHost); + + // Open the file in binary mode for writing + std::ofstream file("output.txt", std::ios::binary); + if (file.is_open()) { + // Write the buffer to the file + file.write(hostptr, bufsize); + + // Close the file + file.close(); + + std::cout << "Buffer written to file successfully." << std::endl; + } else { + std::cerr << "Error opening file." << std::endl; + } + + free(hostptr); + cudaFree(bufptr); + + return 0; +} diff --git a/examples/GetPutRDMA.cc b/examples/GetPutRDMA.cc new file mode 100644 index 00000000..2f499568 --- /dev/null +++ b/examples/GetPutRDMA.cc @@ -0,0 +1,154 @@ +// MinIO C++ Library for Amazon S3 Compatible Cloud Storage +// Copyright 2022-2024 MinIO, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// SPDX-License-Identifier: Apache-2.0 + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include + +int main(int argc, char* argv[]) { + std::string host; + std::string access_key; + std::string secret_key; + + char *bufptr; + size_t bufsize = 10 * 1024 * 1024UL; + bool gpu_enabled = false; + + if (argc <= 1) { + printf("usage: %s \n", argv[0]); + exit(1); + } + + if (argc > 1) { + host = std::string(argv[1]); + access_key = std::string(argv[2]); + secret_key = std::string(argv[3]); + if (argc >= 5) { + bufsize = std::atoi(argv[4]); + } + if (argc >= 6) { + gpu_enabled = std::string(argv[5]) == "gpu"; + } + } + + // Create S3 base URL. + minio::s3::BaseUrl base_url(host, false, "us-east-1"); + + // Create credential provider. + minio::creds::StaticProvider provider(access_key, secret_key); + + // Create S3 client. + minio::s3::Client client(base_url, &provider); + + std::cout << bufsize << " " << std::endl; + if (gpu_enabled) { + cudaMalloc(&bufptr, bufsize); + cudaMemset(bufptr, 'A', bufsize); + cudaStreamSynchronize(0); + + std::cout << "GPU enabled" << std::endl; + } else { + int res = posix_memalign((void **)&bufptr, getpagesize(), bufsize); + if (res) { + std::cerr << "unable to allocate system memory with alignment" + << getpagesize() << "buf size" + << bufsize << std::endl; + } + assert(bufptr); + memset(bufptr, 'A', bufsize); + } + + minio::s3::PutObjectRDMAArgs pargs; + pargs.buf = bufptr; + pargs.size = bufsize; + pargs.bucket = "my-bucket"; + pargs.object = "my-object"; + + // Call to put object. + minio::s3::PutObjectResponse presp = client.PutObject(pargs); + // Handle response. + if (presp) { + std::cout << std::endl + << "data uploaded successfully " << presp.etag << std::endl; + } else { + std::cout << "unable to get object; " << presp.Error().String() << std::endl; + } + + // Create get object arguments. + minio::s3::GetObjectRDMAArgs args; + if (gpu_enabled) { + cudaMemset(bufptr, 'U', bufsize); + cudaStreamSynchronize(0); + } + args.buf = bufptr; + args.size = bufsize; + args.bucket = "my-bucket"; + args.object = "my-object"; + + // Call get object. + minio::s3::GetObjectResponse resp = client.GetObject(args); + + // Handle response. + if (resp) { + std::cout << std::endl + << "data of my-object is received successfully" << std::endl; + } else { + std::cout << "unable to get object; " << resp.Error().String() << std::endl; + } + + char *hostptr; + hostptr = (char *) malloc(bufsize); + if (gpu_enabled) { + cudaMemcpy(hostptr, bufptr, bufsize, cudaMemcpyDeviceToHost); + } else { + memcpy(hostptr, bufptr, bufsize); + } + + // Open the file in binary mode for writing + std::ofstream file("output.txt", std::ios::binary); + if (file.is_open()) { + // Write the buffer to the file + file.write(hostptr, bufsize); + + // Close the file + file.close(); + + std::cout << "Buffer written to file successfully." << std::endl; + } else { + std::cerr << "Error opening file." << std::endl; + } + + free(hostptr); + if (gpu_enabled) { + cudaFree(bufptr); + } else { + free(bufptr); + } + + return 0; +} diff --git a/examples/PutObject.cc b/examples/PutObject.cc index d6bd0f8f..dcba71e4 100644 --- a/examples/PutObject.cc +++ b/examples/PutObject.cc @@ -15,6 +15,8 @@ // // SPDX-License-Identifier: Apache-2.0 +#include + #include #include #include @@ -25,14 +27,29 @@ #include #include #include +#include + +int main(int argc, char* argv[]) { + std::string host; + std::string access_key; + std::string secret_key; + + if (argc <= 1) { + printf("usage: %s \n", argv[0]); + exit(1); + } + + if (argc > 1) { + host = std::string(argv[1]); + access_key = std::string(argv[2]); + secret_key = std::string(argv[3]); + } -int main() { // Create S3 base URL. - minio::s3::BaseUrl base_url("play.min.io"); + minio::s3::BaseUrl base_url(host, false, "us-east-1"); // Create credential provider. - minio::creds::StaticProvider provider( - "Q3AM3UQ867SPQQA43P2F", "zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG"); + minio::creds::StaticProvider provider(access_key, secret_key); // Create S3 client. minio::s3::Client client(base_url, &provider); @@ -40,7 +57,10 @@ int main() { // Create put object arguments. std::ifstream file("my-object.csv"); - minio::s3::PutObjectArgs args(file, 47615315, 0); + std::filesystem::path filePath("my-object.csv"); + std::uintmax_t fileSize = std::filesystem::file_size(filePath); + + minio::s3::PutObjectArgs args(file, fileSize, 16*1024*1024UL); args.bucket = "my-bucket"; args.object = "my-object"; @@ -49,10 +69,10 @@ int main() { // Handle response. if (resp) { - std::cout << "my-object is successfully created" << std::endl; + std::cout << "my-object is successfully created etag=" << resp.etag << " " << std::endl; } else { std::cout << "unable to do put object; " << resp.Error().String() - << std::endl; + << std::endl; } return 0; diff --git a/include/miniocpp/args.h b/include/miniocpp/args.h index d1c4d129..18d0453d 100644 --- a/include/miniocpp/args.h +++ b/include/miniocpp/args.h @@ -29,6 +29,7 @@ #include "sse.h" #include "types.h" #include "utils.h" +#include "nvidia-cuobjclient.h" namespace minio::s3 { @@ -155,10 +156,13 @@ struct PutObjectBaseArgs : public ObjectWriteArgs { struct PutObjectApiArgs : public PutObjectBaseArgs { std::string_view data; + char *buf; + size_t size; utils::Multimap query_params; http::ProgressFunction progressfunc = nullptr; void* progress_userdata = nullptr; - + cuObjClient* rdmaclient = nullptr; + PutObjectApiArgs() = default; ~PutObjectApiArgs() = default; }; // struct PutObjectApiArgs @@ -166,9 +170,12 @@ struct PutObjectApiArgs : public PutObjectBaseArgs { struct UploadPartArgs : public ObjectWriteArgs { std::string upload_id; unsigned int part_number; + char *buf; + size_t part_size; std::string_view data; http::ProgressFunction progressfunc = nullptr; void* progress_userdata = nullptr; + cuObjClient* rdmaclient = nullptr; UploadPartArgs() = default; ~UploadPartArgs() = default; @@ -215,6 +222,16 @@ struct GetObjectArgs : public ObjectConditionalReadArgs { error::Error Validate() const; }; // struct GetObjectArgs +struct GetObjectRDMAArgs : public GetObjectArgs { + char *buf; + size_t size = -1; + + GetObjectRDMAArgs() = default; + ~GetObjectRDMAArgs() = default; + + error::Error Validate() const; +}; // struct GetObjectRDMAArgs + struct ListObjectsArgs : public BucketArgs { std::string delimiter; bool use_url_encoding_type = true; @@ -316,6 +333,7 @@ struct PutObjectArgs : public PutObjectBaseArgs { std::istream& stream; http::ProgressFunction progressfunc = nullptr; void* progress_userdata = nullptr; + cuObjClient* rdmaclient = nullptr; PutObjectArgs(std::istream& stream, long object_size, long part_size); ~PutObjectArgs() = default; @@ -323,6 +341,17 @@ struct PutObjectArgs : public PutObjectBaseArgs { error::Error Validate(); }; // struct PutObjectArgs +struct PutObjectRDMAArgs : public PutObjectBaseArgs { + char *buf; + size_t size = -1; + + PutObjectRDMAArgs() = default; + ~PutObjectRDMAArgs() = default; + + error::Error Validate() const; +}; // struct PutObjectRDMAArgs + + using CopySource = ObjectConditionalReadArgs; struct CopyObjectArgs : public ObjectWriteArgs { @@ -577,12 +606,12 @@ struct PostPolicy { error::Error AddStartsWithCondition(std::string element, std::string value); error::Error RemoveStartsWithCondition(std::string element); error::Error AddContentLengthRangeCondition(size_t lower_limit, - size_t upper_limit); + size_t upper_limit); void RemoveContentLengthRangeCondition(); error::Error FormData(std::map& data, - std::string access_key, std::string secret_key, - std::string session_token, std::string region); + std::string access_key, std::string secret_key, + std::string session_token, std::string region); private: static constexpr const char* eq_ = "eq"; @@ -596,8 +625,8 @@ struct PostPolicy { static std::string trimDollar(std::string value); static std::string getCredentialString(std::string access_key, - utils::UtcTime date, - std::string region); + utils::UtcTime date, + std::string region); static bool isReservedElement(std::string element); }; // struct PostPolicy diff --git a/include/miniocpp/baseclient.h b/include/miniocpp/baseclient.h index 59587402..3afe8249 100644 --- a/include/miniocpp/baseclient.h +++ b/include/miniocpp/baseclient.h @@ -31,6 +31,10 @@ #include "response.h" #include "utils.h" +// RDMA specific includes +#include "rdma.h" +#include "nvidia-cuobjclient.h" + #if defined(_WIN32) && defined(GetObject) #pragma push_macro("GetObject") #undef GetObject @@ -58,7 +62,7 @@ class BaseClient { public: explicit BaseClient(BaseUrl base_url, - creds::Provider* const provider = nullptr); + creds::Provider* const provider = nullptr); virtual ~BaseClient() = default; @@ -71,20 +75,20 @@ class BaseClient { } error::Error SetAppInfo(std::string_view app_name, - std::string_view app_version); + std::string_view app_version); void HandleRedirectResponse(std::string& code, std::string& message, - int status_code, http::Method method, - const utils::Multimap& headers, - const std::string& bucket_name, - bool retry = false); + int status_code, http::Method method, + const utils::Multimap& headers, + const std::string& bucket_name, + bool retry = false); Response GetErrorResponse(http::Response resp, std::string_view resource, - http::Method method, const std::string& bucket_name, - const std::string& object_name); + http::Method method, const std::string& bucket_name, + const std::string& object_name); Response execute(Request& req); Response Execute(Request& req); GetRegionResponse GetRegion(const std::string& bucket_name, - const std::string& region); + const std::string& region); AbortMultipartUploadResponse AbortMultipartUpload( AbortMultipartUploadArgs args); diff --git a/include/miniocpp/client.h b/include/miniocpp/client.h index 5820e168..ffe2829f 100644 --- a/include/miniocpp/client.h +++ b/include/miniocpp/client.h @@ -120,6 +120,9 @@ class Client : public BaseClient { DownloadObjectResponse DownloadObject(DownloadObjectArgs args); ListObjectsResult ListObjects(ListObjectsArgs args); PutObjectResponse PutObject(PutObjectArgs args); + GetObjectResponse GetObject(GetObjectArgs args); + GetObjectResponse GetObject(GetObjectRDMAArgs args); + PutObjectResponse PutObject(PutObjectRDMAArgs args); UploadObjectResponse UploadObject(UploadObjectArgs args); RemoveObjectsResult RemoveObjects(RemoveObjectsArgs args); }; // class Client diff --git a/include/miniocpp/cuda.h b/include/miniocpp/cuda.h new file mode 100644 index 00000000..e26d40ba --- /dev/null +++ b/include/miniocpp/cuda.h @@ -0,0 +1,25029 @@ +/* + * Copyright 1993-2023 NVIDIA Corporation. All rights reserved. + * + * NOTICE TO LICENSEE: + * + * This source code and/or documentation ("Licensed Deliverables") are + * subject to NVIDIA intellectual property rights under U.S. and + * international Copyright laws. + * + * These Licensed Deliverables contained herein is PROPRIETARY and + * CONFIDENTIAL to NVIDIA and is being provided under the terms and + * conditions of a form of NVIDIA software license agreement by and + * between NVIDIA and Licensee ("License Agreement") or electronically + * accepted by Licensee. Notwithstanding any terms or conditions to + * the contrary in the License Agreement, reproduction or disclosure + * of the Licensed Deliverables to any third party without the express + * written consent of NVIDIA is prohibited. + * + * NOTWITHSTANDING ANY TERMS OR CONDITIONS TO THE CONTRARY IN THE + * LICENSE AGREEMENT, NVIDIA MAKES NO REPRESENTATION ABOUT THE + * SUITABILITY OF THESE LICENSED DELIVERABLES FOR ANY PURPOSE. IT IS + * PROVIDED "AS IS" WITHOUT EXPRESS OR IMPLIED WARRANTY OF ANY KIND. + * NVIDIA DISCLAIMS ALL WARRANTIES WITH REGARD TO THESE LICENSED + * DELIVERABLES, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY, + * NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE. + * NOTWITHSTANDING ANY TERMS OR CONDITIONS TO THE CONTRARY IN THE + * LICENSE AGREEMENT, IN NO EVENT SHALL NVIDIA BE LIABLE FOR ANY + * SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, OR ANY + * DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, + * WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS + * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE + * OF THESE LICENSED DELIVERABLES. + * + * U.S. Government End Users. These Licensed Deliverables are a + * "commercial item" as that term is defined at 48 C.F.R. 2.101 (OCT + * 1995), consisting of "commercial computer software" and "commercial + * computer software documentation" as such terms are used in 48 + * C.F.R. 12.212 (SEPT 1995) and is provided to the U.S. Government + * only as a commercial end item. Consistent with 48 C.F.R.12.212 and + * 48 C.F.R. 227.7202-1 through 227.7202-4 (JUNE 1995), all + * U.S. Government End Users acquire the Licensed Deliverables with + * only those rights set forth herein. + * + * Any use of the Licensed Deliverables in individual and commercial + * software must include, in the user documentation and internal + * comments to the code, the above Disclaimer and U.S. Government End + * Users Notice. + */ + +#ifndef __cuda_cuda_h__ +#define __cuda_cuda_h__ + + + + +#include +#ifdef _MSC_VER +typedef unsigned __int32 cuuint32_t; +typedef unsigned __int64 cuuint64_t; +#else +#include +typedef uint32_t cuuint32_t; +typedef uint64_t cuuint64_t; +#endif + +#if defined(__CUDA_API_VERSION_INTERNAL) || defined(__DOXYGEN_ONLY__) || defined(CUDA_ENABLE_DEPRECATED) +#define __CUDA_DEPRECATED +#elif defined(_MSC_VER) +#define __CUDA_DEPRECATED __declspec(deprecated) +#elif defined(__GNUC__) +#define __CUDA_DEPRECATED __attribute__((deprecated)) +#else +#define __CUDA_DEPRECATED +#endif + +#if defined(CUDA_FORCE_API_VERSION) +#error "CUDA_FORCE_API_VERSION is no longer supported." +#endif + +#if defined(__CUDA_API_VERSION_INTERNAL) || defined(CUDA_API_PER_THREAD_DEFAULT_STREAM) + #define __CUDA_API_PER_THREAD_DEFAULT_STREAM + #define __CUDA_API_PTDS(api) api ## _ptds + #define __CUDA_API_PTSZ(api) api ## _ptsz +#else + #define __CUDA_API_PTDS(api) api + #define __CUDA_API_PTSZ(api) api +#endif + +#define cuDeviceTotalMem cuDeviceTotalMem_v2 +#define cuCtxCreate cuCtxCreate_v2 +#define cuCtxCreate_v3 cuCtxCreate_v3 +#define cuCtxCreate_v4 cuCtxCreate_v4 +#define cuModuleGetGlobal cuModuleGetGlobal_v2 +#define cuMemGetInfo cuMemGetInfo_v2 +#define cuMemAlloc cuMemAlloc_v2 +#define cuMemAllocPitch cuMemAllocPitch_v2 +#define cuMemFree cuMemFree_v2 +#define cuMemGetAddressRange cuMemGetAddressRange_v2 +#define cuMemAllocHost cuMemAllocHost_v2 +#define cuMemHostGetDevicePointer cuMemHostGetDevicePointer_v2 +#define cuMemcpyHtoD __CUDA_API_PTDS(cuMemcpyHtoD_v2) +#define cuMemcpyDtoH __CUDA_API_PTDS(cuMemcpyDtoH_v2) +#define cuMemcpyDtoD __CUDA_API_PTDS(cuMemcpyDtoD_v2) +#define cuMemcpyDtoA __CUDA_API_PTDS(cuMemcpyDtoA_v2) +#define cuMemcpyAtoD __CUDA_API_PTDS(cuMemcpyAtoD_v2) +#define cuMemcpyHtoA __CUDA_API_PTDS(cuMemcpyHtoA_v2) +#define cuMemcpyAtoH __CUDA_API_PTDS(cuMemcpyAtoH_v2) +#define cuMemcpyAtoA __CUDA_API_PTDS(cuMemcpyAtoA_v2) +#define cuMemcpyHtoAAsync __CUDA_API_PTSZ(cuMemcpyHtoAAsync_v2) +#define cuMemcpyAtoHAsync __CUDA_API_PTSZ(cuMemcpyAtoHAsync_v2) +#define cuMemcpy2D __CUDA_API_PTDS(cuMemcpy2D_v2) +#define cuMemcpy2DUnaligned __CUDA_API_PTDS(cuMemcpy2DUnaligned_v2) +#define cuMemcpy3D __CUDA_API_PTDS(cuMemcpy3D_v2) +#define cuMemcpyHtoDAsync __CUDA_API_PTSZ(cuMemcpyHtoDAsync_v2) +#define cuMemcpyDtoHAsync __CUDA_API_PTSZ(cuMemcpyDtoHAsync_v2) +#define cuMemcpyDtoDAsync __CUDA_API_PTSZ(cuMemcpyDtoDAsync_v2) +#define cuMemcpy2DAsync __CUDA_API_PTSZ(cuMemcpy2DAsync_v2) +#define cuMemcpy3DAsync __CUDA_API_PTSZ(cuMemcpy3DAsync_v2) +#define cuMemsetD8 __CUDA_API_PTDS(cuMemsetD8_v2) +#define cuMemsetD16 __CUDA_API_PTDS(cuMemsetD16_v2) +#define cuMemsetD32 __CUDA_API_PTDS(cuMemsetD32_v2) +#define cuMemsetD2D8 __CUDA_API_PTDS(cuMemsetD2D8_v2) +#define cuMemsetD2D16 __CUDA_API_PTDS(cuMemsetD2D16_v2) +#define cuMemsetD2D32 __CUDA_API_PTDS(cuMemsetD2D32_v2) +#define cuArrayCreate cuArrayCreate_v2 +#define cuArrayGetDescriptor cuArrayGetDescriptor_v2 +#define cuArray3DCreate cuArray3DCreate_v2 +#define cuArray3DGetDescriptor cuArray3DGetDescriptor_v2 +#define cuTexRefSetAddress cuTexRefSetAddress_v2 +#define cuTexRefGetAddress cuTexRefGetAddress_v2 +#define cuGraphicsResourceGetMappedPointer cuGraphicsResourceGetMappedPointer_v2 +#define cuCtxDestroy cuCtxDestroy_v2 +#define cuCtxPopCurrent cuCtxPopCurrent_v2 +#define cuCtxPushCurrent cuCtxPushCurrent_v2 +#define cuStreamDestroy cuStreamDestroy_v2 +#define cuEventDestroy cuEventDestroy_v2 +#define cuTexRefSetAddress2D cuTexRefSetAddress2D_v3 +#define cuLinkCreate cuLinkCreate_v2 +#define cuLinkAddData cuLinkAddData_v2 +#define cuLinkAddFile cuLinkAddFile_v2 +#define cuMemHostRegister cuMemHostRegister_v2 +#define cuGraphicsResourceSetMapFlags cuGraphicsResourceSetMapFlags_v2 +#define cuStreamBeginCapture __CUDA_API_PTSZ(cuStreamBeginCapture_v2) +#define cuDevicePrimaryCtxRelease cuDevicePrimaryCtxRelease_v2 +#define cuDevicePrimaryCtxReset cuDevicePrimaryCtxReset_v2 +#define cuDevicePrimaryCtxSetFlags cuDevicePrimaryCtxSetFlags_v2 +#define cuDeviceGetUuid_v2 cuDeviceGetUuid_v2 +#define cuIpcOpenMemHandle cuIpcOpenMemHandle_v2 + +#define cuGraphInstantiate cuGraphInstantiateWithFlags + +#define cuGraphExecUpdate cuGraphExecUpdate_v2 +#define cuGetProcAddress cuGetProcAddress_v2 +#define cuGraphAddKernelNode cuGraphAddKernelNode_v2 +#define cuGraphKernelNodeGetParams cuGraphKernelNodeGetParams_v2 +#define cuGraphKernelNodeSetParams cuGraphKernelNodeSetParams_v2 +#define cuGraphExecKernelNodeSetParams cuGraphExecKernelNodeSetParams_v2 + +#define cuStreamWriteValue32 __CUDA_API_PTSZ(cuStreamWriteValue32_v2) +#define cuStreamWaitValue32 __CUDA_API_PTSZ(cuStreamWaitValue32_v2) +#define cuStreamWriteValue64 __CUDA_API_PTSZ(cuStreamWriteValue64_v2) +#define cuStreamWaitValue64 __CUDA_API_PTSZ(cuStreamWaitValue64_v2) +#define cuStreamBatchMemOp __CUDA_API_PTSZ(cuStreamBatchMemOp_v2) +#define cuStreamGetCaptureInfo __CUDA_API_PTSZ(cuStreamGetCaptureInfo_v2) +#define cuStreamGetCaptureInfo_v2 __CUDA_API_PTSZ(cuStreamGetCaptureInfo_v2) + +#if defined(__CUDA_API_PER_THREAD_DEFAULT_STREAM) + #define cuMemcpy __CUDA_API_PTDS(cuMemcpy) + #define cuMemcpyAsync __CUDA_API_PTSZ(cuMemcpyAsync) + #define cuMemcpyPeer __CUDA_API_PTDS(cuMemcpyPeer) + #define cuMemcpyPeerAsync __CUDA_API_PTSZ(cuMemcpyPeerAsync) + #define cuMemcpy3DPeer __CUDA_API_PTDS(cuMemcpy3DPeer) + #define cuMemcpy3DPeerAsync __CUDA_API_PTSZ(cuMemcpy3DPeerAsync) + #define cuMemPrefetchAsync __CUDA_API_PTSZ(cuMemPrefetchAsync) + #define cuMemPrefetchAsync_v2 __CUDA_API_PTSZ(cuMemPrefetchAsync_v2) + + #define cuMemsetD8Async __CUDA_API_PTSZ(cuMemsetD8Async) + #define cuMemsetD16Async __CUDA_API_PTSZ(cuMemsetD16Async) + #define cuMemsetD32Async __CUDA_API_PTSZ(cuMemsetD32Async) + #define cuMemsetD2D8Async __CUDA_API_PTSZ(cuMemsetD2D8Async) + #define cuMemsetD2D16Async __CUDA_API_PTSZ(cuMemsetD2D16Async) + #define cuMemsetD2D32Async __CUDA_API_PTSZ(cuMemsetD2D32Async) + + #define cuStreamGetPriority __CUDA_API_PTSZ(cuStreamGetPriority) + #define cuStreamGetId __CUDA_API_PTSZ(cuStreamGetId) + #define cuStreamGetFlags __CUDA_API_PTSZ(cuStreamGetFlags) + #define cuStreamGetCtx __CUDA_API_PTSZ(cuStreamGetCtx) + #define cuStreamGetCtx_v2 __CUDA_API_PTSZ(cuStreamGetCtx_v2) + #define cuStreamWaitEvent __CUDA_API_PTSZ(cuStreamWaitEvent) + #define cuStreamEndCapture __CUDA_API_PTSZ(cuStreamEndCapture) + #define cuStreamIsCapturing __CUDA_API_PTSZ(cuStreamIsCapturing) + #define cuStreamGetCaptureInfo_v3 __CUDA_API_PTSZ(cuStreamGetCaptureInfo_v3) + #define cuStreamUpdateCaptureDependencies __CUDA_API_PTSZ(cuStreamUpdateCaptureDependencies) + #define cuStreamUpdateCaptureDependencies_v2 __CUDA_API_PTSZ(cuStreamUpdateCaptureDependencies_v2) + #define cuStreamAddCallback __CUDA_API_PTSZ(cuStreamAddCallback) + #define cuStreamAttachMemAsync __CUDA_API_PTSZ(cuStreamAttachMemAsync) + #define cuStreamQuery __CUDA_API_PTSZ(cuStreamQuery) + #define cuStreamSynchronize __CUDA_API_PTSZ(cuStreamSynchronize) + #define cuEventRecord __CUDA_API_PTSZ(cuEventRecord) + #define cuEventRecordWithFlags __CUDA_API_PTSZ(cuEventRecordWithFlags) + #define cuLaunchKernel __CUDA_API_PTSZ(cuLaunchKernel) + #define cuLaunchKernelEx __CUDA_API_PTSZ(cuLaunchKernelEx) + #define cuLaunchHostFunc __CUDA_API_PTSZ(cuLaunchHostFunc) + #define cuGraphicsMapResources __CUDA_API_PTSZ(cuGraphicsMapResources) + #define cuGraphicsUnmapResources __CUDA_API_PTSZ(cuGraphicsUnmapResources) + + + #define cuLaunchCooperativeKernel __CUDA_API_PTSZ(cuLaunchCooperativeKernel) + + #define cuSignalExternalSemaphoresAsync __CUDA_API_PTSZ(cuSignalExternalSemaphoresAsync) + #define cuWaitExternalSemaphoresAsync __CUDA_API_PTSZ(cuWaitExternalSemaphoresAsync) + + #define cuGraphInstantiateWithParams __CUDA_API_PTSZ(cuGraphInstantiateWithParams) + #define cuGraphUpload __CUDA_API_PTSZ(cuGraphUpload) + #define cuGraphLaunch __CUDA_API_PTSZ(cuGraphLaunch) + #define cuStreamCopyAttributes __CUDA_API_PTSZ(cuStreamCopyAttributes) + #define cuStreamGetAttribute __CUDA_API_PTSZ(cuStreamGetAttribute) + #define cuStreamSetAttribute __CUDA_API_PTSZ(cuStreamSetAttribute) + #define cuMemMapArrayAsync __CUDA_API_PTSZ(cuMemMapArrayAsync) + + #define cuMemFreeAsync __CUDA_API_PTSZ(cuMemFreeAsync) + #define cuMemAllocAsync __CUDA_API_PTSZ(cuMemAllocAsync) + #define cuMemAllocFromPoolAsync __CUDA_API_PTSZ(cuMemAllocFromPoolAsync) + + #define cuStreamBeginCaptureToGraph __CUDA_API_PTSZ(cuStreamBeginCaptureToGraph) + +#endif + +/** + * \file cuda.h + * \brief Header file for the CUDA Toolkit application programming interface. + * + * \file cudaGL.h + * \brief Header file for the OpenGL interoperability functions of the + * low-level CUDA driver application programming interface. + * + * \file cudaD3D9.h + * \brief Header file for the Direct3D 9 interoperability functions of the + * low-level CUDA driver application programming interface. + */ + +/** + * \defgroup CUDA_TYPES Data types used by CUDA driver + * @{ + */ + +/** + * CUDA API version number + */ +#define CUDA_VERSION 12060 + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * CUDA device pointer + * CUdeviceptr is defined as an unsigned integer type whose size matches the size of a pointer on the target platform. + */ +#if defined(_WIN64) || defined(__LP64__) +typedef unsigned long long CUdeviceptr_v2; +#else +typedef unsigned int CUdeviceptr_v2; +#endif +typedef CUdeviceptr_v2 CUdeviceptr; /**< CUDA device pointer */ + +typedef int CUdevice_v1; /**< CUDA device */ +typedef CUdevice_v1 CUdevice; /**< CUDA device */ +typedef struct CUctx_st *CUcontext; /**< A regular context handle */ +typedef struct CUmod_st *CUmodule; /**< CUDA module */ +typedef struct CUfunc_st *CUfunction; /**< CUDA function */ +typedef struct CUlib_st *CUlibrary; /**< CUDA library */ +typedef struct CUkern_st *CUkernel; /**< CUDA kernel */ +typedef struct CUarray_st *CUarray; /**< CUDA array */ +typedef struct CUmipmappedArray_st *CUmipmappedArray; /**< CUDA mipmapped array */ +typedef struct CUtexref_st *CUtexref; /**< CUDA texture reference */ +typedef struct CUsurfref_st *CUsurfref; /**< CUDA surface reference */ +typedef struct CUevent_st *CUevent; /**< CUDA event */ +typedef struct CUstream_st *CUstream; /**< CUDA stream */ +typedef struct CUgraphicsResource_st *CUgraphicsResource; /**< CUDA graphics interop resource */ +typedef unsigned long long CUtexObject_v1; /**< An opaque value that represents a CUDA texture object */ +typedef CUtexObject_v1 CUtexObject; /**< An opaque value that represents a CUDA texture object */ +typedef unsigned long long CUsurfObject_v1; /**< An opaque value that represents a CUDA surface object */ +typedef CUsurfObject_v1 CUsurfObject; /**< An opaque value that represents a CUDA surface object */ +typedef struct CUextMemory_st *CUexternalMemory; /**< CUDA external memory */ +typedef struct CUextSemaphore_st *CUexternalSemaphore; /**< CUDA external semaphore */ +typedef struct CUgraph_st *CUgraph; /**< CUDA graph */ +typedef struct CUgraphNode_st *CUgraphNode; /**< CUDA graph node */ +typedef struct CUgraphExec_st *CUgraphExec; /**< CUDA executable graph */ +typedef struct CUmemPoolHandle_st *CUmemoryPool; /**< CUDA memory pool */ +typedef struct CUuserObject_st *CUuserObject; /**< CUDA user object for graphs */ +typedef cuuint64_t CUgraphConditionalHandle; /**< CUDA graph conditional handle */ +typedef struct CUgraphDeviceUpdatableNode_st *CUgraphDeviceNode; /**< CUDA graph device node handle */ +typedef struct CUasyncCallbackEntry_st *CUasyncCallbackHandle; /**< CUDA async notification callback handle */ +/*! + * \typedef typedef struct CUgreenCtx_st* CUgreenCtx + * A green context handle. This handle can be used safely from only one CPU thread at a time. + * Created via ::cuGreenCtxCreate + */ +typedef struct CUgreenCtx_st *CUgreenCtx; + +#ifndef CU_UUID_HAS_BEEN_DEFINED +#define CU_UUID_HAS_BEEN_DEFINED +typedef struct CUuuid_st { /**< CUDA definition of UUID */ + char bytes[16]; +} CUuuid; +#endif + +/** + * CUDA IPC handle size + */ +#define CU_IPC_HANDLE_SIZE 64 + +/** + * Fabric handle - An opaque handle representing a memory allocation + * that can be exported to processes in same or different nodes. For IPC + * between processes on different nodes they must be connected via the + * NVSwitch fabric. + */ +typedef struct CUmemFabricHandle_st { + unsigned char data[CU_IPC_HANDLE_SIZE]; +} CUmemFabricHandle_v1; +typedef CUmemFabricHandle_v1 CUmemFabricHandle; + +/** + * CUDA IPC event handle + */ +typedef struct CUipcEventHandle_st { + char reserved[CU_IPC_HANDLE_SIZE]; +} CUipcEventHandle_v1; +typedef CUipcEventHandle_v1 CUipcEventHandle; + +/** + * CUDA IPC mem handle + */ +typedef struct CUipcMemHandle_st { + char reserved[CU_IPC_HANDLE_SIZE]; +} CUipcMemHandle_v1; +typedef CUipcMemHandle_v1 CUipcMemHandle; + +/** + * CUDA Ipc Mem Flags + */ +typedef enum CUipcMem_flags_enum { + CU_IPC_MEM_LAZY_ENABLE_PEER_ACCESS = 0x1 /**< Automatically enable peer access between remote devices as needed */ +} CUipcMem_flags; + + +/** + * CUDA Mem Attach Flags + */ +typedef enum CUmemAttach_flags_enum { + CU_MEM_ATTACH_GLOBAL = 0x1, /**< Memory can be accessed by any stream on any device */ + CU_MEM_ATTACH_HOST = 0x2, /**< Memory cannot be accessed by any stream on any device */ + CU_MEM_ATTACH_SINGLE = 0x4 /**< Memory can only be accessed by a single stream on the associated device */ +} CUmemAttach_flags; + +/** + * Context creation flags + */ +typedef enum CUctx_flags_enum { + CU_CTX_SCHED_AUTO = 0x00, /**< Automatic scheduling */ + CU_CTX_SCHED_SPIN = 0x01, /**< Set spin as default scheduling */ + CU_CTX_SCHED_YIELD = 0x02, /**< Set yield as default scheduling */ + CU_CTX_SCHED_BLOCKING_SYNC = 0x04, /**< Set blocking synchronization as default scheduling */ + CU_CTX_BLOCKING_SYNC = 0x04, /**< Set blocking synchronization as default scheduling + * \deprecated This flag was deprecated as of CUDA 4.0 + * and was replaced with ::CU_CTX_SCHED_BLOCKING_SYNC. */ + CU_CTX_SCHED_MASK = 0x07, + CU_CTX_MAP_HOST = 0x08, /**< \deprecated This flag was deprecated as of CUDA 11.0 + * and it no longer has any effect. All contexts + * as of CUDA 3.2 behave as though the flag is enabled. */ + CU_CTX_LMEM_RESIZE_TO_MAX = 0x10, /**< Keep local memory allocation after launch */ + CU_CTX_COREDUMP_ENABLE = 0x20, /**< Trigger coredumps from exceptions in this context */ + CU_CTX_USER_COREDUMP_ENABLE= 0x40, /**< Enable user pipe to trigger coredumps in this context */ + CU_CTX_SYNC_MEMOPS = 0x80, /**< Ensure synchronous memory operations on this context will synchronize */ + CU_CTX_FLAGS_MASK = 0xFF +} CUctx_flags; + +/** + * Event sched flags + */ +typedef enum CUevent_sched_flags_enum { + CU_EVENT_SCHED_AUTO = 0x00, /**< Automatic scheduling */ + CU_EVENT_SCHED_SPIN = 0x01, /**< Set spin as default scheduling */ + CU_EVENT_SCHED_YIELD = 0x02, /**< Set yield as default scheduling */ + CU_EVENT_SCHED_BLOCKING_SYNC = 0x04, /**< Set blocking synchronization as default scheduling */ +} CUevent_sched_flags; + +/** + * NVCL event scheduling flags + */ +typedef enum cl_event_flags_enum { + NVCL_EVENT_SCHED_AUTO = 0x00, /**< Automatic scheduling */ + NVCL_EVENT_SCHED_SPIN = 0x01, /**< Set spin as default scheduling */ + NVCL_EVENT_SCHED_YIELD = 0x02, /**< Set yield as default scheduling */ + NVCL_EVENT_SCHED_BLOCKING_SYNC = 0x04, /**< Set blocking synchronization as default scheduling */ +} cl_event_flags; + +/** + * NVCL context scheduling flags + */ +typedef enum cl_context_flags_enum { + NVCL_CTX_SCHED_AUTO = 0x00, /**< Automatic scheduling */ + NVCL_CTX_SCHED_SPIN = 0x01, /**< Set spin as default scheduling */ + NVCL_CTX_SCHED_YIELD = 0x02, /**< Set yield as default scheduling */ + NVCL_CTX_SCHED_BLOCKING_SYNC = 0x04, /**< Set blocking synchronization as default scheduling */ +} cl_context_flags; + + +/** + * Stream creation flags + */ +typedef enum CUstream_flags_enum { + CU_STREAM_DEFAULT = 0x0, /**< Default stream flag */ + CU_STREAM_NON_BLOCKING = 0x1 /**< Stream does not synchronize with stream 0 (the NULL stream) */ +} CUstream_flags; + +/** + * Legacy stream handle + * + * Stream handle that can be passed as a CUstream to use an implicit stream + * with legacy synchronization behavior. + * + * See details of the \link_sync_behavior + */ +#define CU_STREAM_LEGACY ((CUstream)0x1) + +/** + * Per-thread stream handle + * + * Stream handle that can be passed as a CUstream to use an implicit stream + * with per-thread synchronization behavior. + * + * See details of the \link_sync_behavior + */ +#define CU_STREAM_PER_THREAD ((CUstream)0x2) + +/** + * Event creation flags + */ +typedef enum CUevent_flags_enum { + CU_EVENT_DEFAULT = 0x0, /**< Default event flag */ + CU_EVENT_BLOCKING_SYNC = 0x1, /**< Event uses blocking synchronization */ + CU_EVENT_DISABLE_TIMING = 0x2, /**< Event will not record timing data */ + CU_EVENT_INTERPROCESS = 0x4 /**< Event is suitable for interprocess use. CU_EVENT_DISABLE_TIMING must be set */ +} CUevent_flags; + +/** + * Event record flags + */ +typedef enum CUevent_record_flags_enum { + CU_EVENT_RECORD_DEFAULT = 0x0, /**< Default event record flag */ + CU_EVENT_RECORD_EXTERNAL = 0x1 /**< When using stream capture, create an event record node + * instead of the default behavior. This flag is invalid + * when used outside of capture. */ +} CUevent_record_flags; + +/** + * Event wait flags + */ +typedef enum CUevent_wait_flags_enum { + CU_EVENT_WAIT_DEFAULT = 0x0, /**< Default event wait flag */ + CU_EVENT_WAIT_EXTERNAL = 0x1 /**< When using stream capture, create an event wait node + * instead of the default behavior. This flag is invalid + * when used outside of capture.*/ +} CUevent_wait_flags; + +/** + * Flags for ::cuStreamWaitValue32 and ::cuStreamWaitValue64 + */ +typedef enum CUstreamWaitValue_flags_enum { + CU_STREAM_WAIT_VALUE_GEQ = 0x0, /**< Wait until (int32_t)(*addr - value) >= 0 (or int64_t for 64 bit + values). Note this is a cyclic comparison which ignores wraparound. + (Default behavior.) */ + CU_STREAM_WAIT_VALUE_EQ = 0x1, /**< Wait until *addr == value. */ + CU_STREAM_WAIT_VALUE_AND = 0x2, /**< Wait until (*addr & value) != 0. */ + CU_STREAM_WAIT_VALUE_NOR = 0x3, /**< Wait until ~(*addr | value) != 0. Support for this operation can be + queried with ::cuDeviceGetAttribute() and + ::CU_DEVICE_ATTRIBUTE_CAN_USE_STREAM_WAIT_VALUE_NOR.*/ + CU_STREAM_WAIT_VALUE_FLUSH = 1<<30 /**< Follow the wait operation with a flush of outstanding remote writes. This + means that, if a remote write operation is guaranteed to have reached the + device before the wait can be satisfied, that write is guaranteed to be + visible to downstream device work. The device is permitted to reorder + remote writes internally. For example, this flag would be required if + two remote writes arrive in a defined order, the wait is satisfied by the + second write, and downstream work needs to observe the first write. + Support for this operation is restricted to selected platforms and can be + queried with ::CU_DEVICE_ATTRIBUTE_CAN_FLUSH_REMOTE_WRITES.*/ +} CUstreamWaitValue_flags; + +/** + * Flags for ::cuStreamWriteValue32 + */ +typedef enum CUstreamWriteValue_flags_enum { + CU_STREAM_WRITE_VALUE_DEFAULT = 0x0, /**< Default behavior */ + CU_STREAM_WRITE_VALUE_NO_MEMORY_BARRIER = 0x1 /**< Permits the write to be reordered with writes which were issued + before it, as a performance optimization. Normally, + ::cuStreamWriteValue32 will provide a memory fence before the + write, which has similar semantics to + __threadfence_system() but is scoped to the stream + rather than a CUDA thread. + This flag is not supported in the v2 API. */ +} CUstreamWriteValue_flags; + +/** + * Operations for ::cuStreamBatchMemOp + */ +typedef enum CUstreamBatchMemOpType_enum { + CU_STREAM_MEM_OP_WAIT_VALUE_32 = 1, /**< Represents a ::cuStreamWaitValue32 operation */ + CU_STREAM_MEM_OP_WRITE_VALUE_32 = 2, /**< Represents a ::cuStreamWriteValue32 operation */ + CU_STREAM_MEM_OP_WAIT_VALUE_64 = 4, /**< Represents a ::cuStreamWaitValue64 operation */ + CU_STREAM_MEM_OP_WRITE_VALUE_64 = 5, /**< Represents a ::cuStreamWriteValue64 operation */ + CU_STREAM_MEM_OP_BARRIER = 6, /**< Insert a memory barrier of the specified type */ + CU_STREAM_MEM_OP_FLUSH_REMOTE_WRITES = 3 /**< This has the same effect as ::CU_STREAM_WAIT_VALUE_FLUSH, but as a + standalone operation. */ +} CUstreamBatchMemOpType; + +/** + * Flags for ::cuStreamMemoryBarrier + */ +typedef enum CUstreamMemoryBarrier_flags_enum { + CU_STREAM_MEMORY_BARRIER_TYPE_SYS = 0x0, /**< System-wide memory barrier. */ + CU_STREAM_MEMORY_BARRIER_TYPE_GPU = 0x1 /**< Limit memory barrier scope to the GPU. */ +} CUstreamMemoryBarrier_flags; + +/** + * Per-operation parameters for ::cuStreamBatchMemOp + */ +typedef union CUstreamBatchMemOpParams_union { + CUstreamBatchMemOpType operation; + struct CUstreamMemOpWaitValueParams_st { + CUstreamBatchMemOpType operation; + CUdeviceptr address; + union { + cuuint32_t value; + cuuint64_t value64; + }; + unsigned int flags; + CUdeviceptr alias; /**< For driver internal use. Initial value is unimportant. */ + } waitValue; + struct CUstreamMemOpWriteValueParams_st { + CUstreamBatchMemOpType operation; + CUdeviceptr address; + union { + cuuint32_t value; + cuuint64_t value64; + }; + unsigned int flags; + CUdeviceptr alias; /**< For driver internal use. Initial value is unimportant. */ + } writeValue; + struct CUstreamMemOpFlushRemoteWritesParams_st { + CUstreamBatchMemOpType operation; + unsigned int flags; + } flushRemoteWrites; + struct CUstreamMemOpMemoryBarrierParams_st { /**< Only supported in the _v2 API */ + CUstreamBatchMemOpType operation; + unsigned int flags; + } memoryBarrier; + cuuint64_t pad[6]; +} CUstreamBatchMemOpParams_v1; +typedef CUstreamBatchMemOpParams_v1 CUstreamBatchMemOpParams; + +typedef struct CUDA_BATCH_MEM_OP_NODE_PARAMS_v1_st { + CUcontext ctx; + unsigned int count; + CUstreamBatchMemOpParams *paramArray; + unsigned int flags; +} CUDA_BATCH_MEM_OP_NODE_PARAMS_v1; +typedef CUDA_BATCH_MEM_OP_NODE_PARAMS_v1 CUDA_BATCH_MEM_OP_NODE_PARAMS; + +/** + * Batch memory operation node parameters + */ +typedef struct CUDA_BATCH_MEM_OP_NODE_PARAMS_v2_st { + CUcontext ctx; /**< Context to use for the operations. */ + unsigned int count; /**< Number of operations in paramArray. */ + CUstreamBatchMemOpParams *paramArray; /**< Array of batch memory operations. */ + unsigned int flags; /**< Flags to control the node. */ +} CUDA_BATCH_MEM_OP_NODE_PARAMS_v2; + +/** + * Occupancy calculator flag + */ +typedef enum CUoccupancy_flags_enum { + CU_OCCUPANCY_DEFAULT = 0x0, /**< Default behavior */ + CU_OCCUPANCY_DISABLE_CACHING_OVERRIDE = 0x1 /**< Assume global caching is enabled and cannot be automatically turned off */ +} CUoccupancy_flags; + +/** + * Flags for ::cuStreamUpdateCaptureDependencies + */ +typedef enum CUstreamUpdateCaptureDependencies_flags_enum { + CU_STREAM_ADD_CAPTURE_DEPENDENCIES = 0x0, /**< Add new nodes to the dependency set */ + CU_STREAM_SET_CAPTURE_DEPENDENCIES = 0x1 /**< Replace the dependency set with the new nodes */ +} CUstreamUpdateCaptureDependencies_flags; + +/** +* Types of async notification that can be sent +*/ +typedef enum CUasyncNotificationType_enum { + CU_ASYNC_NOTIFICATION_TYPE_OVER_BUDGET = 0x1 +} CUasyncNotificationType; + +/** +* Information passed to the user via the async notification callback +*/ +typedef struct CUasyncNotificationInfo_st { + CUasyncNotificationType type; + union { + struct { + unsigned long long bytesOverBudget; + } overBudget; + } info; +} CUasyncNotificationInfo; + +/** + * CUDA async notification callback + * \param info Information describing what actions to take as a result of this trim notification. + * \param userData Pointer to user defined data provided at registration. + * \param callback The callback handle associated with this specific callback. + */ +typedef void (*CUasyncCallback)(CUasyncNotificationInfo *info, void *userData, CUasyncCallbackHandle callback); + +/** + * Array formats + */ +typedef enum CUarray_format_enum { + CU_AD_FORMAT_UNSIGNED_INT8 = 0x01, /**< Unsigned 8-bit integers */ + CU_AD_FORMAT_UNSIGNED_INT16 = 0x02, /**< Unsigned 16-bit integers */ + CU_AD_FORMAT_UNSIGNED_INT32 = 0x03, /**< Unsigned 32-bit integers */ + CU_AD_FORMAT_SIGNED_INT8 = 0x08, /**< Signed 8-bit integers */ + CU_AD_FORMAT_SIGNED_INT16 = 0x09, /**< Signed 16-bit integers */ + CU_AD_FORMAT_SIGNED_INT32 = 0x0a, /**< Signed 32-bit integers */ + CU_AD_FORMAT_HALF = 0x10, /**< 16-bit floating point */ + CU_AD_FORMAT_FLOAT = 0x20, /**< 32-bit floating point */ + CU_AD_FORMAT_NV12 = 0xb0, /**< 8-bit YUV planar format, with 4:2:0 sampling */ + CU_AD_FORMAT_UNORM_INT8X1 = 0xc0, /**< 1 channel unsigned 8-bit normalized integer */ + CU_AD_FORMAT_UNORM_INT8X2 = 0xc1, /**< 2 channel unsigned 8-bit normalized integer */ + CU_AD_FORMAT_UNORM_INT8X4 = 0xc2, /**< 4 channel unsigned 8-bit normalized integer */ + CU_AD_FORMAT_UNORM_INT16X1 = 0xc3, /**< 1 channel unsigned 16-bit normalized integer */ + CU_AD_FORMAT_UNORM_INT16X2 = 0xc4, /**< 2 channel unsigned 16-bit normalized integer */ + CU_AD_FORMAT_UNORM_INT16X4 = 0xc5, /**< 4 channel unsigned 16-bit normalized integer */ + CU_AD_FORMAT_SNORM_INT8X1 = 0xc6, /**< 1 channel signed 8-bit normalized integer */ + CU_AD_FORMAT_SNORM_INT8X2 = 0xc7, /**< 2 channel signed 8-bit normalized integer */ + CU_AD_FORMAT_SNORM_INT8X4 = 0xc8, /**< 4 channel signed 8-bit normalized integer */ + CU_AD_FORMAT_SNORM_INT16X1 = 0xc9, /**< 1 channel signed 16-bit normalized integer */ + CU_AD_FORMAT_SNORM_INT16X2 = 0xca, /**< 2 channel signed 16-bit normalized integer */ + CU_AD_FORMAT_SNORM_INT16X4 = 0xcb, /**< 4 channel signed 16-bit normalized integer */ + CU_AD_FORMAT_BC1_UNORM = 0x91, /**< 4 channel unsigned normalized block-compressed (BC1 compression) format */ + CU_AD_FORMAT_BC1_UNORM_SRGB = 0x92, /**< 4 channel unsigned normalized block-compressed (BC1 compression) format with sRGB encoding*/ + CU_AD_FORMAT_BC2_UNORM = 0x93, /**< 4 channel unsigned normalized block-compressed (BC2 compression) format */ + CU_AD_FORMAT_BC2_UNORM_SRGB = 0x94, /**< 4 channel unsigned normalized block-compressed (BC2 compression) format with sRGB encoding*/ + CU_AD_FORMAT_BC3_UNORM = 0x95, /**< 4 channel unsigned normalized block-compressed (BC3 compression) format */ + CU_AD_FORMAT_BC3_UNORM_SRGB = 0x96, /**< 4 channel unsigned normalized block-compressed (BC3 compression) format with sRGB encoding*/ + CU_AD_FORMAT_BC4_UNORM = 0x97, /**< 1 channel unsigned normalized block-compressed (BC4 compression) format */ + CU_AD_FORMAT_BC4_SNORM = 0x98, /**< 1 channel signed normalized block-compressed (BC4 compression) format */ + CU_AD_FORMAT_BC5_UNORM = 0x99, /**< 2 channel unsigned normalized block-compressed (BC5 compression) format */ + CU_AD_FORMAT_BC5_SNORM = 0x9a, /**< 2 channel signed normalized block-compressed (BC5 compression) format */ + CU_AD_FORMAT_BC6H_UF16 = 0x9b, /**< 3 channel unsigned half-float block-compressed (BC6H compression) format */ + CU_AD_FORMAT_BC6H_SF16 = 0x9c, /**< 3 channel signed half-float block-compressed (BC6H compression) format */ + CU_AD_FORMAT_BC7_UNORM = 0x9d, /**< 4 channel unsigned normalized block-compressed (BC7 compression) format */ + CU_AD_FORMAT_BC7_UNORM_SRGB = 0x9e, /**< 4 channel unsigned normalized block-compressed (BC7 compression) format with sRGB encoding */ + CU_AD_FORMAT_P010 = 0x9f, /**< 10-bit YUV planar format, with 4:2:0 sampling */ + CU_AD_FORMAT_P016 = 0xa1, /**< 16-bit YUV planar format, with 4:2:0 sampling */ + CU_AD_FORMAT_NV16 = 0xa2, /**< 8-bit YUV planar format, with 4:2:2 sampling */ + CU_AD_FORMAT_P210 = 0xa3, /**< 10-bit YUV planar format, with 4:2:2 sampling */ + CU_AD_FORMAT_P216 = 0xa4, /**< 16-bit YUV planar format, with 4:2:2 sampling */ + CU_AD_FORMAT_YUY2 = 0xa5, /**< 2 channel, 8-bit YUV packed planar format, with 4:2:2 sampling */ + CU_AD_FORMAT_Y210 = 0xa6, /**< 2 channel, 10-bit YUV packed planar format, with 4:2:2 sampling */ + CU_AD_FORMAT_Y216 = 0xa7, /**< 2 channel, 16-bit YUV packed planar format, with 4:2:2 sampling */ + CU_AD_FORMAT_AYUV = 0xa8, /**< 4 channel, 8-bit YUV packed planar format, with 4:4:4 sampling */ + CU_AD_FORMAT_Y410 = 0xa9, /**< 10-bit YUV packed planar format, with 4:4:4 sampling */ + CU_AD_FORMAT_Y416 = 0xb1, /**< 4 channel, 12-bit YUV packed planar format, with 4:4:4 sampling */ + CU_AD_FORMAT_Y444_PLANAR8 = 0xb2, /**< 3 channel 8-bit YUV planar format, with 4:4:4 sampling */ + CU_AD_FORMAT_Y444_PLANAR10 = 0xb3, /**< 3 channel 10-bit YUV planar format, with 4:4:4 sampling */ + CU_AD_FORMAT_MAX = 0x7FFFFFFF +} CUarray_format; + +/** + * Texture reference addressing modes + */ +typedef enum CUaddress_mode_enum { + CU_TR_ADDRESS_MODE_WRAP = 0, /**< Wrapping address mode */ + CU_TR_ADDRESS_MODE_CLAMP = 1, /**< Clamp to edge address mode */ + CU_TR_ADDRESS_MODE_MIRROR = 2, /**< Mirror address mode */ + CU_TR_ADDRESS_MODE_BORDER = 3 /**< Border address mode */ +} CUaddress_mode; + +/** + * Texture reference filtering modes + */ +typedef enum CUfilter_mode_enum { + CU_TR_FILTER_MODE_POINT = 0, /**< Point filter mode */ + CU_TR_FILTER_MODE_LINEAR = 1 /**< Linear filter mode */ +} CUfilter_mode; + +/** + * Device properties + */ +typedef enum CUdevice_attribute_enum { + CU_DEVICE_ATTRIBUTE_MAX_THREADS_PER_BLOCK = 1, /**< Maximum number of threads per block */ + CU_DEVICE_ATTRIBUTE_MAX_BLOCK_DIM_X = 2, /**< Maximum block dimension X */ + CU_DEVICE_ATTRIBUTE_MAX_BLOCK_DIM_Y = 3, /**< Maximum block dimension Y */ + CU_DEVICE_ATTRIBUTE_MAX_BLOCK_DIM_Z = 4, /**< Maximum block dimension Z */ + CU_DEVICE_ATTRIBUTE_MAX_GRID_DIM_X = 5, /**< Maximum grid dimension X */ + CU_DEVICE_ATTRIBUTE_MAX_GRID_DIM_Y = 6, /**< Maximum grid dimension Y */ + CU_DEVICE_ATTRIBUTE_MAX_GRID_DIM_Z = 7, /**< Maximum grid dimension Z */ + CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK = 8, /**< Maximum shared memory available per block in bytes */ + CU_DEVICE_ATTRIBUTE_SHARED_MEMORY_PER_BLOCK = 8, /**< Deprecated, use CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK */ + CU_DEVICE_ATTRIBUTE_TOTAL_CONSTANT_MEMORY = 9, /**< Memory available on device for __constant__ variables in a CUDA C kernel in bytes */ + CU_DEVICE_ATTRIBUTE_WARP_SIZE = 10, /**< Warp size in threads */ + CU_DEVICE_ATTRIBUTE_MAX_PITCH = 11, /**< Maximum pitch in bytes allowed by memory copies */ + CU_DEVICE_ATTRIBUTE_MAX_REGISTERS_PER_BLOCK = 12, /**< Maximum number of 32-bit registers available per block */ + CU_DEVICE_ATTRIBUTE_REGISTERS_PER_BLOCK = 12, /**< Deprecated, use CU_DEVICE_ATTRIBUTE_MAX_REGISTERS_PER_BLOCK */ + CU_DEVICE_ATTRIBUTE_CLOCK_RATE = 13, /**< Typical clock frequency in kilohertz */ + CU_DEVICE_ATTRIBUTE_TEXTURE_ALIGNMENT = 14, /**< Alignment requirement for textures */ + CU_DEVICE_ATTRIBUTE_GPU_OVERLAP = 15, /**< Device can possibly copy memory and execute a kernel concurrently. Deprecated. Use instead CU_DEVICE_ATTRIBUTE_ASYNC_ENGINE_COUNT. */ + CU_DEVICE_ATTRIBUTE_MULTIPROCESSOR_COUNT = 16, /**< Number of multiprocessors on device */ + CU_DEVICE_ATTRIBUTE_KERNEL_EXEC_TIMEOUT = 17, /**< Specifies whether there is a run time limit on kernels */ + CU_DEVICE_ATTRIBUTE_INTEGRATED = 18, /**< Device is integrated with host memory */ + CU_DEVICE_ATTRIBUTE_CAN_MAP_HOST_MEMORY = 19, /**< Device can map host memory into CUDA address space */ + CU_DEVICE_ATTRIBUTE_COMPUTE_MODE = 20, /**< Compute mode (See ::CUcomputemode for details) */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_WIDTH = 21, /**< Maximum 1D texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_WIDTH = 22, /**< Maximum 2D texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_HEIGHT = 23, /**< Maximum 2D texture height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_WIDTH = 24, /**< Maximum 3D texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_HEIGHT = 25, /**< Maximum 3D texture height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_DEPTH = 26, /**< Maximum 3D texture depth */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_WIDTH = 27, /**< Maximum 2D layered texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_HEIGHT = 28, /**< Maximum 2D layered texture height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_LAYERS = 29, /**< Maximum layers in a 2D layered texture */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_ARRAY_WIDTH = 27, /**< Deprecated, use CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_WIDTH */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_ARRAY_HEIGHT = 28, /**< Deprecated, use CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_HEIGHT */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_ARRAY_NUMSLICES = 29, /**< Deprecated, use CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_LAYERS */ + CU_DEVICE_ATTRIBUTE_SURFACE_ALIGNMENT = 30, /**< Alignment requirement for surfaces */ + CU_DEVICE_ATTRIBUTE_CONCURRENT_KERNELS = 31, /**< Device can possibly execute multiple kernels concurrently */ + CU_DEVICE_ATTRIBUTE_ECC_ENABLED = 32, /**< Device has ECC support enabled */ + CU_DEVICE_ATTRIBUTE_PCI_BUS_ID = 33, /**< PCI bus ID of the device */ + CU_DEVICE_ATTRIBUTE_PCI_DEVICE_ID = 34, /**< PCI device ID of the device */ + CU_DEVICE_ATTRIBUTE_TCC_DRIVER = 35, /**< Device is using TCC driver model */ + CU_DEVICE_ATTRIBUTE_MEMORY_CLOCK_RATE = 36, /**< Peak memory clock frequency in kilohertz */ + CU_DEVICE_ATTRIBUTE_GLOBAL_MEMORY_BUS_WIDTH = 37, /**< Global memory bus width in bits */ + CU_DEVICE_ATTRIBUTE_L2_CACHE_SIZE = 38, /**< Size of L2 cache in bytes */ + CU_DEVICE_ATTRIBUTE_MAX_THREADS_PER_MULTIPROCESSOR = 39, /**< Maximum resident threads per multiprocessor */ + CU_DEVICE_ATTRIBUTE_ASYNC_ENGINE_COUNT = 40, /**< Number of asynchronous engines */ + CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING = 41, /**< Device shares a unified address space with the host */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LAYERED_WIDTH = 42, /**< Maximum 1D layered texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LAYERED_LAYERS = 43, /**< Maximum layers in a 1D layered texture */ + CU_DEVICE_ATTRIBUTE_CAN_TEX2D_GATHER = 44, /**< Deprecated, do not use. */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_GATHER_WIDTH = 45, /**< Maximum 2D texture width if CUDA_ARRAY3D_TEXTURE_GATHER is set */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_GATHER_HEIGHT = 46, /**< Maximum 2D texture height if CUDA_ARRAY3D_TEXTURE_GATHER is set */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_WIDTH_ALTERNATE = 47, /**< Alternate maximum 3D texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_HEIGHT_ALTERNATE = 48, /**< Alternate maximum 3D texture height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_DEPTH_ALTERNATE = 49, /**< Alternate maximum 3D texture depth */ + CU_DEVICE_ATTRIBUTE_PCI_DOMAIN_ID = 50, /**< PCI domain ID of the device */ + CU_DEVICE_ATTRIBUTE_TEXTURE_PITCH_ALIGNMENT = 51, /**< Pitch alignment requirement for textures */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURECUBEMAP_WIDTH = 52, /**< Maximum cubemap texture width/height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURECUBEMAP_LAYERED_WIDTH = 53, /**< Maximum cubemap layered texture width/height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURECUBEMAP_LAYERED_LAYERS = 54, /**< Maximum layers in a cubemap layered texture */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE1D_WIDTH = 55, /**< Maximum 1D surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_WIDTH = 56, /**< Maximum 2D surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_HEIGHT = 57, /**< Maximum 2D surface height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE3D_WIDTH = 58, /**< Maximum 3D surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE3D_HEIGHT = 59, /**< Maximum 3D surface height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE3D_DEPTH = 60, /**< Maximum 3D surface depth */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE1D_LAYERED_WIDTH = 61, /**< Maximum 1D layered surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE1D_LAYERED_LAYERS = 62, /**< Maximum layers in a 1D layered surface */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_LAYERED_WIDTH = 63, /**< Maximum 2D layered surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_LAYERED_HEIGHT = 64, /**< Maximum 2D layered surface height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_LAYERED_LAYERS = 65, /**< Maximum layers in a 2D layered surface */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACECUBEMAP_WIDTH = 66, /**< Maximum cubemap surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACECUBEMAP_LAYERED_WIDTH = 67, /**< Maximum cubemap layered surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACECUBEMAP_LAYERED_LAYERS = 68, /**< Maximum layers in a cubemap layered surface */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LINEAR_WIDTH = 69, /**< Deprecated, do not use. Use cudaDeviceGetTexture1DLinearMaxWidth() or cuDeviceGetTexture1DLinearMaxWidth() instead. */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_WIDTH = 70, /**< Maximum 2D linear texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_HEIGHT = 71, /**< Maximum 2D linear texture height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_PITCH = 72, /**< Maximum 2D linear texture pitch in bytes */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_MIPMAPPED_WIDTH = 73, /**< Maximum mipmapped 2D texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_MIPMAPPED_HEIGHT = 74, /**< Maximum mipmapped 2D texture height */ + CU_DEVICE_ATTRIBUTE_COMPUTE_CAPABILITY_MAJOR = 75, /**< Major compute capability version number */ + CU_DEVICE_ATTRIBUTE_COMPUTE_CAPABILITY_MINOR = 76, /**< Minor compute capability version number */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_MIPMAPPED_WIDTH = 77, /**< Maximum mipmapped 1D texture width */ + CU_DEVICE_ATTRIBUTE_STREAM_PRIORITIES_SUPPORTED = 78, /**< Device supports stream priorities */ + CU_DEVICE_ATTRIBUTE_GLOBAL_L1_CACHE_SUPPORTED = 79, /**< Device supports caching globals in L1 */ + CU_DEVICE_ATTRIBUTE_LOCAL_L1_CACHE_SUPPORTED = 80, /**< Device supports caching locals in L1 */ + CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_MULTIPROCESSOR = 81, /**< Maximum shared memory available per multiprocessor in bytes */ + CU_DEVICE_ATTRIBUTE_MAX_REGISTERS_PER_MULTIPROCESSOR = 82, /**< Maximum number of 32-bit registers available per multiprocessor */ + CU_DEVICE_ATTRIBUTE_MANAGED_MEMORY = 83, /**< Device can allocate managed memory on this system */ + CU_DEVICE_ATTRIBUTE_MULTI_GPU_BOARD = 84, /**< Device is on a multi-GPU board */ + CU_DEVICE_ATTRIBUTE_MULTI_GPU_BOARD_GROUP_ID = 85, /**< Unique id for a group of devices on the same multi-GPU board */ + CU_DEVICE_ATTRIBUTE_HOST_NATIVE_ATOMIC_SUPPORTED = 86, /**< Link between the device and the host supports native atomic operations (this is a placeholder attribute, and is not supported on any current hardware)*/ + CU_DEVICE_ATTRIBUTE_SINGLE_TO_DOUBLE_PRECISION_PERF_RATIO = 87, /**< Ratio of single precision performance (in floating-point operations per second) to double precision performance */ + CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS = 88, /**< Device supports coherently accessing pageable memory without calling cudaHostRegister on it */ + CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS = 89, /**< Device can coherently access managed memory concurrently with the CPU */ + CU_DEVICE_ATTRIBUTE_COMPUTE_PREEMPTION_SUPPORTED = 90, /**< Device supports compute preemption. */ + CU_DEVICE_ATTRIBUTE_CAN_USE_HOST_POINTER_FOR_REGISTERED_MEM = 91, /**< Device can access host registered memory at the same virtual address as the CPU */ + CU_DEVICE_ATTRIBUTE_CAN_USE_STREAM_MEM_OPS_V1 = 92, /**< Deprecated, along with v1 MemOps API, ::cuStreamBatchMemOp and related APIs are supported. */ + CU_DEVICE_ATTRIBUTE_CAN_USE_64_BIT_STREAM_MEM_OPS_V1 = 93, /**< Deprecated, along with v1 MemOps API, 64-bit operations are supported in ::cuStreamBatchMemOp and related APIs. */ + CU_DEVICE_ATTRIBUTE_CAN_USE_STREAM_WAIT_VALUE_NOR_V1 = 94, /**< Deprecated, along with v1 MemOps API, ::CU_STREAM_WAIT_VALUE_NOR is supported. */ + CU_DEVICE_ATTRIBUTE_COOPERATIVE_LAUNCH = 95, /**< Device supports launching cooperative kernels via ::cuLaunchCooperativeKernel */ + CU_DEVICE_ATTRIBUTE_COOPERATIVE_MULTI_DEVICE_LAUNCH = 96, /**< Deprecated, ::cuLaunchCooperativeKernelMultiDevice is deprecated. */ + CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK_OPTIN = 97, /**< Maximum optin shared memory per block */ + CU_DEVICE_ATTRIBUTE_CAN_FLUSH_REMOTE_WRITES = 98, /**< The ::CU_STREAM_WAIT_VALUE_FLUSH flag and the ::CU_STREAM_MEM_OP_FLUSH_REMOTE_WRITES MemOp are supported on the device. See \ref CUDA_MEMOP for additional details. */ + CU_DEVICE_ATTRIBUTE_HOST_REGISTER_SUPPORTED = 99, /**< Device supports host memory registration via ::cudaHostRegister. */ + CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES = 100, /**< Device accesses pageable memory via the host's page tables. */ + CU_DEVICE_ATTRIBUTE_DIRECT_MANAGED_MEM_ACCESS_FROM_HOST = 101, /**< The host can directly access managed memory on the device without migration. */ + CU_DEVICE_ATTRIBUTE_VIRTUAL_ADDRESS_MANAGEMENT_SUPPORTED = 102, /**< Deprecated, Use CU_DEVICE_ATTRIBUTE_VIRTUAL_MEMORY_MANAGEMENT_SUPPORTED*/ + CU_DEVICE_ATTRIBUTE_VIRTUAL_MEMORY_MANAGEMENT_SUPPORTED = 102, /**< Device supports virtual memory management APIs like ::cuMemAddressReserve, ::cuMemCreate, ::cuMemMap and related APIs */ + CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_POSIX_FILE_DESCRIPTOR_SUPPORTED = 103, /**< Device supports exporting memory to a posix file descriptor with ::cuMemExportToShareableHandle, if requested via ::cuMemCreate */ + CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_WIN32_HANDLE_SUPPORTED = 104, /**< Device supports exporting memory to a Win32 NT handle with ::cuMemExportToShareableHandle, if requested via ::cuMemCreate */ + CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_WIN32_KMT_HANDLE_SUPPORTED = 105, /**< Device supports exporting memory to a Win32 KMT handle with ::cuMemExportToShareableHandle, if requested via ::cuMemCreate */ + CU_DEVICE_ATTRIBUTE_MAX_BLOCKS_PER_MULTIPROCESSOR = 106, /**< Maximum number of blocks per multiprocessor */ + CU_DEVICE_ATTRIBUTE_GENERIC_COMPRESSION_SUPPORTED = 107, /**< Device supports compression of memory */ + CU_DEVICE_ATTRIBUTE_MAX_PERSISTING_L2_CACHE_SIZE = 108, /**< Maximum L2 persisting lines capacity setting in bytes. */ + CU_DEVICE_ATTRIBUTE_MAX_ACCESS_POLICY_WINDOW_SIZE = 109, /**< Maximum value of CUaccessPolicyWindow::num_bytes. */ + CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_WITH_CUDA_VMM_SUPPORTED = 110, /**< Device supports specifying the GPUDirect RDMA flag with ::cuMemCreate */ + CU_DEVICE_ATTRIBUTE_RESERVED_SHARED_MEMORY_PER_BLOCK = 111, /**< Shared memory reserved by CUDA driver per block in bytes */ + CU_DEVICE_ATTRIBUTE_SPARSE_CUDA_ARRAY_SUPPORTED = 112, /**< Device supports sparse CUDA arrays and sparse CUDA mipmapped arrays */ + CU_DEVICE_ATTRIBUTE_READ_ONLY_HOST_REGISTER_SUPPORTED = 113, /**< Device supports using the ::cuMemHostRegister flag ::CU_MEMHOSTERGISTER_READ_ONLY to register memory that must be mapped as read-only to the GPU */ + CU_DEVICE_ATTRIBUTE_TIMELINE_SEMAPHORE_INTEROP_SUPPORTED = 114, /**< External timeline semaphore interop is supported on the device */ + CU_DEVICE_ATTRIBUTE_MEMORY_POOLS_SUPPORTED = 115, /**< Device supports using the ::cuMemAllocAsync and ::cuMemPool family of APIs */ + CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_SUPPORTED = 116, /**< Device supports GPUDirect RDMA APIs, like nvidia_p2p_get_pages (see https://docs.nvidia.com/cuda/gpudirect-rdma for more information) */ + CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_FLUSH_WRITES_OPTIONS = 117, /**< The returned attribute shall be interpreted as a bitmask, where the individual bits are described by the ::CUflushGPUDirectRDMAWritesOptions enum */ + CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_WRITES_ORDERING = 118, /**< GPUDirect RDMA writes to the device do not need to be flushed for consumers within the scope indicated by the returned attribute. See ::CUGPUDirectRDMAWritesOrdering for the numerical values returned here. */ + CU_DEVICE_ATTRIBUTE_MEMPOOL_SUPPORTED_HANDLE_TYPES = 119, /**< Handle types supported with mempool based IPC */ + CU_DEVICE_ATTRIBUTE_CLUSTER_LAUNCH = 120, /**< Indicates device supports cluster launch */ + CU_DEVICE_ATTRIBUTE_DEFERRED_MAPPING_CUDA_ARRAY_SUPPORTED = 121, /**< Device supports deferred mapping CUDA arrays and CUDA mipmapped arrays */ + CU_DEVICE_ATTRIBUTE_CAN_USE_64_BIT_STREAM_MEM_OPS = 122, /**< 64-bit operations are supported in ::cuStreamBatchMemOp and related MemOp APIs. */ + CU_DEVICE_ATTRIBUTE_CAN_USE_STREAM_WAIT_VALUE_NOR = 123, /**< ::CU_STREAM_WAIT_VALUE_NOR is supported by MemOp APIs. */ + CU_DEVICE_ATTRIBUTE_DMA_BUF_SUPPORTED = 124, /**< Device supports buffer sharing with dma_buf mechanism. */ + CU_DEVICE_ATTRIBUTE_IPC_EVENT_SUPPORTED = 125, /**< Device supports IPC Events. */ + CU_DEVICE_ATTRIBUTE_MEM_SYNC_DOMAIN_COUNT = 126, /**< Number of memory domains the device supports. */ + CU_DEVICE_ATTRIBUTE_TENSOR_MAP_ACCESS_SUPPORTED = 127, /**< Device supports accessing memory using Tensor Map. */ + CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_FABRIC_SUPPORTED = 128, /**< Device supports exporting memory to a fabric handle with cuMemExportToShareableHandle() or requested with cuMemCreate() */ + CU_DEVICE_ATTRIBUTE_UNIFIED_FUNCTION_POINTERS = 129, /**< Device supports unified function pointers. */ + CU_DEVICE_ATTRIBUTE_NUMA_CONFIG = 130, /**< NUMA configuration of a device: value is of type ::CUdeviceNumaConfig enum */ + CU_DEVICE_ATTRIBUTE_NUMA_ID = 131, /**< NUMA node ID of the GPU memory */ + CU_DEVICE_ATTRIBUTE_MULTICAST_SUPPORTED = 132, /**< Device supports switch multicast and reduction operations. */ + CU_DEVICE_ATTRIBUTE_MPS_ENABLED = 133, /**< Indicates if contexts created on this device will be shared via MPS */ + CU_DEVICE_ATTRIBUTE_HOST_NUMA_ID = 134, /**< NUMA ID of the host node closest to the device. Returns -1 when system does not support NUMA. */ + CU_DEVICE_ATTRIBUTE_D3D12_CIG_SUPPORTED = 135, /**< Device supports CIG with D3D12. */ + CU_DEVICE_ATTRIBUTE_MAX +} CUdevice_attribute; + +/** + * Legacy device properties + */ +typedef struct CUdevprop_st { + int maxThreadsPerBlock; /**< Maximum number of threads per block */ + int maxThreadsDim[3]; /**< Maximum size of each dimension of a block */ + int maxGridSize[3]; /**< Maximum size of each dimension of a grid */ + int sharedMemPerBlock; /**< Shared memory available per block in bytes */ + int totalConstantMemory; /**< Constant memory available on device in bytes */ + int SIMDWidth; /**< Warp size in threads */ + int memPitch; /**< Maximum pitch in bytes allowed by memory copies */ + int regsPerBlock; /**< 32-bit registers available per block */ + int clockRate; /**< Clock frequency in kilohertz */ + int textureAlign; /**< Alignment requirement for textures */ +} CUdevprop_v1; +typedef CUdevprop_v1 CUdevprop; + +/** + * Pointer information + */ +typedef enum CUpointer_attribute_enum { + CU_POINTER_ATTRIBUTE_CONTEXT = 1, /**< The ::CUcontext on which a pointer was allocated or registered */ + CU_POINTER_ATTRIBUTE_MEMORY_TYPE = 2, /**< The ::CUmemorytype describing the physical location of a pointer */ + CU_POINTER_ATTRIBUTE_DEVICE_POINTER = 3, /**< The address at which a pointer's memory may be accessed on the device */ + CU_POINTER_ATTRIBUTE_HOST_POINTER = 4, /**< The address at which a pointer's memory may be accessed on the host */ + CU_POINTER_ATTRIBUTE_P2P_TOKENS = 5, /**< A pair of tokens for use with the nv-p2p.h Linux kernel interface */ + CU_POINTER_ATTRIBUTE_SYNC_MEMOPS = 6, /**< Synchronize every synchronous memory operation initiated on this region */ + CU_POINTER_ATTRIBUTE_BUFFER_ID = 7, /**< A process-wide unique ID for an allocated memory region*/ + CU_POINTER_ATTRIBUTE_IS_MANAGED = 8, /**< Indicates if the pointer points to managed memory */ + CU_POINTER_ATTRIBUTE_DEVICE_ORDINAL = 9, /**< A device ordinal of a device on which a pointer was allocated or registered */ + CU_POINTER_ATTRIBUTE_IS_LEGACY_CUDA_IPC_CAPABLE = 10, /**< 1 if this pointer maps to an allocation that is suitable for ::cudaIpcGetMemHandle, 0 otherwise **/ + CU_POINTER_ATTRIBUTE_RANGE_START_ADDR = 11, /**< Starting address for this requested pointer */ + CU_POINTER_ATTRIBUTE_RANGE_SIZE = 12, /**< Size of the address range for this requested pointer */ + CU_POINTER_ATTRIBUTE_MAPPED = 13, /**< 1 if this pointer is in a valid address range that is mapped to a backing allocation, 0 otherwise **/ + CU_POINTER_ATTRIBUTE_ALLOWED_HANDLE_TYPES = 14, /**< Bitmask of allowed ::CUmemAllocationHandleType for this allocation **/ + CU_POINTER_ATTRIBUTE_IS_GPU_DIRECT_RDMA_CAPABLE = 15, /**< 1 if the memory this pointer is referencing can be used with the GPUDirect RDMA API **/ + CU_POINTER_ATTRIBUTE_ACCESS_FLAGS = 16, /**< Returns the access flags the device associated with the current context has on the corresponding memory referenced by the pointer given */ + CU_POINTER_ATTRIBUTE_MEMPOOL_HANDLE = 17, /**< Returns the mempool handle for the allocation if it was allocated from a mempool. Otherwise returns NULL. **/ + CU_POINTER_ATTRIBUTE_MAPPING_SIZE = 18, /**< Size of the actual underlying mapping that the pointer belongs to **/ + CU_POINTER_ATTRIBUTE_MAPPING_BASE_ADDR = 19, /**< The start address of the mapping that the pointer belongs to **/ + CU_POINTER_ATTRIBUTE_MEMORY_BLOCK_ID = 20 /**< A process-wide unique id corresponding to the physical allocation the pointer belongs to **/ +} CUpointer_attribute; + +/** + * Function properties + */ +typedef enum CUfunction_attribute_enum { + /** + * The maximum number of threads per block, beyond which a launch of the + * function would fail. This number depends on both the function and the + * device on which the function is currently loaded. + */ + CU_FUNC_ATTRIBUTE_MAX_THREADS_PER_BLOCK = 0, + + /** + * The size in bytes of statically-allocated shared memory required by + * this function. This does not include dynamically-allocated shared + * memory requested by the user at runtime. + */ + CU_FUNC_ATTRIBUTE_SHARED_SIZE_BYTES = 1, + + /** + * The size in bytes of user-allocated constant memory required by this + * function. + */ + CU_FUNC_ATTRIBUTE_CONST_SIZE_BYTES = 2, + + /** + * The size in bytes of local memory used by each thread of this function. + */ + CU_FUNC_ATTRIBUTE_LOCAL_SIZE_BYTES = 3, + + /** + * The number of registers used by each thread of this function. + */ + CU_FUNC_ATTRIBUTE_NUM_REGS = 4, + + /** + * The PTX virtual architecture version for which the function was + * compiled. This value is the major PTX version * 10 + the minor PTX + * version, so a PTX version 1.3 function would return the value 13. + * Note that this may return the undefined value of 0 for cubins + * compiled prior to CUDA 3.0. + */ + CU_FUNC_ATTRIBUTE_PTX_VERSION = 5, + + /** + * The binary architecture version for which the function was compiled. + * This value is the major binary version * 10 + the minor binary version, + * so a binary version 1.3 function would return the value 13. Note that + * this will return a value of 10 for legacy cubins that do not have a + * properly-encoded binary architecture version. + */ + CU_FUNC_ATTRIBUTE_BINARY_VERSION = 6, + + /** + * The attribute to indicate whether the function has been compiled with + * user specified option "-Xptxas --dlcm=ca" set . + */ + CU_FUNC_ATTRIBUTE_CACHE_MODE_CA = 7, + + /** + * The maximum size in bytes of dynamically-allocated shared memory that can be used by + * this function. If the user-specified dynamic shared memory size is larger than this + * value, the launch will fail. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES = 8, + + /** + * On devices where the L1 cache and shared memory use the same hardware resources, + * this sets the shared memory carveout preference, in percent of the total shared memory. + * Refer to ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_MULTIPROCESSOR. + * This is only a hint, and the driver can choose a different ratio if required to execute the function. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT = 9, + + /** + * If this attribute is set, the kernel must launch with a valid cluster + * size specified. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_CLUSTER_SIZE_MUST_BE_SET = 10, + + /** + * The required cluster width in blocks. The values must either all be 0 or + * all be positive. The validity of the cluster dimensions is otherwise + * checked at launch time. + * + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_WIDTH = 11, + + /** + * The required cluster height in blocks. The values must either all be 0 or + * all be positive. The validity of the cluster dimensions is otherwise + * checked at launch time. + * + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime should return CUDA_ERROR_NOT_PERMITTED. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_HEIGHT = 12, + + /** + * The required cluster depth in blocks. The values must either all be 0 or + * all be positive. The validity of the cluster dimensions is otherwise + * checked at launch time. + * + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime should return CUDA_ERROR_NOT_PERMITTED. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_DEPTH = 13, + + /** + * Whether the function can be launched with non-portable cluster size. 1 is + * allowed, 0 is disallowed. A non-portable cluster size may only function + * on the specific SKUs the program is tested on. The launch might fail if + * the program is run on a different hardware platform. + * + * CUDA API provides cudaOccupancyMaxActiveClusters to assist with checking + * whether the desired size can be launched on the current device. + * + * Portable Cluster Size + * + * A portable cluster size is guaranteed to be functional on all compute + * capabilities higher than the target compute capability. The portable + * cluster size for sm_90 is 8 blocks per cluster. This value may increase + * for future compute capabilities. + * + * The specific hardware unit may support higher cluster sizes that’s not + * guaranteed to be portable. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_NON_PORTABLE_CLUSTER_SIZE_ALLOWED = 14, + + /** + * The block scheduling policy of a function. The value type is + * CUclusterSchedulingPolicy / cudaClusterSchedulingPolicy. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE = 15, + + CU_FUNC_ATTRIBUTE_MAX +} CUfunction_attribute; + +/** + * Function cache configurations + */ +typedef enum CUfunc_cache_enum { + CU_FUNC_CACHE_PREFER_NONE = 0x00, /**< no preference for shared memory or L1 (default) */ + CU_FUNC_CACHE_PREFER_SHARED = 0x01, /**< prefer larger shared memory and smaller L1 cache */ + CU_FUNC_CACHE_PREFER_L1 = 0x02, /**< prefer larger L1 cache and smaller shared memory */ + CU_FUNC_CACHE_PREFER_EQUAL = 0x03 /**< prefer equal sized L1 cache and shared memory */ +} CUfunc_cache; + +/** + * \deprecated + * + * Shared memory configurations + */ +typedef enum CUsharedconfig_enum { + CU_SHARED_MEM_CONFIG_DEFAULT_BANK_SIZE = 0x00, /**< set default shared memory bank size */ + CU_SHARED_MEM_CONFIG_FOUR_BYTE_BANK_SIZE = 0x01, /**< set shared memory bank width to four bytes */ + CU_SHARED_MEM_CONFIG_EIGHT_BYTE_BANK_SIZE = 0x02 /**< set shared memory bank width to eight bytes */ +} CUsharedconfig; + +/** + * Shared memory carveout configurations. These may be passed to ::cuFuncSetAttribute or ::cuKernelSetAttribute + */ +typedef enum CUshared_carveout_enum { + CU_SHAREDMEM_CARVEOUT_DEFAULT = -1, /**< No preference for shared memory or L1 (default) */ + CU_SHAREDMEM_CARVEOUT_MAX_SHARED = 100, /**< Prefer maximum available shared memory, minimum L1 cache */ + CU_SHAREDMEM_CARVEOUT_MAX_L1 = 0 /**< Prefer maximum available L1 cache, minimum shared memory */ +} CUshared_carveout; + +/** + * Memory types + */ +typedef enum CUmemorytype_enum { + CU_MEMORYTYPE_HOST = 0x01, /**< Host memory */ + CU_MEMORYTYPE_DEVICE = 0x02, /**< Device memory */ + CU_MEMORYTYPE_ARRAY = 0x03, /**< Array memory */ + CU_MEMORYTYPE_UNIFIED = 0x04 /**< Unified device or host memory */ +} CUmemorytype; + +/** + * Compute Modes + */ +typedef enum CUcomputemode_enum { + CU_COMPUTEMODE_DEFAULT = 0, /**< Default compute mode (Multiple contexts allowed per device) */ + CU_COMPUTEMODE_PROHIBITED = 2, /**< Compute-prohibited mode (No contexts can be created on this device at this time) */ + CU_COMPUTEMODE_EXCLUSIVE_PROCESS = 3 /**< Compute-exclusive-process mode (Only one context used by a single process can be present on this device at a time) */ +} CUcomputemode; + +/** + * Memory advise values + */ +typedef enum CUmem_advise_enum { + CU_MEM_ADVISE_SET_READ_MOSTLY = 1, /**< Data will mostly be read and only occasionally be written to */ + CU_MEM_ADVISE_UNSET_READ_MOSTLY = 2, /**< Undo the effect of ::CU_MEM_ADVISE_SET_READ_MOSTLY */ + CU_MEM_ADVISE_SET_PREFERRED_LOCATION = 3, /**< Set the preferred location for the data as the specified device */ + CU_MEM_ADVISE_UNSET_PREFERRED_LOCATION = 4, /**< Clear the preferred location for the data */ + CU_MEM_ADVISE_SET_ACCESSED_BY = 5, /**< Data will be accessed by the specified device, so prevent page faults as much as possible */ + CU_MEM_ADVISE_UNSET_ACCESSED_BY = 6 /**< Let the Unified Memory subsystem decide on the page faulting policy for the specified device */ +} CUmem_advise; + +typedef enum CUmem_range_attribute_enum { + CU_MEM_RANGE_ATTRIBUTE_READ_MOSTLY = 1, /**< Whether the range will mostly be read and only occasionally be written to */ + CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION = 2, /**< The preferred location of the range */ + CU_MEM_RANGE_ATTRIBUTE_ACCESSED_BY = 3, /**< Memory range has ::CU_MEM_ADVISE_SET_ACCESSED_BY set for specified device */ + CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION = 4 /**< The last location to which the range was prefetched */ + , CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_TYPE = 5 /**< The preferred location type of the range */ + , CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_ID = 6 /**< The preferred location id of the range */ + , CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_TYPE = 7 /**< The last location type to which the range was prefetched */ + , CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_ID = 8 /**< The last location id to which the range was prefetched */ +} CUmem_range_attribute; + +/** + * Online compiler and linker options + */ +typedef enum CUjit_option_enum +{ + /** + * Max number of registers that a thread may use.\n + * Option type: unsigned int\n + * Applies to: compiler only + */ + CU_JIT_MAX_REGISTERS = 0, + + /** + * IN: Specifies minimum number of threads per block to target compilation + * for\n + * OUT: Returns the number of threads the compiler actually targeted. + * This restricts the resource utilization of the compiler (e.g. max + * registers) such that a block with the given number of threads should be + * able to launch based on register limitations. Note, this option does not + * currently take into account any other resource limitations, such as + * shared memory utilization.\n + * Cannot be combined with ::CU_JIT_TARGET.\n + * Option type: unsigned int\n + * Applies to: compiler only + */ + CU_JIT_THREADS_PER_BLOCK = 1, + + /** + * Overwrites the option value with the total wall clock time, in + * milliseconds, spent in the compiler and linker\n + * Option type: float\n + * Applies to: compiler and linker + */ + CU_JIT_WALL_TIME = 2, + + /** + * Pointer to a buffer in which to print any log messages + * that are informational in nature (the buffer size is specified via + * option ::CU_JIT_INFO_LOG_BUFFER_SIZE_BYTES)\n + * Option type: char *\n + * Applies to: compiler and linker + */ + CU_JIT_INFO_LOG_BUFFER = 3, + + /** + * IN: Log buffer size in bytes. Log messages will be capped at this size + * (including null terminator)\n + * OUT: Amount of log buffer filled with messages\n + * Option type: unsigned int\n + * Applies to: compiler and linker + */ + CU_JIT_INFO_LOG_BUFFER_SIZE_BYTES = 4, + + /** + * Pointer to a buffer in which to print any log messages that + * reflect errors (the buffer size is specified via option + * ::CU_JIT_ERROR_LOG_BUFFER_SIZE_BYTES)\n + * Option type: char *\n + * Applies to: compiler and linker + */ + CU_JIT_ERROR_LOG_BUFFER = 5, + + /** + * IN: Log buffer size in bytes. Log messages will be capped at this size + * (including null terminator)\n + * OUT: Amount of log buffer filled with messages\n + * Option type: unsigned int\n + * Applies to: compiler and linker + */ + CU_JIT_ERROR_LOG_BUFFER_SIZE_BYTES = 6, + + /** + * Level of optimizations to apply to generated code (0 - 4), with 4 + * being the default and highest level of optimizations.\n + * Option type: unsigned int\n + * Applies to: compiler only + */ + CU_JIT_OPTIMIZATION_LEVEL = 7, + + /** + * No option value required. Determines the target based on the current + * attached context (default)\n + * Option type: No option value needed\n + * Applies to: compiler and linker + */ + CU_JIT_TARGET_FROM_CUCONTEXT = 8, + + /** + * Target is chosen based on supplied ::CUjit_target. Cannot be + * combined with ::CU_JIT_THREADS_PER_BLOCK.\n + * Option type: unsigned int for enumerated type ::CUjit_target\n + * Applies to: compiler and linker + */ + CU_JIT_TARGET = 9, + + /** + * Specifies choice of fallback strategy if matching cubin is not found. + * Choice is based on supplied ::CUjit_fallback. This option cannot be + * used with cuLink* APIs as the linker requires exact matches.\n + * Option type: unsigned int for enumerated type ::CUjit_fallback\n + * Applies to: compiler only + */ + CU_JIT_FALLBACK_STRATEGY = 10, + + /** + * Specifies whether to create debug information in output (-g) + * (0: false, default)\n + * Option type: int\n + * Applies to: compiler and linker + */ + CU_JIT_GENERATE_DEBUG_INFO = 11, + + /** + * Generate verbose log messages (0: false, default)\n + * Option type: int\n + * Applies to: compiler and linker + */ + CU_JIT_LOG_VERBOSE = 12, + + /** + * Generate line number information (-lineinfo) (0: false, default)\n + * Option type: int\n + * Applies to: compiler only + */ + CU_JIT_GENERATE_LINE_INFO = 13, + + /** + * Specifies whether to enable caching explicitly (-dlcm) \n + * Choice is based on supplied ::CUjit_cacheMode_enum.\n + * Option type: unsigned int for enumerated type ::CUjit_cacheMode_enum\n + * Applies to: compiler only + */ + CU_JIT_CACHE_MODE = 14, + + /** + * \deprecated + * This jit option is deprecated and should not be used. + */ + CU_JIT_NEW_SM3X_OPT = 15, + + /** + * This jit option is used for internal purpose only. + */ + CU_JIT_FAST_COMPILE = 16, + + /** + * Array of device symbol names that will be relocated to the corresponding + * host addresses stored in ::CU_JIT_GLOBAL_SYMBOL_ADDRESSES.\n + * Must contain ::CU_JIT_GLOBAL_SYMBOL_COUNT entries.\n + * When loading a device module, driver will relocate all encountered + * unresolved symbols to the host addresses.\n + * It is only allowed to register symbols that correspond to unresolved + * global variables.\n + * It is illegal to register the same device symbol at multiple addresses.\n + * Option type: const char **\n + * Applies to: dynamic linker only + */ + CU_JIT_GLOBAL_SYMBOL_NAMES = 17, + + /** + * Array of host addresses that will be used to relocate corresponding + * device symbols stored in ::CU_JIT_GLOBAL_SYMBOL_NAMES.\n + * Must contain ::CU_JIT_GLOBAL_SYMBOL_COUNT entries.\n + * Option type: void **\n + * Applies to: dynamic linker only + */ + CU_JIT_GLOBAL_SYMBOL_ADDRESSES = 18, + + /** + * Number of entries in ::CU_JIT_GLOBAL_SYMBOL_NAMES and + * ::CU_JIT_GLOBAL_SYMBOL_ADDRESSES arrays.\n + * Option type: unsigned int\n + * Applies to: dynamic linker only + */ + CU_JIT_GLOBAL_SYMBOL_COUNT = 19, + + /** + * \deprecated + * Enable link-time optimization (-dlto) for device code (Disabled by default).\n + * This option is not supported on 32-bit platforms.\n + * Option type: int\n + * Applies to: compiler and linker + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_LTO = 20, + + /** + * \deprecated + * Control single-precision denormals (-ftz) support (0: false, default). + * 1 : flushes denormal values to zero + * 0 : preserves denormal values + * Option type: int\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_FTZ = 21, + + /** + * \deprecated + * Control single-precision floating-point division and reciprocals + * (-prec-div) support (1: true, default). + * 1 : Enables the IEEE round-to-nearest mode + * 0 : Enables the fast approximation mode + * Option type: int\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_PREC_DIV = 22, + + /** + * \deprecated + * Control single-precision floating-point square root + * (-prec-sqrt) support (1: true, default). + * 1 : Enables the IEEE round-to-nearest mode + * 0 : Enables the fast approximation mode + * Option type: int\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_PREC_SQRT = 23, + + /** + * \deprecated + * Enable/Disable the contraction of floating-point multiplies + * and adds/subtracts into floating-point multiply-add (-fma) + * operations (1: Enable, default; 0: Disable). + * Option type: int\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_FMA = 24, + + /** + * \deprecated + * Array of kernel names that should be preserved at link time while others + * can be removed.\n + * Must contain ::CU_JIT_REFERENCED_KERNEL_COUNT entries.\n + * Note that kernel names can be mangled by the compiler in which case the + * mangled name needs to be specified.\n + * Wildcard "*" can be used to represent zero or more characters instead of + * specifying the full or mangled name.\n + * It is important to note that the wildcard "*" is also added implicitly. + * For example, specifying "foo" will match "foobaz", "barfoo", "barfoobaz" and + * thus preserve all kernels with those names. This can be avoided by providing + * a more specific name like "barfoobaz".\n + * Option type: const char **\n + * Applies to: dynamic linker only + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_REFERENCED_KERNEL_NAMES = 25, + + /** + * \deprecated + * Number of entries in ::CU_JIT_REFERENCED_KERNEL_NAMES array.\n + * Option type: unsigned int\n + * Applies to: dynamic linker only + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_REFERENCED_KERNEL_COUNT = 26, + + /** + * \deprecated + * Array of variable names (__device__ and/or __constant__) that should be + * preserved at link time while others can be removed.\n + * Must contain ::CU_JIT_REFERENCED_VARIABLE_COUNT entries.\n + * Note that variable names can be mangled by the compiler in which case the + * mangled name needs to be specified.\n + * Wildcard "*" can be used to represent zero or more characters instead of + * specifying the full or mangled name.\n + * It is important to note that the wildcard "*" is also added implicitly. + * For example, specifying "foo" will match "foobaz", "barfoo", "barfoobaz" and + * thus preserve all variables with those names. This can be avoided by providing + * a more specific name like "barfoobaz".\n + * Option type: const char **\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_REFERENCED_VARIABLE_NAMES = 27, + + /** + * \deprecated + * Number of entries in ::CU_JIT_REFERENCED_VARIABLE_NAMES array.\n + * Option type: unsigned int\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_REFERENCED_VARIABLE_COUNT = 28, + + /** + * \deprecated + * This option serves as a hint to enable the JIT compiler/linker + * to remove constant (__constant__) and device (__device__) variables + * unreferenced in device code (Disabled by default).\n + * Note that host references to constant and device variables using APIs like + * ::cuModuleGetGlobal() with this option specified may result in undefined behavior unless + * the variables are explicitly specified using ::CU_JIT_REFERENCED_VARIABLE_NAMES.\n + * Option type: int\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_OPTIMIZE_UNUSED_DEVICE_VARIABLES = 29, + + /** + * Generate position independent code (0: false)\n + * Option type: int\n + * Applies to: compiler only + */ + CU_JIT_POSITION_INDEPENDENT_CODE = 30, + + /** + * This option hints to the JIT compiler the minimum number of CTAs from the + * kernel’s grid to be mapped to a SM. This option is ignored when used together + * with ::CU_JIT_MAX_REGISTERS or ::CU_JIT_THREADS_PER_BLOCK. + * Optimizations based on this option need ::CU_JIT_MAX_THREADS_PER_BLOCK to + * be specified as well. For kernels already using PTX directive .minnctapersm, + * this option will be ignored by default. Use ::CU_JIT_OVERRIDE_DIRECTIVE_VALUES + * to let this option take precedence over the PTX directive. + * Option type: unsigned int\n + * Applies to: compiler only + */ + CU_JIT_MIN_CTA_PER_SM = 31, + + /** + * Maximum number threads in a thread block, computed as the product of + * the maximum extent specifed for each dimension of the block. This limit + * is guaranteed not to be exeeded in any invocation of the kernel. Exceeding + * the the maximum number of threads results in runtime error or kernel launch + * failure. For kernels already using PTX directive .maxntid, this option will + * be ignored by default. Use ::CU_JIT_OVERRIDE_DIRECTIVE_VALUES to let this + * option take precedence over the PTX directive. + * Option type: int\n + * Applies to: compiler only + */ + CU_JIT_MAX_THREADS_PER_BLOCK = 32, + + /** + * This option lets the values specified using ::CU_JIT_MAX_REGISTERS, + * ::CU_JIT_THREADS_PER_BLOCK, ::CU_JIT_MAX_THREADS_PER_BLOCK and + * ::CU_JIT_MIN_CTA_PER_SM take precedence over any PTX directives. + * (0: Disable, default; 1: Enable) + * Option type: int\n + * Applies to: compiler only + */ + CU_JIT_OVERRIDE_DIRECTIVE_VALUES = 33, + CU_JIT_NUM_OPTIONS + +} CUjit_option; + +/* + * Indicates that compute device class supports accelerated features. + */ +#define CU_COMPUTE_ACCELERATED_TARGET_BASE 0x10000 + +/** + * Online compilation targets + */ +typedef enum CUjit_target_enum +{ + CU_TARGET_COMPUTE_30 = 30, /**< Compute device class 3.0 */ + CU_TARGET_COMPUTE_32 = 32, /**< Compute device class 3.2 */ + CU_TARGET_COMPUTE_35 = 35, /**< Compute device class 3.5 */ + CU_TARGET_COMPUTE_37 = 37, /**< Compute device class 3.7 */ + CU_TARGET_COMPUTE_50 = 50, /**< Compute device class 5.0 */ + CU_TARGET_COMPUTE_52 = 52, /**< Compute device class 5.2 */ + CU_TARGET_COMPUTE_53 = 53, /**< Compute device class 5.3 */ + CU_TARGET_COMPUTE_60 = 60, /**< Compute device class 6.0.*/ + CU_TARGET_COMPUTE_61 = 61, /**< Compute device class 6.1.*/ + CU_TARGET_COMPUTE_62 = 62, /**< Compute device class 6.2.*/ + CU_TARGET_COMPUTE_70 = 70, /**< Compute device class 7.0.*/ + CU_TARGET_COMPUTE_72 = 72, /**< Compute device class 7.2.*/ + CU_TARGET_COMPUTE_75 = 75, /**< Compute device class 7.5.*/ + CU_TARGET_COMPUTE_80 = 80, /**< Compute device class 8.0.*/ + CU_TARGET_COMPUTE_86 = 86, /**< Compute device class 8.6.*/ + CU_TARGET_COMPUTE_87 = 87, /**< Compute device class 8.7.*/ + CU_TARGET_COMPUTE_89 = 89, /**< Compute device class 8.9.*/ + CU_TARGET_COMPUTE_90 = 90, /**< Compute device class 9.0.*/ + + /**< Compute device class 9.0. with accelerated features.*/ + CU_TARGET_COMPUTE_90A = CU_COMPUTE_ACCELERATED_TARGET_BASE + CU_TARGET_COMPUTE_90, +} CUjit_target; + +/** + * Cubin matching fallback strategies + */ +typedef enum CUjit_fallback_enum +{ + CU_PREFER_PTX = 0, /**< Prefer to compile ptx if exact binary match not found */ + + CU_PREFER_BINARY /**< Prefer to fall back to compatible binary code if exact match not found */ + +} CUjit_fallback; + +/** + * Caching modes for dlcm + */ +typedef enum CUjit_cacheMode_enum +{ + CU_JIT_CACHE_OPTION_NONE = 0, /**< Compile with no -dlcm flag specified */ + CU_JIT_CACHE_OPTION_CG, /**< Compile with L1 cache disabled */ + CU_JIT_CACHE_OPTION_CA /**< Compile with L1 cache enabled */ +} CUjit_cacheMode; + +/** + * Device code formats + */ +typedef enum CUjitInputType_enum +{ + /** + * Compiled device-class-specific device code\n + * Applicable options: none + */ + CU_JIT_INPUT_CUBIN = 0, + + /** + * PTX source code\n + * Applicable options: PTX compiler options + */ + CU_JIT_INPUT_PTX = 1, + + /** + * Bundle of multiple cubins and/or PTX of some device code\n + * Applicable options: PTX compiler options, ::CU_JIT_FALLBACK_STRATEGY + */ + CU_JIT_INPUT_FATBINARY = 2, + + /** + * Host object with embedded device code\n + * Applicable options: PTX compiler options, ::CU_JIT_FALLBACK_STRATEGY + */ + CU_JIT_INPUT_OBJECT = 3, + + /** + * Archive of host objects with embedded device code\n + * Applicable options: PTX compiler options, ::CU_JIT_FALLBACK_STRATEGY + */ + CU_JIT_INPUT_LIBRARY = 4, + + /** + * \deprecated + * High-level intermediate code for link-time optimization\n + * Applicable options: NVVM compiler options, PTX compiler options + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_INPUT_NVVM = 5, + + CU_JIT_NUM_INPUT_TYPES = 6 +} CUjitInputType; + +typedef struct CUlinkState_st *CUlinkState; + +/** + * Flags to register a graphics resource + */ +typedef enum CUgraphicsRegisterFlags_enum { + CU_GRAPHICS_REGISTER_FLAGS_NONE = 0x00, + CU_GRAPHICS_REGISTER_FLAGS_READ_ONLY = 0x01, + CU_GRAPHICS_REGISTER_FLAGS_WRITE_DISCARD = 0x02, + CU_GRAPHICS_REGISTER_FLAGS_SURFACE_LDST = 0x04, + CU_GRAPHICS_REGISTER_FLAGS_TEXTURE_GATHER = 0x08 +} CUgraphicsRegisterFlags; + +/** + * Flags for mapping and unmapping interop resources + */ +typedef enum CUgraphicsMapResourceFlags_enum { + CU_GRAPHICS_MAP_RESOURCE_FLAGS_NONE = 0x00, + CU_GRAPHICS_MAP_RESOURCE_FLAGS_READ_ONLY = 0x01, + CU_GRAPHICS_MAP_RESOURCE_FLAGS_WRITE_DISCARD = 0x02 +} CUgraphicsMapResourceFlags; + +/** + * Array indices for cube faces + */ +typedef enum CUarray_cubemap_face_enum { + CU_CUBEMAP_FACE_POSITIVE_X = 0x00, /**< Positive X face of cubemap */ + CU_CUBEMAP_FACE_NEGATIVE_X = 0x01, /**< Negative X face of cubemap */ + CU_CUBEMAP_FACE_POSITIVE_Y = 0x02, /**< Positive Y face of cubemap */ + CU_CUBEMAP_FACE_NEGATIVE_Y = 0x03, /**< Negative Y face of cubemap */ + CU_CUBEMAP_FACE_POSITIVE_Z = 0x04, /**< Positive Z face of cubemap */ + CU_CUBEMAP_FACE_NEGATIVE_Z = 0x05 /**< Negative Z face of cubemap */ +} CUarray_cubemap_face; + +/** + * Limits + */ +typedef enum CUlimit_enum { + CU_LIMIT_STACK_SIZE = 0x00, /**< GPU thread stack size */ + CU_LIMIT_PRINTF_FIFO_SIZE = 0x01, /**< GPU printf FIFO size */ + CU_LIMIT_MALLOC_HEAP_SIZE = 0x02, /**< GPU malloc heap size */ + CU_LIMIT_DEV_RUNTIME_SYNC_DEPTH = 0x03, /**< GPU device runtime launch synchronize depth */ + CU_LIMIT_DEV_RUNTIME_PENDING_LAUNCH_COUNT = 0x04, /**< GPU device runtime pending launch count */ + CU_LIMIT_MAX_L2_FETCH_GRANULARITY = 0x05, /**< A value between 0 and 128 that indicates the maximum fetch granularity of L2 (in Bytes). This is a hint */ + CU_LIMIT_PERSISTING_L2_CACHE_SIZE = 0x06, /**< A size in bytes for L2 persisting lines cache size */ + CU_LIMIT_SHMEM_SIZE = 0x07, /**< A maximum size in bytes of shared memory available to CUDA kernels on a CIG context. Can only be queried, cannot be set */ + CU_LIMIT_CIG_ENABLED = 0x08, /**< A non-zero value indicates this CUDA context is a CIG-enabled context. Can only be queried, cannot be set */ + CU_LIMIT_CIG_SHMEM_FALLBACK_ENABLED = 0x09, /**< When set to a non-zero value, CUDA will fail to launch a kernel on a CIG context, instead of using the fallback path, if the kernel uses more shared memory than available */ + CU_LIMIT_MAX +} CUlimit; + +/** + * Resource types + */ +typedef enum CUresourcetype_enum { + CU_RESOURCE_TYPE_ARRAY = 0x00, /**< Array resource */ + CU_RESOURCE_TYPE_MIPMAPPED_ARRAY = 0x01, /**< Mipmapped array resource */ + CU_RESOURCE_TYPE_LINEAR = 0x02, /**< Linear resource */ + CU_RESOURCE_TYPE_PITCH2D = 0x03 /**< Pitch 2D resource */ +} CUresourcetype; + +#ifdef _WIN32 +#define CUDA_CB __stdcall +#else +#define CUDA_CB +#endif + +/** + * CUDA host function + * \param userData Argument value passed to the function + */ +typedef void (CUDA_CB *CUhostFn)(void *userData); + +/** + * Specifies performance hint with ::CUaccessPolicyWindow for hitProp and missProp members. + */ +typedef enum CUaccessProperty_enum { + CU_ACCESS_PROPERTY_NORMAL = 0, /**< Normal cache persistence. */ + CU_ACCESS_PROPERTY_STREAMING = 1, /**< Streaming access is less likely to persit from cache. */ + CU_ACCESS_PROPERTY_PERSISTING = 2 /**< Persisting access is more likely to persist in cache.*/ +} CUaccessProperty; + +/** + * Specifies an access policy for a window, a contiguous extent of memory + * beginning at base_ptr and ending at base_ptr + num_bytes. + * num_bytes is limited by CU_DEVICE_ATTRIBUTE_MAX_ACCESS_POLICY_WINDOW_SIZE. + * Partition into many segments and assign segments such that: + * sum of "hit segments" / window == approx. ratio. + * sum of "miss segments" / window == approx 1-ratio. + * Segments and ratio specifications are fitted to the capabilities of + * the architecture. + * Accesses in a hit segment apply the hitProp access policy. + * Accesses in a miss segment apply the missProp access policy. + */ +typedef struct CUaccessPolicyWindow_st { + void *base_ptr; /**< Starting address of the access policy window. CUDA driver may align it. */ + size_t num_bytes; /**< Size in bytes of the window policy. CUDA driver may restrict the maximum size and alignment. */ + float hitRatio; /**< hitRatio specifies percentage of lines assigned hitProp, rest are assigned missProp. */ + CUaccessProperty hitProp; /**< ::CUaccessProperty set for hit. */ + CUaccessProperty missProp; /**< ::CUaccessProperty set for miss. Must be either NORMAL or STREAMING */ +} CUaccessPolicyWindow_v1; +/** + * Access policy window + */ +typedef CUaccessPolicyWindow_v1 CUaccessPolicyWindow; + +/** + * GPU kernel node parameters + */ +typedef struct CUDA_KERNEL_NODE_PARAMS_st { + CUfunction func; /**< Kernel to launch */ + unsigned int gridDimX; /**< Width of grid in blocks */ + unsigned int gridDimY; /**< Height of grid in blocks */ + unsigned int gridDimZ; /**< Depth of grid in blocks */ + unsigned int blockDimX; /**< X dimension of each thread block */ + unsigned int blockDimY; /**< Y dimension of each thread block */ + unsigned int blockDimZ; /**< Z dimension of each thread block */ + unsigned int sharedMemBytes; /**< Dynamic shared-memory size per thread block in bytes */ + void **kernelParams; /**< Array of pointers to kernel parameters */ + void **extra; /**< Extra options */ +} CUDA_KERNEL_NODE_PARAMS_v1; + +/** + * GPU kernel node parameters + */ +typedef struct CUDA_KERNEL_NODE_PARAMS_v2_st { + CUfunction func; /**< Kernel to launch */ + unsigned int gridDimX; /**< Width of grid in blocks */ + unsigned int gridDimY; /**< Height of grid in blocks */ + unsigned int gridDimZ; /**< Depth of grid in blocks */ + unsigned int blockDimX; /**< X dimension of each thread block */ + unsigned int blockDimY; /**< Y dimension of each thread block */ + unsigned int blockDimZ; /**< Z dimension of each thread block */ + unsigned int sharedMemBytes; /**< Dynamic shared-memory size per thread block in bytes */ + void **kernelParams; /**< Array of pointers to kernel parameters */ + void **extra; /**< Extra options */ + CUkernel kern; /**< Kernel to launch, will only be referenced if func is NULL */ + CUcontext ctx; /**< Context for the kernel task to run in. The value NULL will indicate the current context should be used by the api. This field is ignored if func is set. */ +} CUDA_KERNEL_NODE_PARAMS_v2; +typedef CUDA_KERNEL_NODE_PARAMS_v2 CUDA_KERNEL_NODE_PARAMS; + +/** + * GPU kernel node parameters + */ +typedef struct CUDA_KERNEL_NODE_PARAMS_v3_st { + CUfunction func; /**< Kernel to launch */ + unsigned int gridDimX; /**< Width of grid in blocks */ + unsigned int gridDimY; /**< Height of grid in blocks */ + unsigned int gridDimZ; /**< Depth of grid in blocks */ + unsigned int blockDimX; /**< X dimension of each thread block */ + unsigned int blockDimY; /**< Y dimension of each thread block */ + unsigned int blockDimZ; /**< Z dimension of each thread block */ + unsigned int sharedMemBytes; /**< Dynamic shared-memory size per thread block in bytes */ + void **kernelParams; /**< Array of pointers to kernel parameters */ + void **extra; /**< Extra options */ + CUkernel kern; /**< Kernel to launch, will only be referenced if func is NULL */ + CUcontext ctx; /**< Context for the kernel task to run in. The value NULL will indicate the current context should be used by the api. This field is ignored if func is set. */ +} CUDA_KERNEL_NODE_PARAMS_v3; + +/** + * Memset node parameters + */ +typedef struct CUDA_MEMSET_NODE_PARAMS_st { + CUdeviceptr dst; /**< Destination device pointer */ + size_t pitch; /**< Pitch of destination device pointer. Unused if height is 1 */ + unsigned int value; /**< Value to be set */ + unsigned int elementSize; /**< Size of each element in bytes. Must be 1, 2, or 4. */ + size_t width; /**< Width of the row in elements */ + size_t height; /**< Number of rows */ +} CUDA_MEMSET_NODE_PARAMS_v1; +typedef CUDA_MEMSET_NODE_PARAMS_v1 CUDA_MEMSET_NODE_PARAMS; + +/** + * Memset node parameters + */ +typedef struct CUDA_MEMSET_NODE_PARAMS_v2_st { + CUdeviceptr dst; /**< Destination device pointer */ + size_t pitch; /**< Pitch of destination device pointer. Unused if height is 1 */ + unsigned int value; /**< Value to be set */ + unsigned int elementSize; /**< Size of each element in bytes. Must be 1, 2, or 4. */ + size_t width; /**< Width of the row in elements */ + size_t height; /**< Number of rows */ + CUcontext ctx; /**< Context on which to run the node */ +} CUDA_MEMSET_NODE_PARAMS_v2; + +/** + * Host node parameters + */ +typedef struct CUDA_HOST_NODE_PARAMS_st { + CUhostFn fn; /**< The function to call when the node executes */ + void* userData; /**< Argument to pass to the function */ +} CUDA_HOST_NODE_PARAMS_v1; +typedef CUDA_HOST_NODE_PARAMS_v1 CUDA_HOST_NODE_PARAMS; + +/** + * Host node parameters + */ +typedef struct CUDA_HOST_NODE_PARAMS_v2_st { + CUhostFn fn; /**< The function to call when the node executes */ + void* userData; /**< Argument to pass to the function */ +} CUDA_HOST_NODE_PARAMS_v2; + +/** + * Conditional node handle flags + */ +#define CU_GRAPH_COND_ASSIGN_DEFAULT 0x1 /**< Default value is applied when graph is launched. */ + +/** + * Conditional node types + */ +typedef enum CUgraphConditionalNodeType_enum { + CU_GRAPH_COND_TYPE_IF = 0, /**< Conditional 'if' Node. Body executed once if condition value is non-zero. */ + CU_GRAPH_COND_TYPE_WHILE = 1, /**< Conditional 'while' Node. Body executed repeatedly while condition value is non-zero. */ +} CUgraphConditionalNodeType; + +/** + * Conditional node parameters + */ +typedef struct CUDA_CONDITIONAL_NODE_PARAMS { + CUgraphConditionalHandle handle; /**< Conditional node handle. + Handles must be created in advance of creating the node + using ::cuGraphConditionalHandleCreate. */ + CUgraphConditionalNodeType type; /**< Type of conditional node. */ + unsigned int size; /**< Size of graph output array. Must be 1. */ + CUgraph *phGraph_out; /**< CUDA-owned array populated with conditional node child graphs during creation of the node. + Valid for the lifetime of the conditional node. + The contents of the graph(s) are subject to the following constraints: + + - Allowed node types are kernel nodes, empty nodes, child graphs, memsets, + memcopies, and conditionals. This applies recursively to child graphs and conditional bodies. + - All kernels, including kernels in nested conditionals or child graphs at any level, + must belong to the same CUDA context. + + These graphs may be populated using graph node creation APIs or ::cuStreamBeginCaptureToGraph. */ + CUcontext ctx; /**< Context on which to run the node. Must match context used to create the handle and all body nodes. */ +} CUDA_CONDITIONAL_NODE_PARAMS; + +/** + * Graph node types + */ +typedef enum CUgraphNodeType_enum { + CU_GRAPH_NODE_TYPE_KERNEL = 0, /**< GPU kernel node */ + CU_GRAPH_NODE_TYPE_MEMCPY = 1, /**< Memcpy node */ + CU_GRAPH_NODE_TYPE_MEMSET = 2, /**< Memset node */ + CU_GRAPH_NODE_TYPE_HOST = 3, /**< Host (executable) node */ + CU_GRAPH_NODE_TYPE_GRAPH = 4, /**< Node which executes an embedded graph */ + CU_GRAPH_NODE_TYPE_EMPTY = 5, /**< Empty (no-op) node */ + CU_GRAPH_NODE_TYPE_WAIT_EVENT = 6, /**< External event wait node */ + CU_GRAPH_NODE_TYPE_EVENT_RECORD = 7, /**< External event record node */ + CU_GRAPH_NODE_TYPE_EXT_SEMAS_SIGNAL = 8, /**< External semaphore signal node */ + CU_GRAPH_NODE_TYPE_EXT_SEMAS_WAIT = 9, /**< External semaphore wait node */ + CU_GRAPH_NODE_TYPE_MEM_ALLOC = 10,/**< Memory Allocation Node */ + CU_GRAPH_NODE_TYPE_MEM_FREE = 11,/**< Memory Free Node */ + CU_GRAPH_NODE_TYPE_BATCH_MEM_OP = 12,/**< Batch MemOp Node */ + CU_GRAPH_NODE_TYPE_CONDITIONAL = 13 /**< Conditional Node + + May be used to implement a conditional execution path or loop + inside of a graph. The graph(s) contained within the body of the conditional node + can be selectively executed or iterated upon based on the value of a conditional + variable. + + Handles must be created in advance of creating the node + using ::cuGraphConditionalHandleCreate. + + The following restrictions apply to graphs which contain conditional nodes: + The graph cannot be used in a child node. + Only one instantiation of the graph may exist at any point in time. + The graph cannot be cloned. + + To set the control value, supply a default value when creating the handle and/or + call ::cudaGraphSetConditional from device code.*/ +} CUgraphNodeType; + +/** + * Type annotations that can be applied to graph edges as part of ::CUgraphEdgeData. + */ +typedef enum CUgraphDependencyType_enum { + CU_GRAPH_DEPENDENCY_TYPE_DEFAULT = 0, /**< This is an ordinary dependency. */ + CU_GRAPH_DEPENDENCY_TYPE_PROGRAMMATIC = 1 /**< This dependency type allows the downstream node to + use \c cudaGridDependencySynchronize(). It may only be used + between kernel nodes, and must be used with either the + ::CU_GRAPH_KERNEL_NODE_PORT_PROGRAMMATIC or + ::CU_GRAPH_KERNEL_NODE_PORT_LAUNCH_ORDER outgoing port. */ +} CUgraphDependencyType; + +/** + * This port activates when the kernel has finished executing. + */ +#define CU_GRAPH_KERNEL_NODE_PORT_DEFAULT 0 +/** + * This port activates when all blocks of the kernel have performed cudaTriggerProgrammaticLaunchCompletion() + * or have terminated. It must be used with edge type ::CU_GRAPH_DEPENDENCY_TYPE_PROGRAMMATIC. See also + * ::CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_EVENT. + */ +#define CU_GRAPH_KERNEL_NODE_PORT_PROGRAMMATIC 1 +/** + * This port activates when all blocks of the kernel have begun execution. See also + * ::CU_LAUNCH_ATTRIBUTE_LAUNCH_COMPLETION_EVENT. + */ +#define CU_GRAPH_KERNEL_NODE_PORT_LAUNCH_ORDER 2 + +/** + * Optional annotation for edges in a CUDA graph. Note, all edges implicitly have annotations and + * default to a zero-initialized value if not specified. A zero-initialized struct indicates a + * standard full serialization of two nodes with memory visibility. + */ +typedef struct CUgraphEdgeData_st { + unsigned char from_port; /**< This indicates when the dependency is triggered from the upstream + node on the edge. The meaning is specfic to the node type. A value + of 0 in all cases means full completion of the upstream node, with + memory visibility to the downstream node or portion thereof + (indicated by \c to_port). +
+ Only kernel nodes define non-zero ports. A kernel node + can use the following output port types: + ::CU_GRAPH_KERNEL_NODE_PORT_DEFAULT, ::CU_GRAPH_KERNEL_NODE_PORT_PROGRAMMATIC, + or ::CU_GRAPH_KERNEL_NODE_PORT_LAUNCH_ORDER. */ + unsigned char to_port; /**< This indicates what portion of the downstream node is dependent on + the upstream node or portion thereof (indicated by \c from_port). The + meaning is specific to the node type. A value of 0 in all cases means + the entirety of the downstream node is dependent on the upstream work. +
+ Currently no node types define non-zero ports. Accordingly, this field + must be set to zero. */ + unsigned char type; /**< This should be populated with a value from ::CUgraphDependencyType. (It + is typed as char due to compiler-specific layout of bitfields.) See + ::CUgraphDependencyType. */ + unsigned char reserved[5]; /**< These bytes are unused and must be zeroed. This ensures + compatibility if additional fields are added in the future. */ +} CUgraphEdgeData; + +/** + * Graph instantiation results +*/ +typedef enum CUgraphInstantiateResult_enum +{ + CUDA_GRAPH_INSTANTIATE_SUCCESS = 0, /**< Instantiation succeeded */ + CUDA_GRAPH_INSTANTIATE_ERROR = 1, /**< Instantiation failed for an unexpected reason which is described in the return value of the function */ + CUDA_GRAPH_INSTANTIATE_INVALID_STRUCTURE = 2, /**< Instantiation failed due to invalid structure, such as cycles */ + CUDA_GRAPH_INSTANTIATE_NODE_OPERATION_NOT_SUPPORTED = 3, /**< Instantiation for device launch failed because the graph contained an unsupported operation */ + CUDA_GRAPH_INSTANTIATE_MULTIPLE_CTXS_NOT_SUPPORTED = 4 /**< Instantiation for device launch failed due to the nodes belonging to different contexts */ +} CUgraphInstantiateResult; + +/** + * Graph instantiation parameters + */ +typedef struct CUDA_GRAPH_INSTANTIATE_PARAMS_st +{ + cuuint64_t flags; /**< Instantiation flags */ + CUstream hUploadStream; /**< Upload stream */ + CUgraphNode hErrNode_out; /**< The node which caused instantiation to fail, if any */ + CUgraphInstantiateResult result_out; /**< Whether instantiation was successful. If it failed, the reason why */ +} CUDA_GRAPH_INSTANTIATE_PARAMS; + +typedef enum CUsynchronizationPolicy_enum { + CU_SYNC_POLICY_AUTO = 1, + CU_SYNC_POLICY_SPIN = 2, + CU_SYNC_POLICY_YIELD = 3, + CU_SYNC_POLICY_BLOCKING_SYNC = 4 +} CUsynchronizationPolicy; + +/** + * Cluster scheduling policies. These may be passed to ::cuFuncSetAttribute or ::cuKernelSetAttribute + */ +typedef enum CUclusterSchedulingPolicy_enum { + CU_CLUSTER_SCHEDULING_POLICY_DEFAULT = 0, /**< the default policy */ + CU_CLUSTER_SCHEDULING_POLICY_SPREAD = 1, /**< spread the blocks within a cluster to the SMs */ + CU_CLUSTER_SCHEDULING_POLICY_LOAD_BALANCING = 2 /**< allow the hardware to load-balance the blocks in a cluster to the SMs */ +} CUclusterSchedulingPolicy; + +/** + * Memory Synchronization Domain + * + * A kernel can be launched in a specified memory synchronization domain that affects all memory operations issued by + * that kernel. A memory barrier issued in one domain will only order memory operations in that domain, thus eliminating + * latency increase from memory barriers ordering unrelated traffic. + * + * By default, kernels are launched in domain 0. Kernel launched with ::CU_LAUNCH_MEM_SYNC_DOMAIN_REMOTE will have a + * different domain ID. User may also alter the domain ID with ::CUlaunchMemSyncDomainMap for a specific stream / + * graph node / kernel launch. See ::CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN, ::cuStreamSetAttribute, ::cuLaunchKernelEx, + * ::cuGraphKernelNodeSetAttribute. + * + * Memory operations done in kernels launched in different domains are considered system-scope distanced. In other + * words, a GPU scoped memory synchronization is not sufficient for memory order to be observed by kernels in another + * memory synchronization domain even if they are on the same GPU. + */ +typedef enum CUlaunchMemSyncDomain_enum { + CU_LAUNCH_MEM_SYNC_DOMAIN_DEFAULT = 0, /**< Launch kernels in the default domain */ + CU_LAUNCH_MEM_SYNC_DOMAIN_REMOTE = 1 /**< Launch kernels in the remote domain */ +} CUlaunchMemSyncDomain; + +/** + * Memory Synchronization Domain map + * + * See ::cudaLaunchMemSyncDomain. + * + * By default, kernels are launched in domain 0. Kernel launched with ::CU_LAUNCH_MEM_SYNC_DOMAIN_REMOTE will have a + * different domain ID. User may also alter the domain ID with ::CUlaunchMemSyncDomainMap for a specific stream / + * graph node / kernel launch. See ::CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP. + * + * Domain ID range is available through ::CU_DEVICE_ATTRIBUTE_MEM_SYNC_DOMAIN_COUNT. + */ +typedef struct CUlaunchMemSyncDomainMap_st { + unsigned char default_; /**< The default domain ID to use for designated kernels */ + unsigned char remote; /**< The remote domain ID to use for designated kernels */ +} CUlaunchMemSyncDomainMap; + +/** + * Launch attributes enum; used as id field of ::CUlaunchAttribute + */ +typedef enum CUlaunchAttributeID_enum { + CU_LAUNCH_ATTRIBUTE_IGNORE = 0 /**< Ignored entry, for convenient composition */ + , CU_LAUNCH_ATTRIBUTE_ACCESS_POLICY_WINDOW = 1 /**< Valid for streams, graph nodes, launches. See + ::CUlaunchAttributeValue::accessPolicyWindow. */ + , CU_LAUNCH_ATTRIBUTE_COOPERATIVE = 2 /**< Valid for graph nodes, launches. See + ::CUlaunchAttributeValue::cooperative. */ + , CU_LAUNCH_ATTRIBUTE_SYNCHRONIZATION_POLICY = 3 /**< Valid for streams. See + ::CUlaunchAttributeValue::syncPolicy. */ + , CU_LAUNCH_ATTRIBUTE_CLUSTER_DIMENSION = 4 /**< Valid for graph nodes, launches. See ::CUlaunchAttributeValue::clusterDim. */ + , CU_LAUNCH_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE = 5 /**< Valid for graph nodes, launches. See ::CUlaunchAttributeValue::clusterSchedulingPolicyPreference. */ + , CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_STREAM_SERIALIZATION = 6 /**< Valid for launches. Setting + ::CUlaunchAttributeValue::programmaticStreamSerializationAllowed + to non-0 signals that the kernel will use programmatic + means to resolve its stream dependency, so that the + CUDA runtime should opportunistically allow the grid's + execution to overlap with the previous kernel in the + stream, if that kernel requests the overlap. The + dependent launches can choose to wait on the + dependency using the programmatic sync + (cudaGridDependencySynchronize() or equivalent PTX + instructions). */ + , CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_EVENT = 7 /**< Valid for launches. Set + ::CUlaunchAttributeValue::programmaticEvent to + record the event. Event recorded through this + launch attribute is guaranteed to only trigger + after all block in the associated kernel trigger + the event. A block can trigger the event through + PTX launchdep.release or CUDA builtin function + cudaTriggerProgrammaticLaunchCompletion(). A + trigger can also be inserted at the beginning of + each block's execution if triggerAtBlockStart is + set to non-0. The dependent launches can choose to + wait on the dependency using the programmatic sync + (cudaGridDependencySynchronize() or equivalent PTX + instructions). Note that dependents (including the + CPU thread calling cuEventSynchronize()) are not + guaranteed to observe the release precisely when + it is released. For example, cuEventSynchronize() + may only observe the event trigger long after the + associated kernel has completed. This recording + type is primarily meant for establishing + programmatic dependency between device tasks. Note + also this type of dependency allows, but does not + guarantee, concurrent execution of tasks. +
+ The event supplied must not be an interprocess or + interop event. The event must disable timing (i.e. + must be created with the ::CU_EVENT_DISABLE_TIMING + flag set). + */ + , CU_LAUNCH_ATTRIBUTE_PRIORITY = 8 /**< Valid for streams, graph nodes, launches. See + ::CUlaunchAttributeValue::priority. */ + , CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP = 9 /**< Valid for streams, graph nodes, launches. See + ::CUlaunchAttributeValue::memSyncDomainMap. */ + , CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN = 10 /**< Valid for streams, graph nodes, launches. See + ::CUlaunchAttributeValue::memSyncDomain. */ + , CU_LAUNCH_ATTRIBUTE_LAUNCH_COMPLETION_EVENT = 12 /**< Valid for launches. Set + ::CUlaunchAttributeValue::launchCompletionEvent to record the + event. +
+ Nominally, the event is triggered once all blocks of the kernel + have begun execution. Currently this is a best effort. If a kernel + B has a launch completion dependency on a kernel A, B may wait + until A is complete. Alternatively, blocks of B may begin before + all blocks of A have begun, for example if B can claim execution + resources unavailable to A (e.g. they run on different GPUs) or + if B is a higher priority than A. + Exercise caution if such an ordering inversion could lead + to deadlock. +
+ A launch completion event is nominally similar to a programmatic + event with \c triggerAtBlockStart set except that it is not + visible to \c cudaGridDependencySynchronize() and can be used with + compute capability less than 9.0. +
+ The event supplied must not be an interprocess or interop + event. The event must disable timing (i.e. must be created + with the ::CU_EVENT_DISABLE_TIMING flag set). */ + , CU_LAUNCH_ATTRIBUTE_DEVICE_UPDATABLE_KERNEL_NODE = 13 /**< Valid for graph nodes, launches. This attribute is graphs-only, + and passing it to a launch in a non-capturing stream will result + in an error. +
+ ::CUlaunchAttributeValue::deviceUpdatableKernelNode::deviceUpdatable can + only be set to 0 or 1. Setting the field to 1 indicates that the + corresponding kernel node should be device-updatable. On success, a handle + will be returned via + ::CUlaunchAttributeValue::deviceUpdatableKernelNode::devNode which can be + passed to the various device-side update functions to update the node's + kernel parameters from within another kernel. For more information on the + types of device updates that can be made, as well as the relevant limitations + thereof, see ::cudaGraphKernelNodeUpdatesApply. +
+ Nodes which are device-updatable have additional restrictions compared to + regular kernel nodes. Firstly, device-updatable nodes cannot be removed + from their graph via ::cuGraphDestroyNode. Additionally, once opted-in + to this functionality, a node cannot opt out, and any attempt to set the + deviceUpdatable attribute to 0 will result in an error. Device-updatable + kernel nodes also cannot have their attributes copied to/from another kernel + node via ::cuGraphKernelNodeCopyAttributes. Graphs containing one or more + device-updatable nodes also do not allow multiple instantiation, and neither + the graph nor its instantiated version can be passed to ::cuGraphExecUpdate. +
+ If a graph contains device-updatable nodes and updates those nodes from the device + from within the graph, the graph must be uploaded with ::cuGraphUpload before it + is launched. For such a graph, if host-side executable graph updates are made to the + device-updatable nodes, the graph must be uploaded before it is launched again. */ + , CU_LAUNCH_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT = 14 /**< Valid for launches. On devices where the L1 cache and shared memory use the + same hardware resources, setting ::CUlaunchAttributeValue::sharedMemCarveout to a + percentage between 0-100 signals the CUDA driver to set the shared memory carveout + preference, in percent of the total shared memory for that kernel launch. + This attribute takes precedence over ::CU_FUNC_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT. + This is only a hint, and the CUDA driver can choose a different configuration if + required for the launch. */ +#if defined(__CUDA_API_VERSION_INTERNAL) && !defined(__CUDA_API_VERSION_INTERNAL_ODR) + , CU_LAUNCH_ATTRIBUTE_MAX +#endif +} CUlaunchAttributeID; + +/** + * Launch attributes union; used as value field of ::CUlaunchAttribute + */ +typedef union CUlaunchAttributeValue_union { + char pad[64]; /* Pad to 64 bytes */ + CUaccessPolicyWindow accessPolicyWindow; /**< Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_ACCESS_POLICY_WINDOW. */ + int cooperative; /**< Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_COOPERATIVE. Nonzero indicates a cooperative + kernel (see ::cuLaunchCooperativeKernel). */ + CUsynchronizationPolicy syncPolicy; /**< Value of launch attribute + ::CU_LAUNCH_ATTRIBUTE_SYNCHRONIZATION_POLICY. ::CUsynchronizationPolicy for + work queued up in this stream */ + + /** + * Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_CLUSTER_DIMENSION that + * represents the desired cluster dimensions for the kernel. Opaque type + * with the following fields: + * - \p x - The X dimension of the cluster, in blocks. Must be a divisor + * of the grid X dimension. + * - \p y - The Y dimension of the cluster, in blocks. Must be a divisor + * of the grid Y dimension. + * - \p z - The Z dimension of the cluster, in blocks. Must be a divisor + * of the grid Z dimension. + */ + struct { + unsigned int x; + unsigned int y; + unsigned int z; + } clusterDim; + CUclusterSchedulingPolicy clusterSchedulingPolicyPreference; /**< Value of launch attribute + ::CU_LAUNCH_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE. Cluster + scheduling policy preference for the kernel. */ + int programmaticStreamSerializationAllowed; /**< Value of launch attribute + ::CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_STREAM_SERIALIZATION. */ + /** + * Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_EVENT + * with the following fields: + * - \p CUevent event - Event to fire when all blocks trigger it. + * - \p Event record flags, see ::cuEventRecordWithFlags. Does not accept :CU_EVENT_RECORD_EXTERNAL. + * - \p triggerAtBlockStart - If this is set to non-0, each block launch will automatically trigger the event. + */ + struct { + CUevent event; + int flags; + int triggerAtBlockStart; + } programmaticEvent; + /** + * Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_LAUNCH_COMPLETION_EVENT + * with the following fields: + * - \p CUevent event - Event to fire when the last block launches + * - \p int flags; - Event record flags, see ::cuEventRecordWithFlags. Does not accept ::CU_EVENT_RECORD_EXTERNAL. + */ + struct { + CUevent event; + int flags; + } launchCompletionEvent; + int priority; /**< Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_PRIORITY. Execution priority of the kernel. */ + CUlaunchMemSyncDomainMap memSyncDomainMap; /**< Value of launch attribute + ::CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP. See + ::CUlaunchMemSyncDomainMap. */ + CUlaunchMemSyncDomain memSyncDomain; /**< Value of launch attribute + ::CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN. See::CUlaunchMemSyncDomain */ + + /** + * Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_DEVICE_UPDATABLE_KERNEL_NODE. + * with the following fields: + * - \p int deviceUpdatable - Whether or not the resulting kernel node should be device-updatable. + * - \p CUgraphDeviceNode devNode - Returns a handle to pass to the various device-side update functions. + */ + struct { + int deviceUpdatable; + CUgraphDeviceNode devNode; + } deviceUpdatableKernelNode; + unsigned int sharedMemCarveout; /**< Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT. */ +} CUlaunchAttributeValue; + +/** + * Launch attribute + */ +typedef struct CUlaunchAttribute_st { + CUlaunchAttributeID id; /**< Attribute to set */ + char pad[8 - sizeof(CUlaunchAttributeID)]; + CUlaunchAttributeValue value; /**< Value of the attribute */ +} CUlaunchAttribute; + +/** + * CUDA extensible launch configuration + */ +typedef struct CUlaunchConfig_st { + unsigned int gridDimX; /**< Width of grid in blocks */ + unsigned int gridDimY; /**< Height of grid in blocks */ + unsigned int gridDimZ; /**< Depth of grid in blocks */ + unsigned int blockDimX; /**< X dimension of each thread block */ + unsigned int blockDimY; /**< Y dimension of each thread block */ + unsigned int blockDimZ; /**< Z dimension of each thread block */ + unsigned int sharedMemBytes; /**< Dynamic shared-memory size per thread block in bytes */ + CUstream hStream; /**< Stream identifier */ + CUlaunchAttribute *attrs; /**< List of attributes; nullable if ::CUlaunchConfig::numAttrs == 0 */ + unsigned int numAttrs; /**< Number of attributes populated in ::CUlaunchConfig::attrs */ +} CUlaunchConfig; + +typedef CUlaunchAttributeID CUkernelNodeAttrID; +#define CU_KERNEL_NODE_ATTRIBUTE_ACCESS_POLICY_WINDOW CU_LAUNCH_ATTRIBUTE_ACCESS_POLICY_WINDOW +#define CU_KERNEL_NODE_ATTRIBUTE_COOPERATIVE CU_LAUNCH_ATTRIBUTE_COOPERATIVE +#define CU_KERNEL_NODE_ATTRIBUTE_CLUSTER_DIMENSION CU_LAUNCH_ATTRIBUTE_CLUSTER_DIMENSION +#define CU_KERNEL_NODE_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE CU_LAUNCH_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE +#define CU_KERNEL_NODE_ATTRIBUTE_PRIORITY CU_LAUNCH_ATTRIBUTE_PRIORITY +#define CU_KERNEL_NODE_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP +#define CU_KERNEL_NODE_ATTRIBUTE_MEM_SYNC_DOMAIN CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN +#define CU_KERNEL_NODE_ATTRIBUTE_DEVICE_UPDATABLE_KERNEL_NODE CU_LAUNCH_ATTRIBUTE_DEVICE_UPDATABLE_KERNEL_NODE +#define CU_KERNEL_NODE_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT CU_LAUNCH_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT + +typedef CUlaunchAttributeValue CUkernelNodeAttrValue_v1; +typedef CUkernelNodeAttrValue_v1 CUkernelNodeAttrValue; + +/** + * Possible stream capture statuses returned by ::cuStreamIsCapturing + */ +typedef enum CUstreamCaptureStatus_enum { + CU_STREAM_CAPTURE_STATUS_NONE = 0, /**< Stream is not capturing */ + CU_STREAM_CAPTURE_STATUS_ACTIVE = 1, /**< Stream is actively capturing */ + CU_STREAM_CAPTURE_STATUS_INVALIDATED = 2 /**< Stream is part of a capture sequence that + has been invalidated, but not terminated */ +} CUstreamCaptureStatus; + +/** + * Possible modes for stream capture thread interactions. For more details see + * ::cuStreamBeginCapture and ::cuThreadExchangeStreamCaptureMode + */ +typedef enum CUstreamCaptureMode_enum { + CU_STREAM_CAPTURE_MODE_GLOBAL = 0, + CU_STREAM_CAPTURE_MODE_THREAD_LOCAL = 1, + CU_STREAM_CAPTURE_MODE_RELAXED = 2 +} CUstreamCaptureMode; + +typedef CUlaunchAttributeID CUstreamAttrID; +#define CU_STREAM_ATTRIBUTE_ACCESS_POLICY_WINDOW CU_LAUNCH_ATTRIBUTE_ACCESS_POLICY_WINDOW +#define CU_STREAM_ATTRIBUTE_SYNCHRONIZATION_POLICY CU_LAUNCH_ATTRIBUTE_SYNCHRONIZATION_POLICY +#define CU_STREAM_ATTRIBUTE_PRIORITY CU_LAUNCH_ATTRIBUTE_PRIORITY +#define CU_STREAM_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP +#define CU_STREAM_ATTRIBUTE_MEM_SYNC_DOMAIN CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN + +typedef CUlaunchAttributeValue CUstreamAttrValue_v1; +typedef CUstreamAttrValue_v1 CUstreamAttrValue; + +/** + * Flags to specify search options. For more details see ::cuGetProcAddress + */ +typedef enum CUdriverProcAddress_flags_enum { + CU_GET_PROC_ADDRESS_DEFAULT = 0, /**< Default search mode for driver symbols. */ + CU_GET_PROC_ADDRESS_LEGACY_STREAM = 1 << 0, /**< Search for legacy versions of driver symbols. */ + CU_GET_PROC_ADDRESS_PER_THREAD_DEFAULT_STREAM = 1 << 1 /**< Search for per-thread versions of driver symbols. */ +} CUdriverProcAddress_flags; + +/** + * Flags to indicate search status. For more details see ::cuGetProcAddress + */ +typedef enum CUdriverProcAddressQueryResult_enum { + CU_GET_PROC_ADDRESS_SUCCESS = 0, /**< Symbol was succesfully found */ + CU_GET_PROC_ADDRESS_SYMBOL_NOT_FOUND = 1, /**< Symbol was not found in search */ + CU_GET_PROC_ADDRESS_VERSION_NOT_SUFFICIENT = 2 /**< Symbol was found but version supplied was not sufficient */ +} CUdriverProcAddressQueryResult; + +/** + * Execution Affinity Types + */ +typedef enum CUexecAffinityType_enum { + CU_EXEC_AFFINITY_TYPE_SM_COUNT = 0, /**< Create a context with limited SMs. */ + CU_EXEC_AFFINITY_TYPE_MAX +} CUexecAffinityType; + +/** + * Value for ::CU_EXEC_AFFINITY_TYPE_SM_COUNT + */ +typedef struct CUexecAffinitySmCount_st { + unsigned int val; /**< The number of SMs the context is limited to use. */ +} CUexecAffinitySmCount_v1; +typedef CUexecAffinitySmCount_v1 CUexecAffinitySmCount; + +/** + * Execution Affinity Parameters + */ +typedef struct CUexecAffinityParam_st { + CUexecAffinityType type; + union { + CUexecAffinitySmCount smCount; /** Value for ::CU_EXEC_AFFINITY_TYPE_SM_COUNT */ + } param; +} CUexecAffinityParam_v1; +/** + * Execution Affinity Parameters + */ +typedef CUexecAffinityParam_v1 CUexecAffinityParam; + +typedef enum CUcigDataType_enum { + CIG_DATA_TYPE_D3D12_COMMAND_QUEUE = 0x1, /** D3D12 Command Queue Handle */ +} CUcigDataType; + +/** +* CIG Context Create Params +*/ +typedef struct CUctxCigParam_st { + CUcigDataType sharedDataType; + void* sharedData; +} CUctxCigParam; + +/** +* Params for creating CUDA context +* Exactly one of execAffinityParams and cigParams +* must be non-NULL. +*/ +typedef struct CUctxCreateParams_st { + CUexecAffinityParam *execAffinityParams; + int numExecAffinityParams; + CUctxCigParam *cigParams; +} CUctxCreateParams; + +/** + * Library options to be specified with ::cuLibraryLoadData() or ::cuLibraryLoadFromFile() + */ +typedef enum CUlibraryOption_enum +{ + CU_LIBRARY_HOST_UNIVERSAL_FUNCTION_AND_DATA_TABLE = 0, + + /** + * Specifes that the argument \p code passed to ::cuLibraryLoadData() will be preserved. + * Specifying this option will let the driver know that \p code can be accessed at any point + * until ::cuLibraryUnload(). The default behavior is for the driver to allocate and + * maintain its own copy of \p code. Note that this is only a memory usage optimization + * hint and the driver can choose to ignore it if required. + * Specifying this option with ::cuLibraryLoadFromFile() is invalid and + * will return ::CUDA_ERROR_INVALID_VALUE. + */ + CU_LIBRARY_BINARY_IS_PRESERVED = 1, + + CU_LIBRARY_NUM_OPTIONS +} CUlibraryOption; + +typedef struct CUlibraryHostUniversalFunctionAndDataTable_st +{ + void *functionTable; + size_t functionWindowSize; + void *dataTable; + size_t dataWindowSize; +} CUlibraryHostUniversalFunctionAndDataTable; + +/** + * Error codes + */ +typedef enum cudaError_enum { + /** + * The API call returned with no errors. In the case of query calls, this + * also means that the operation being queried is complete (see + * ::cuEventQuery() and ::cuStreamQuery()). + */ + CUDA_SUCCESS = 0, + + /** + * This indicates that one or more of the parameters passed to the API call + * is not within an acceptable range of values. + */ + CUDA_ERROR_INVALID_VALUE = 1, + + /** + * The API call failed because it was unable to allocate enough memory or + * other resources to perform the requested operation. + */ + CUDA_ERROR_OUT_OF_MEMORY = 2, + + /** + * This indicates that the CUDA driver has not been initialized with + * ::cuInit() or that initialization has failed. + */ + CUDA_ERROR_NOT_INITIALIZED = 3, + + /** + * This indicates that the CUDA driver is in the process of shutting down. + */ + CUDA_ERROR_DEINITIALIZED = 4, + + /** + * This indicates profiler is not initialized for this run. This can + * happen when the application is running with external profiling tools + * like visual profiler. + */ + CUDA_ERROR_PROFILER_DISABLED = 5, + + /** + * \deprecated + * This error return is deprecated as of CUDA 5.0. It is no longer an error + * to attempt to enable/disable the profiling via ::cuProfilerStart or + * ::cuProfilerStop without initialization. + */ + CUDA_ERROR_PROFILER_NOT_INITIALIZED = 6, + + /** + * \deprecated + * This error return is deprecated as of CUDA 5.0. It is no longer an error + * to call cuProfilerStart() when profiling is already enabled. + */ + CUDA_ERROR_PROFILER_ALREADY_STARTED = 7, + + /** + * \deprecated + * This error return is deprecated as of CUDA 5.0. It is no longer an error + * to call cuProfilerStop() when profiling is already disabled. + */ + CUDA_ERROR_PROFILER_ALREADY_STOPPED = 8, + + /** + * This indicates that the CUDA driver that the application has loaded is a + * stub library. Applications that run with the stub rather than a real + * driver loaded will result in CUDA API returning this error. + */ + CUDA_ERROR_STUB_LIBRARY = 34, + + /** + * This indicates that requested CUDA device is unavailable at the current + * time. Devices are often unavailable due to use of + * ::CU_COMPUTEMODE_EXCLUSIVE_PROCESS or ::CU_COMPUTEMODE_PROHIBITED. + */ + CUDA_ERROR_DEVICE_UNAVAILABLE = 46, + + /** + * This indicates that no CUDA-capable devices were detected by the installed + * CUDA driver. + */ + CUDA_ERROR_NO_DEVICE = 100, + + /** + * This indicates that the device ordinal supplied by the user does not + * correspond to a valid CUDA device or that the action requested is + * invalid for the specified device. + */ + CUDA_ERROR_INVALID_DEVICE = 101, + + /** + * This error indicates that the Grid license is not applied. + */ + CUDA_ERROR_DEVICE_NOT_LICENSED = 102, + + /** + * This indicates that the device kernel image is invalid. This can also + * indicate an invalid CUDA module. + */ + CUDA_ERROR_INVALID_IMAGE = 200, + + /** + * This most frequently indicates that there is no context bound to the + * current thread. This can also be returned if the context passed to an + * API call is not a valid handle (such as a context that has had + * ::cuCtxDestroy() invoked on it). This can also be returned if a user + * mixes different API versions (i.e. 3010 context with 3020 API calls). + * See ::cuCtxGetApiVersion() for more details. + * This can also be returned if the green context passed to an API call + * was not converted to a ::CUcontext using ::cuCtxFromGreenCtx API. + */ + CUDA_ERROR_INVALID_CONTEXT = 201, + + /** + * This indicated that the context being supplied as a parameter to the + * API call was already the active context. + * \deprecated + * This error return is deprecated as of CUDA 3.2. It is no longer an + * error to attempt to push the active context via ::cuCtxPushCurrent(). + */ + CUDA_ERROR_CONTEXT_ALREADY_CURRENT = 202, + + /** + * This indicates that a map or register operation has failed. + */ + CUDA_ERROR_MAP_FAILED = 205, + + /** + * This indicates that an unmap or unregister operation has failed. + */ + CUDA_ERROR_UNMAP_FAILED = 206, + + /** + * This indicates that the specified array is currently mapped and thus + * cannot be destroyed. + */ + CUDA_ERROR_ARRAY_IS_MAPPED = 207, + + /** + * This indicates that the resource is already mapped. + */ + CUDA_ERROR_ALREADY_MAPPED = 208, + + /** + * This indicates that there is no kernel image available that is suitable + * for the device. This can occur when a user specifies code generation + * options for a particular CUDA source file that do not include the + * corresponding device configuration. + */ + CUDA_ERROR_NO_BINARY_FOR_GPU = 209, + + /** + * This indicates that a resource has already been acquired. + */ + CUDA_ERROR_ALREADY_ACQUIRED = 210, + + /** + * This indicates that a resource is not mapped. + */ + CUDA_ERROR_NOT_MAPPED = 211, + + /** + * This indicates that a mapped resource is not available for access as an + * array. + */ + CUDA_ERROR_NOT_MAPPED_AS_ARRAY = 212, + + /** + * This indicates that a mapped resource is not available for access as a + * pointer. + */ + CUDA_ERROR_NOT_MAPPED_AS_POINTER = 213, + + /** + * This indicates that an uncorrectable ECC error was detected during + * execution. + */ + CUDA_ERROR_ECC_UNCORRECTABLE = 214, + + /** + * This indicates that the ::CUlimit passed to the API call is not + * supported by the active device. + */ + CUDA_ERROR_UNSUPPORTED_LIMIT = 215, + + /** + * This indicates that the ::CUcontext passed to the API call can + * only be bound to a single CPU thread at a time but is already + * bound to a CPU thread. + */ + CUDA_ERROR_CONTEXT_ALREADY_IN_USE = 216, + + /** + * This indicates that peer access is not supported across the given + * devices. + */ + CUDA_ERROR_PEER_ACCESS_UNSUPPORTED = 217, + + /** + * This indicates that a PTX JIT compilation failed. + */ + CUDA_ERROR_INVALID_PTX = 218, + + /** + * This indicates an error with OpenGL or DirectX context. + */ + CUDA_ERROR_INVALID_GRAPHICS_CONTEXT = 219, + + /** + * This indicates that an uncorrectable NVLink error was detected during the + * execution. + */ + CUDA_ERROR_NVLINK_UNCORRECTABLE = 220, + + /** + * This indicates that the PTX JIT compiler library was not found. + */ + CUDA_ERROR_JIT_COMPILER_NOT_FOUND = 221, + + /** + * This indicates that the provided PTX was compiled with an unsupported toolchain. + */ + + CUDA_ERROR_UNSUPPORTED_PTX_VERSION = 222, + + /** + * This indicates that the PTX JIT compilation was disabled. + */ + CUDA_ERROR_JIT_COMPILATION_DISABLED = 223, + + /** + * This indicates that the ::CUexecAffinityType passed to the API call is not + * supported by the active device. + */ + CUDA_ERROR_UNSUPPORTED_EXEC_AFFINITY = 224, + + /** + * This indicates that the code to be compiled by the PTX JIT contains + * unsupported call to cudaDeviceSynchronize. + */ + CUDA_ERROR_UNSUPPORTED_DEVSIDE_SYNC = 225, + + /** + * This indicates that the device kernel source is invalid. This includes + * compilation/linker errors encountered in device code or user error. + */ + CUDA_ERROR_INVALID_SOURCE = 300, + + /** + * This indicates that the file specified was not found. + */ + CUDA_ERROR_FILE_NOT_FOUND = 301, + + /** + * This indicates that a link to a shared object failed to resolve. + */ + CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND = 302, + + /** + * This indicates that initialization of a shared object failed. + */ + CUDA_ERROR_SHARED_OBJECT_INIT_FAILED = 303, + + /** + * This indicates that an OS call failed. + */ + CUDA_ERROR_OPERATING_SYSTEM = 304, + + /** + * This indicates that a resource handle passed to the API call was not + * valid. Resource handles are opaque types like ::CUstream and ::CUevent. + */ + CUDA_ERROR_INVALID_HANDLE = 400, + + /** + * This indicates that a resource required by the API call is not in a + * valid state to perform the requested operation. + */ + CUDA_ERROR_ILLEGAL_STATE = 401, + + /** + * This indicates an attempt was made to introspect an object in a way that + * would discard semantically important information. This is either due to + * the object using funtionality newer than the API version used to + * introspect it or omission of optional return arguments. + */ + CUDA_ERROR_LOSSY_QUERY = 402, + + /** + * This indicates that a named symbol was not found. Examples of symbols + * are global/constant variable names, driver function names, texture names, + * and surface names. + */ + CUDA_ERROR_NOT_FOUND = 500, + + /** + * This indicates that asynchronous operations issued previously have not + * completed yet. This result is not actually an error, but must be indicated + * differently than ::CUDA_SUCCESS (which indicates completion). Calls that + * may return this value include ::cuEventQuery() and ::cuStreamQuery(). + */ + CUDA_ERROR_NOT_READY = 600, + + /** + * While executing a kernel, the device encountered a + * load or store instruction on an invalid memory address. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_ILLEGAL_ADDRESS = 700, + + /** + * This indicates that a launch did not occur because it did not have + * appropriate resources. This error usually indicates that the user has + * attempted to pass too many arguments to the device kernel, or the + * kernel launch specifies too many threads for the kernel's register + * count. Passing arguments of the wrong size (i.e. a 64-bit pointer + * when a 32-bit int is expected) is equivalent to passing too many + * arguments and can also result in this error. + */ + CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES = 701, + + /** + * This indicates that the device kernel took too long to execute. This can + * only occur if timeouts are enabled - see the device attribute + * ::CU_DEVICE_ATTRIBUTE_KERNEL_EXEC_TIMEOUT for more information. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_LAUNCH_TIMEOUT = 702, + + /** + * This error indicates a kernel launch that uses an incompatible texturing + * mode. + */ + CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING = 703, + + /** + * This error indicates that a call to ::cuCtxEnablePeerAccess() is + * trying to re-enable peer access to a context which has already + * had peer access to it enabled. + */ + CUDA_ERROR_PEER_ACCESS_ALREADY_ENABLED = 704, + + /** + * This error indicates that ::cuCtxDisablePeerAccess() is + * trying to disable peer access which has not been enabled yet + * via ::cuCtxEnablePeerAccess(). + */ + CUDA_ERROR_PEER_ACCESS_NOT_ENABLED = 705, + + /** + * This error indicates that the primary context for the specified device + * has already been initialized. + */ + CUDA_ERROR_PRIMARY_CONTEXT_ACTIVE = 708, + + /** + * This error indicates that the context current to the calling thread + * has been destroyed using ::cuCtxDestroy, or is a primary context which + * has not yet been initialized. + */ + CUDA_ERROR_CONTEXT_IS_DESTROYED = 709, + + /** + * A device-side assert triggered during kernel execution. The context + * cannot be used anymore, and must be destroyed. All existing device + * memory allocations from this context are invalid and must be + * reconstructed if the program is to continue using CUDA. + */ + CUDA_ERROR_ASSERT = 710, + + /** + * This error indicates that the hardware resources required to enable + * peer access have been exhausted for one or more of the devices + * passed to ::cuCtxEnablePeerAccess(). + */ + CUDA_ERROR_TOO_MANY_PEERS = 711, + + /** + * This error indicates that the memory range passed to ::cuMemHostRegister() + * has already been registered. + */ + CUDA_ERROR_HOST_MEMORY_ALREADY_REGISTERED = 712, + + /** + * This error indicates that the pointer passed to ::cuMemHostUnregister() + * does not correspond to any currently registered memory region. + */ + CUDA_ERROR_HOST_MEMORY_NOT_REGISTERED = 713, + + /** + * While executing a kernel, the device encountered a stack error. + * This can be due to stack corruption or exceeding the stack size limit. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_HARDWARE_STACK_ERROR = 714, + + /** + * While executing a kernel, the device encountered an illegal instruction. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_ILLEGAL_INSTRUCTION = 715, + + /** + * While executing a kernel, the device encountered a load or store instruction + * on a memory address which is not aligned. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_MISALIGNED_ADDRESS = 716, + + /** + * While executing a kernel, the device encountered an instruction + * which can only operate on memory locations in certain address spaces + * (global, shared, or local), but was supplied a memory address not + * belonging to an allowed address space. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_INVALID_ADDRESS_SPACE = 717, + + /** + * While executing a kernel, the device program counter wrapped its address space. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_INVALID_PC = 718, + + /** + * An exception occurred on the device while executing a kernel. Common + * causes include dereferencing an invalid device pointer and accessing + * out of bounds shared memory. Less common cases can be system specific - more + * information about these cases can be found in the system specific user guide. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_LAUNCH_FAILED = 719, + + /** + * This error indicates that the number of blocks launched per grid for a kernel that was + * launched via either ::cuLaunchCooperativeKernel or ::cuLaunchCooperativeKernelMultiDevice + * exceeds the maximum number of blocks as allowed by ::cuOccupancyMaxActiveBlocksPerMultiprocessor + * or ::cuOccupancyMaxActiveBlocksPerMultiprocessorWithFlags times the number of multiprocessors + * as specified by the device attribute ::CU_DEVICE_ATTRIBUTE_MULTIPROCESSOR_COUNT. + */ + CUDA_ERROR_COOPERATIVE_LAUNCH_TOO_LARGE = 720, + + /** + * This error indicates that the attempted operation is not permitted. + */ + CUDA_ERROR_NOT_PERMITTED = 800, + + /** + * This error indicates that the attempted operation is not supported + * on the current system or device. + */ + CUDA_ERROR_NOT_SUPPORTED = 801, + + /** + * This error indicates that the system is not yet ready to start any CUDA + * work. To continue using CUDA, verify the system configuration is in a + * valid state and all required driver daemons are actively running. + * More information about this error can be found in the system specific + * user guide. + */ + CUDA_ERROR_SYSTEM_NOT_READY = 802, + + /** + * This error indicates that there is a mismatch between the versions of + * the display driver and the CUDA driver. Refer to the compatibility documentation + * for supported versions. + */ + CUDA_ERROR_SYSTEM_DRIVER_MISMATCH = 803, + + /** + * This error indicates that the system was upgraded to run with forward compatibility + * but the visible hardware detected by CUDA does not support this configuration. + * Refer to the compatibility documentation for the supported hardware matrix or ensure + * that only supported hardware is visible during initialization via the CUDA_VISIBLE_DEVICES + * environment variable. + */ + CUDA_ERROR_COMPAT_NOT_SUPPORTED_ON_DEVICE = 804, + + /** + * This error indicates that the MPS client failed to connect to the MPS control daemon or the MPS server. + */ + CUDA_ERROR_MPS_CONNECTION_FAILED = 805, + + /** + * This error indicates that the remote procedural call between the MPS server and the MPS client failed. + */ + CUDA_ERROR_MPS_RPC_FAILURE = 806, + + /** + * This error indicates that the MPS server is not ready to accept new MPS client requests. + * This error can be returned when the MPS server is in the process of recovering from a fatal failure. + */ + CUDA_ERROR_MPS_SERVER_NOT_READY = 807, + + /** + * This error indicates that the hardware resources required to create MPS client have been exhausted. + */ + CUDA_ERROR_MPS_MAX_CLIENTS_REACHED = 808, + + /** + * This error indicates the the hardware resources required to support device connections have been exhausted. + */ + CUDA_ERROR_MPS_MAX_CONNECTIONS_REACHED = 809, + + /** + * This error indicates that the MPS client has been terminated by the server. To continue using CUDA, the process must be terminated and relaunched. + */ + CUDA_ERROR_MPS_CLIENT_TERMINATED = 810, + + /** + * This error indicates that the module is using CUDA Dynamic Parallelism, but the current configuration, like MPS, does not support it. + */ + CUDA_ERROR_CDP_NOT_SUPPORTED = 811, + + /** + * This error indicates that a module contains an unsupported interaction between different versions of CUDA Dynamic Parallelism. + */ + CUDA_ERROR_CDP_VERSION_MISMATCH = 812, + + /** + * This error indicates that the operation is not permitted when + * the stream is capturing. + */ + CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED = 900, + + /** + * This error indicates that the current capture sequence on the stream + * has been invalidated due to a previous error. + */ + CUDA_ERROR_STREAM_CAPTURE_INVALIDATED = 901, + + /** + * This error indicates that the operation would have resulted in a merge + * of two independent capture sequences. + */ + CUDA_ERROR_STREAM_CAPTURE_MERGE = 902, + + /** + * This error indicates that the capture was not initiated in this stream. + */ + CUDA_ERROR_STREAM_CAPTURE_UNMATCHED = 903, + + /** + * This error indicates that the capture sequence contains a fork that was + * not joined to the primary stream. + */ + CUDA_ERROR_STREAM_CAPTURE_UNJOINED = 904, + + /** + * This error indicates that a dependency would have been created which + * crosses the capture sequence boundary. Only implicit in-stream ordering + * dependencies are allowed to cross the boundary. + */ + CUDA_ERROR_STREAM_CAPTURE_ISOLATION = 905, + + /** + * This error indicates a disallowed implicit dependency on a current capture + * sequence from cudaStreamLegacy. + */ + CUDA_ERROR_STREAM_CAPTURE_IMPLICIT = 906, + + /** + * This error indicates that the operation is not permitted on an event which + * was last recorded in a capturing stream. + */ + CUDA_ERROR_CAPTURED_EVENT = 907, + + /** + * A stream capture sequence not initiated with the ::CU_STREAM_CAPTURE_MODE_RELAXED + * argument to ::cuStreamBeginCapture was passed to ::cuStreamEndCapture in a + * different thread. + */ + CUDA_ERROR_STREAM_CAPTURE_WRONG_THREAD = 908, + + /** + * This error indicates that the timeout specified for the wait operation has lapsed. + */ + CUDA_ERROR_TIMEOUT = 909, + + /** + * This error indicates that the graph update was not performed because it included + * changes which violated constraints specific to instantiated graph update. + */ + CUDA_ERROR_GRAPH_EXEC_UPDATE_FAILURE = 910, + + /** + * This indicates that an async error has occurred in a device outside of CUDA. + * If CUDA was waiting for an external device's signal before consuming shared data, + * the external device signaled an error indicating that the data is not valid for + * consumption. This leaves the process in an inconsistent state and any further CUDA + * work will return the same error. To continue using CUDA, the process must be + * terminated and relaunched. + */ + CUDA_ERROR_EXTERNAL_DEVICE = 911, + + /** + * Indicates a kernel launch error due to cluster misconfiguration. + */ + CUDA_ERROR_INVALID_CLUSTER_SIZE = 912, + + /** + * Indiciates a function handle is not loaded when calling an API that requires + * a loaded function. + */ + CUDA_ERROR_FUNCTION_NOT_LOADED = 913, + + /** + * This error indicates one or more resources passed in are not valid resource + * types for the operation. + */ + CUDA_ERROR_INVALID_RESOURCE_TYPE = 914, + + /** + * This error indicates one or more resources are insufficient or non-applicable for + * the operation. + */ + CUDA_ERROR_INVALID_RESOURCE_CONFIGURATION = 915, + + /** + * This indicates that an unknown internal error has occurred. + */ + CUDA_ERROR_UNKNOWN = 999 +} CUresult; + +/** + * P2P Attributes + */ +typedef enum CUdevice_P2PAttribute_enum { + CU_DEVICE_P2P_ATTRIBUTE_PERFORMANCE_RANK = 0x01, /**< A relative value indicating the performance of the link between two devices */ + CU_DEVICE_P2P_ATTRIBUTE_ACCESS_SUPPORTED = 0x02, /**< P2P Access is enable */ + CU_DEVICE_P2P_ATTRIBUTE_NATIVE_ATOMIC_SUPPORTED = 0x03, /**< Atomic operation over the link supported */ + CU_DEVICE_P2P_ATTRIBUTE_ACCESS_ACCESS_SUPPORTED = 0x04, /**< \deprecated use CU_DEVICE_P2P_ATTRIBUTE_CUDA_ARRAY_ACCESS_SUPPORTED instead */ + CU_DEVICE_P2P_ATTRIBUTE_CUDA_ARRAY_ACCESS_SUPPORTED = 0x04 /**< Accessing CUDA arrays over the link supported */ +} CUdevice_P2PAttribute; + +/** + * CUDA stream callback + * \param hStream The stream the callback was added to, as passed to ::cuStreamAddCallback. May be NULL. + * \param status ::CUDA_SUCCESS or any persistent error on the stream. + * \param userData User parameter provided at registration. + */ +typedef void (CUDA_CB *CUstreamCallback)(CUstream hStream, CUresult status, void *userData); + +/** + * Block size to per-block dynamic shared memory mapping for a certain + * kernel \param blockSize Block size of the kernel. + * + * \return The dynamic shared memory needed by a block. + */ +typedef size_t (CUDA_CB *CUoccupancyB2DSize)(int blockSize); + +/** + * If set, host memory is portable between CUDA contexts. + * Flag for ::cuMemHostAlloc() + */ +#define CU_MEMHOSTALLOC_PORTABLE 0x01 + +/** + * If set, host memory is mapped into CUDA address space and + * ::cuMemHostGetDevicePointer() may be called on the host pointer. + * Flag for ::cuMemHostAlloc() + */ +#define CU_MEMHOSTALLOC_DEVICEMAP 0x02 + +/** + * If set, host memory is allocated as write-combined - fast to write, + * faster to DMA, slow to read except via SSE4 streaming load instruction + * (MOVNTDQA). + * Flag for ::cuMemHostAlloc() + */ +#define CU_MEMHOSTALLOC_WRITECOMBINED 0x04 + +/** + * If set, host memory is portable between CUDA contexts. + * Flag for ::cuMemHostRegister() + */ +#define CU_MEMHOSTREGISTER_PORTABLE 0x01 + +/** + * If set, host memory is mapped into CUDA address space and + * ::cuMemHostGetDevicePointer() may be called on the host pointer. + * Flag for ::cuMemHostRegister() + */ +#define CU_MEMHOSTREGISTER_DEVICEMAP 0x02 + +/** + * If set, the passed memory pointer is treated as pointing to some + * memory-mapped I/O space, e.g. belonging to a third-party PCIe device. + * On Windows the flag is a no-op. + * On Linux that memory is marked as non cache-coherent for the GPU and + * is expected to be physically contiguous. It may return + * ::CUDA_ERROR_NOT_PERMITTED if run as an unprivileged user, + * ::CUDA_ERROR_NOT_SUPPORTED on older Linux kernel versions. + * On all other platforms, it is not supported and ::CUDA_ERROR_NOT_SUPPORTED + * is returned. + * Flag for ::cuMemHostRegister() + */ +#define CU_MEMHOSTREGISTER_IOMEMORY 0x04 + +/** +* If set, the passed memory pointer is treated as pointing to memory that is +* considered read-only by the device. On platforms without +* ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, this flag is +* required in order to register memory mapped to the CPU as read-only. Support +* for the use of this flag can be queried from the device attribute +* ::CU_DEVICE_ATTRIBUTE_READ_ONLY_HOST_REGISTER_SUPPORTED. Using this flag with +* a current context associated with a device that does not have this attribute +* set will cause ::cuMemHostRegister to error with ::CUDA_ERROR_NOT_SUPPORTED. +*/ +#define CU_MEMHOSTREGISTER_READ_ONLY 0x08 + +/** + * 2D memory copy parameters + */ +typedef struct CUDA_MEMCPY2D_st { + size_t srcXInBytes; /**< Source X in bytes */ + size_t srcY; /**< Source Y */ + + CUmemorytype srcMemoryType; /**< Source memory type (host, device, array) */ + const void *srcHost; /**< Source host pointer */ + CUdeviceptr srcDevice; /**< Source device pointer */ + CUarray srcArray; /**< Source array reference */ + size_t srcPitch; /**< Source pitch (ignored when src is array) */ + + size_t dstXInBytes; /**< Destination X in bytes */ + size_t dstY; /**< Destination Y */ + + CUmemorytype dstMemoryType; /**< Destination memory type (host, device, array) */ + void *dstHost; /**< Destination host pointer */ + CUdeviceptr dstDevice; /**< Destination device pointer */ + CUarray dstArray; /**< Destination array reference */ + size_t dstPitch; /**< Destination pitch (ignored when dst is array) */ + + size_t WidthInBytes; /**< Width of 2D memory copy in bytes */ + size_t Height; /**< Height of 2D memory copy */ +} CUDA_MEMCPY2D_v2; +typedef CUDA_MEMCPY2D_v2 CUDA_MEMCPY2D; + +/** + * 3D memory copy parameters + */ +typedef struct CUDA_MEMCPY3D_st { + size_t srcXInBytes; /**< Source X in bytes */ + size_t srcY; /**< Source Y */ + size_t srcZ; /**< Source Z */ + size_t srcLOD; /**< Source LOD */ + CUmemorytype srcMemoryType; /**< Source memory type (host, device, array) */ + const void *srcHost; /**< Source host pointer */ + CUdeviceptr srcDevice; /**< Source device pointer */ + CUarray srcArray; /**< Source array reference */ + void *reserved0; /**< Must be NULL */ + size_t srcPitch; /**< Source pitch (ignored when src is array) */ + size_t srcHeight; /**< Source height (ignored when src is array; may be 0 if Depth==1) */ + + size_t dstXInBytes; /**< Destination X in bytes */ + size_t dstY; /**< Destination Y */ + size_t dstZ; /**< Destination Z */ + size_t dstLOD; /**< Destination LOD */ + CUmemorytype dstMemoryType; /**< Destination memory type (host, device, array) */ + void *dstHost; /**< Destination host pointer */ + CUdeviceptr dstDevice; /**< Destination device pointer */ + CUarray dstArray; /**< Destination array reference */ + void *reserved1; /**< Must be NULL */ + size_t dstPitch; /**< Destination pitch (ignored when dst is array) */ + size_t dstHeight; /**< Destination height (ignored when dst is array; may be 0 if Depth==1) */ + + size_t WidthInBytes; /**< Width of 3D memory copy in bytes */ + size_t Height; /**< Height of 3D memory copy */ + size_t Depth; /**< Depth of 3D memory copy */ +} CUDA_MEMCPY3D_v2; +typedef CUDA_MEMCPY3D_v2 CUDA_MEMCPY3D; + +/** + * 3D memory cross-context copy parameters + */ +typedef struct CUDA_MEMCPY3D_PEER_st { + size_t srcXInBytes; /**< Source X in bytes */ + size_t srcY; /**< Source Y */ + size_t srcZ; /**< Source Z */ + size_t srcLOD; /**< Source LOD */ + CUmemorytype srcMemoryType; /**< Source memory type (host, device, array) */ + const void *srcHost; /**< Source host pointer */ + CUdeviceptr srcDevice; /**< Source device pointer */ + CUarray srcArray; /**< Source array reference */ + CUcontext srcContext; /**< Source context (ignored with srcMemoryType is ::CU_MEMORYTYPE_ARRAY) */ + size_t srcPitch; /**< Source pitch (ignored when src is array) */ + size_t srcHeight; /**< Source height (ignored when src is array; may be 0 if Depth==1) */ + + size_t dstXInBytes; /**< Destination X in bytes */ + size_t dstY; /**< Destination Y */ + size_t dstZ; /**< Destination Z */ + size_t dstLOD; /**< Destination LOD */ + CUmemorytype dstMemoryType; /**< Destination memory type (host, device, array) */ + void *dstHost; /**< Destination host pointer */ + CUdeviceptr dstDevice; /**< Destination device pointer */ + CUarray dstArray; /**< Destination array reference */ + CUcontext dstContext; /**< Destination context (ignored with dstMemoryType is ::CU_MEMORYTYPE_ARRAY) */ + size_t dstPitch; /**< Destination pitch (ignored when dst is array) */ + size_t dstHeight; /**< Destination height (ignored when dst is array; may be 0 if Depth==1) */ + + size_t WidthInBytes; /**< Width of 3D memory copy in bytes */ + size_t Height; /**< Height of 3D memory copy */ + size_t Depth; /**< Depth of 3D memory copy */ +} CUDA_MEMCPY3D_PEER_v1; +typedef CUDA_MEMCPY3D_PEER_v1 CUDA_MEMCPY3D_PEER; + +/** + * Memcpy node parameters + */ +typedef struct CUDA_MEMCPY_NODE_PARAMS_st { + int flags; /**< Must be zero */ + int reserved; /**< Must be zero */ + CUcontext copyCtx; /**< Context on which to run the node */ + CUDA_MEMCPY3D copyParams; /**< Parameters for the memory copy */ +} CUDA_MEMCPY_NODE_PARAMS; + +/** + * Array descriptor + */ +typedef struct CUDA_ARRAY_DESCRIPTOR_st +{ + size_t Width; /**< Width of array */ + size_t Height; /**< Height of array */ + + CUarray_format Format; /**< Array format */ + unsigned int NumChannels; /**< Channels per array element */ +} CUDA_ARRAY_DESCRIPTOR_v2; +typedef CUDA_ARRAY_DESCRIPTOR_v2 CUDA_ARRAY_DESCRIPTOR; + +/** + * 3D array descriptor + */ +typedef struct CUDA_ARRAY3D_DESCRIPTOR_st +{ + size_t Width; /**< Width of 3D array */ + size_t Height; /**< Height of 3D array */ + size_t Depth; /**< Depth of 3D array */ + + CUarray_format Format; /**< Array format */ + unsigned int NumChannels; /**< Channels per array element */ + unsigned int Flags; /**< Flags */ +} CUDA_ARRAY3D_DESCRIPTOR_v2; +typedef CUDA_ARRAY3D_DESCRIPTOR_v2 CUDA_ARRAY3D_DESCRIPTOR; + +/** + * Indicates that the layered sparse CUDA array or CUDA mipmapped array has a single mip tail region for all layers + */ +#define CU_ARRAY_SPARSE_PROPERTIES_SINGLE_MIPTAIL 0x1 + +/** + * CUDA array sparse properties + */ +typedef struct CUDA_ARRAY_SPARSE_PROPERTIES_st { + struct { + unsigned int width; /**< Width of sparse tile in elements */ + unsigned int height; /**< Height of sparse tile in elements */ + unsigned int depth; /**< Depth of sparse tile in elements */ + } tileExtent; + + /** + * First mip level at which the mip tail begins. + */ + unsigned int miptailFirstLevel; + /** + * Total size of the mip tail. + */ + unsigned long long miptailSize; + /** + * Flags will either be zero or ::CU_ARRAY_SPARSE_PROPERTIES_SINGLE_MIPTAIL + */ + unsigned int flags; + unsigned int reserved[4]; +} CUDA_ARRAY_SPARSE_PROPERTIES_v1; +typedef CUDA_ARRAY_SPARSE_PROPERTIES_v1 CUDA_ARRAY_SPARSE_PROPERTIES; + +/** + * CUDA array memory requirements + */ +typedef struct CUDA_ARRAY_MEMORY_REQUIREMENTS_st { + size_t size; /**< Total required memory size */ + size_t alignment; /**< alignment requirement */ + unsigned int reserved[4]; +} CUDA_ARRAY_MEMORY_REQUIREMENTS_v1; +typedef CUDA_ARRAY_MEMORY_REQUIREMENTS_v1 CUDA_ARRAY_MEMORY_REQUIREMENTS; + +/** + * CUDA Resource descriptor + */ +typedef struct CUDA_RESOURCE_DESC_st +{ + CUresourcetype resType; /**< Resource type */ + + union { + struct { + CUarray hArray; /**< CUDA array */ + } array; + struct { + CUmipmappedArray hMipmappedArray; /**< CUDA mipmapped array */ + } mipmap; + struct { + CUdeviceptr devPtr; /**< Device pointer */ + CUarray_format format; /**< Array format */ + unsigned int numChannels; /**< Channels per array element */ + size_t sizeInBytes; /**< Size in bytes */ + } linear; + struct { + CUdeviceptr devPtr; /**< Device pointer */ + CUarray_format format; /**< Array format */ + unsigned int numChannels; /**< Channels per array element */ + size_t width; /**< Width of the array in elements */ + size_t height; /**< Height of the array in elements */ + size_t pitchInBytes; /**< Pitch between two rows in bytes */ + } pitch2D; + struct { + int reserved[32]; + } reserved; + } res; + + unsigned int flags; /**< Flags (must be zero) */ +} CUDA_RESOURCE_DESC_v1; +typedef CUDA_RESOURCE_DESC_v1 CUDA_RESOURCE_DESC; + +/** + * Texture descriptor + */ +typedef struct CUDA_TEXTURE_DESC_st { + CUaddress_mode addressMode[3]; /**< Address modes */ + CUfilter_mode filterMode; /**< Filter mode */ + unsigned int flags; /**< Flags */ + unsigned int maxAnisotropy; /**< Maximum anisotropy ratio */ + CUfilter_mode mipmapFilterMode; /**< Mipmap filter mode */ + float mipmapLevelBias; /**< Mipmap level bias */ + float minMipmapLevelClamp; /**< Mipmap minimum level clamp */ + float maxMipmapLevelClamp; /**< Mipmap maximum level clamp */ + float borderColor[4]; /**< Border Color */ + int reserved[12]; +} CUDA_TEXTURE_DESC_v1; +typedef CUDA_TEXTURE_DESC_v1 CUDA_TEXTURE_DESC; + +/** + * Resource view format + */ +typedef enum CUresourceViewFormat_enum +{ + CU_RES_VIEW_FORMAT_NONE = 0x00, /**< No resource view format (use underlying resource format) */ + CU_RES_VIEW_FORMAT_UINT_1X8 = 0x01, /**< 1 channel unsigned 8-bit integers */ + CU_RES_VIEW_FORMAT_UINT_2X8 = 0x02, /**< 2 channel unsigned 8-bit integers */ + CU_RES_VIEW_FORMAT_UINT_4X8 = 0x03, /**< 4 channel unsigned 8-bit integers */ + CU_RES_VIEW_FORMAT_SINT_1X8 = 0x04, /**< 1 channel signed 8-bit integers */ + CU_RES_VIEW_FORMAT_SINT_2X8 = 0x05, /**< 2 channel signed 8-bit integers */ + CU_RES_VIEW_FORMAT_SINT_4X8 = 0x06, /**< 4 channel signed 8-bit integers */ + CU_RES_VIEW_FORMAT_UINT_1X16 = 0x07, /**< 1 channel unsigned 16-bit integers */ + CU_RES_VIEW_FORMAT_UINT_2X16 = 0x08, /**< 2 channel unsigned 16-bit integers */ + CU_RES_VIEW_FORMAT_UINT_4X16 = 0x09, /**< 4 channel unsigned 16-bit integers */ + CU_RES_VIEW_FORMAT_SINT_1X16 = 0x0a, /**< 1 channel signed 16-bit integers */ + CU_RES_VIEW_FORMAT_SINT_2X16 = 0x0b, /**< 2 channel signed 16-bit integers */ + CU_RES_VIEW_FORMAT_SINT_4X16 = 0x0c, /**< 4 channel signed 16-bit integers */ + CU_RES_VIEW_FORMAT_UINT_1X32 = 0x0d, /**< 1 channel unsigned 32-bit integers */ + CU_RES_VIEW_FORMAT_UINT_2X32 = 0x0e, /**< 2 channel unsigned 32-bit integers */ + CU_RES_VIEW_FORMAT_UINT_4X32 = 0x0f, /**< 4 channel unsigned 32-bit integers */ + CU_RES_VIEW_FORMAT_SINT_1X32 = 0x10, /**< 1 channel signed 32-bit integers */ + CU_RES_VIEW_FORMAT_SINT_2X32 = 0x11, /**< 2 channel signed 32-bit integers */ + CU_RES_VIEW_FORMAT_SINT_4X32 = 0x12, /**< 4 channel signed 32-bit integers */ + CU_RES_VIEW_FORMAT_FLOAT_1X16 = 0x13, /**< 1 channel 16-bit floating point */ + CU_RES_VIEW_FORMAT_FLOAT_2X16 = 0x14, /**< 2 channel 16-bit floating point */ + CU_RES_VIEW_FORMAT_FLOAT_4X16 = 0x15, /**< 4 channel 16-bit floating point */ + CU_RES_VIEW_FORMAT_FLOAT_1X32 = 0x16, /**< 1 channel 32-bit floating point */ + CU_RES_VIEW_FORMAT_FLOAT_2X32 = 0x17, /**< 2 channel 32-bit floating point */ + CU_RES_VIEW_FORMAT_FLOAT_4X32 = 0x18, /**< 4 channel 32-bit floating point */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC1 = 0x19, /**< Block compressed 1 */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC2 = 0x1a, /**< Block compressed 2 */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC3 = 0x1b, /**< Block compressed 3 */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC4 = 0x1c, /**< Block compressed 4 unsigned */ + CU_RES_VIEW_FORMAT_SIGNED_BC4 = 0x1d, /**< Block compressed 4 signed */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC5 = 0x1e, /**< Block compressed 5 unsigned */ + CU_RES_VIEW_FORMAT_SIGNED_BC5 = 0x1f, /**< Block compressed 5 signed */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC6H = 0x20, /**< Block compressed 6 unsigned half-float */ + CU_RES_VIEW_FORMAT_SIGNED_BC6H = 0x21, /**< Block compressed 6 signed half-float */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC7 = 0x22 /**< Block compressed 7 */ +} CUresourceViewFormat; + +/** + * Resource view descriptor + */ +typedef struct CUDA_RESOURCE_VIEW_DESC_st +{ + CUresourceViewFormat format; /**< Resource view format */ + size_t width; /**< Width of the resource view */ + size_t height; /**< Height of the resource view */ + size_t depth; /**< Depth of the resource view */ + unsigned int firstMipmapLevel; /**< First defined mipmap level */ + unsigned int lastMipmapLevel; /**< Last defined mipmap level */ + unsigned int firstLayer; /**< First layer index */ + unsigned int lastLayer; /**< Last layer index */ + unsigned int reserved[16]; +} CUDA_RESOURCE_VIEW_DESC_v1; +typedef CUDA_RESOURCE_VIEW_DESC_v1 CUDA_RESOURCE_VIEW_DESC; + +/** + * Size of tensor map descriptor + */ +#define CU_TENSOR_MAP_NUM_QWORDS 16 + +/** + * Tensor map descriptor. Requires compiler support for aligning to 64 bytes. + */ +typedef struct CUtensorMap_st { +#if defined(__cplusplus) && (__cplusplus >= 201103L) + alignas(64) +#elif __STDC_VERSION__ >= 201112L + _Alignas(64) +#endif + cuuint64_t opaque[CU_TENSOR_MAP_NUM_QWORDS]; +} CUtensorMap; + +/** + * Tensor map data type + */ +typedef enum CUtensorMapDataType_enum { + CU_TENSOR_MAP_DATA_TYPE_UINT8 = 0, + CU_TENSOR_MAP_DATA_TYPE_UINT16, + CU_TENSOR_MAP_DATA_TYPE_UINT32, + CU_TENSOR_MAP_DATA_TYPE_INT32, + CU_TENSOR_MAP_DATA_TYPE_UINT64, + CU_TENSOR_MAP_DATA_TYPE_INT64, + CU_TENSOR_MAP_DATA_TYPE_FLOAT16, + CU_TENSOR_MAP_DATA_TYPE_FLOAT32, + CU_TENSOR_MAP_DATA_TYPE_FLOAT64, + CU_TENSOR_MAP_DATA_TYPE_BFLOAT16, + CU_TENSOR_MAP_DATA_TYPE_FLOAT32_FTZ, + CU_TENSOR_MAP_DATA_TYPE_TFLOAT32, + CU_TENSOR_MAP_DATA_TYPE_TFLOAT32_FTZ, +} CUtensorMapDataType; + +/** + * Tensor map interleave layout type + */ +typedef enum CUtensorMapInterleave_enum { + CU_TENSOR_MAP_INTERLEAVE_NONE = 0, + CU_TENSOR_MAP_INTERLEAVE_16B, + CU_TENSOR_MAP_INTERLEAVE_32B +} CUtensorMapInterleave; + +/** + * Tensor map swizzling mode of shared memory banks + */ +typedef enum CUtensorMapSwizzle_enum { + CU_TENSOR_MAP_SWIZZLE_NONE = 0, + CU_TENSOR_MAP_SWIZZLE_32B, + CU_TENSOR_MAP_SWIZZLE_64B, + CU_TENSOR_MAP_SWIZZLE_128B, +} CUtensorMapSwizzle; + +/** + * Tensor map L2 promotion type + */ +typedef enum CUtensorMapL2promotion_enum { + CU_TENSOR_MAP_L2_PROMOTION_NONE = 0, + CU_TENSOR_MAP_L2_PROMOTION_L2_64B, + CU_TENSOR_MAP_L2_PROMOTION_L2_128B, + CU_TENSOR_MAP_L2_PROMOTION_L2_256B +} CUtensorMapL2promotion; + +/** + * Tensor map out-of-bounds fill type + */ +typedef enum CUtensorMapFloatOOBfill_enum { + CU_TENSOR_MAP_FLOAT_OOB_FILL_NONE = 0, + CU_TENSOR_MAP_FLOAT_OOB_FILL_NAN_REQUEST_ZERO_FMA +} CUtensorMapFloatOOBfill; + +/** + * GPU Direct v3 tokens + */ +typedef struct CUDA_POINTER_ATTRIBUTE_P2P_TOKENS_st { + unsigned long long p2pToken; + unsigned int vaSpaceToken; +} CUDA_POINTER_ATTRIBUTE_P2P_TOKENS_v1; +typedef CUDA_POINTER_ATTRIBUTE_P2P_TOKENS_v1 CUDA_POINTER_ATTRIBUTE_P2P_TOKENS; + +/** +* Access flags that specify the level of access the current context's device has +* on the memory referenced. +*/ +typedef enum CUDA_POINTER_ATTRIBUTE_ACCESS_FLAGS_enum { + CU_POINTER_ATTRIBUTE_ACCESS_FLAG_NONE = 0x0, /**< No access, meaning the device cannot access this memory at all, thus must be staged through accessible memory in order to complete certain operations */ + CU_POINTER_ATTRIBUTE_ACCESS_FLAG_READ = 0x1, /**< Read-only access, meaning writes to this memory are considered invalid accesses and thus return error in that case. */ + CU_POINTER_ATTRIBUTE_ACCESS_FLAG_READWRITE = 0x3 /**< Read-write access, the device has full read-write access to the memory */ +} CUDA_POINTER_ATTRIBUTE_ACCESS_FLAGS; + +/** + * Kernel launch parameters + */ +typedef struct CUDA_LAUNCH_PARAMS_st { + CUfunction function; /**< Kernel to launch */ + unsigned int gridDimX; /**< Width of grid in blocks */ + unsigned int gridDimY; /**< Height of grid in blocks */ + unsigned int gridDimZ; /**< Depth of grid in blocks */ + unsigned int blockDimX; /**< X dimension of each thread block */ + unsigned int blockDimY; /**< Y dimension of each thread block */ + unsigned int blockDimZ; /**< Z dimension of each thread block */ + unsigned int sharedMemBytes; /**< Dynamic shared-memory size per thread block in bytes */ + CUstream hStream; /**< Stream identifier */ + void **kernelParams; /**< Array of pointers to kernel parameters */ +} CUDA_LAUNCH_PARAMS_v1; +typedef CUDA_LAUNCH_PARAMS_v1 CUDA_LAUNCH_PARAMS; + +/** + * External memory handle types + */ +typedef enum CUexternalMemoryHandleType_enum { + /** + * Handle is an opaque file descriptor + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD = 1, + /** + * Handle is an opaque shared NT handle + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32 = 2, + /** + * Handle is an opaque, globally shared handle + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT = 3, + /** + * Handle is a D3D12 heap object + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP = 4, + /** + * Handle is a D3D12 committed resource + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE = 5, + /** + * Handle is a shared NT handle to a D3D11 resource + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE = 6, + /** + * Handle is a globally shared handle to a D3D11 resource + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE_KMT = 7, + /** + * Handle is an NvSciBuf object + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF = 8 +} CUexternalMemoryHandleType; + +/** + * Indicates that the external memory object is a dedicated resource + */ +#define CUDA_EXTERNAL_MEMORY_DEDICATED 0x1 + +/** When the \p flags parameter of ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS + * contains this flag, it indicates that signaling an external semaphore object + * should skip performing appropriate memory synchronization operations over all + * the external memory objects that are imported as ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF, + * which otherwise are performed by default to ensure data coherency with other + * importers of the same NvSciBuf memory objects. + */ +#define CUDA_EXTERNAL_SEMAPHORE_SIGNAL_SKIP_NVSCIBUF_MEMSYNC 0x01 + +/** When the \p flags parameter of ::CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS + * contains this flag, it indicates that waiting on an external semaphore object + * should skip performing appropriate memory synchronization operations over all + * the external memory objects that are imported as ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF, + * which otherwise are performed by default to ensure data coherency with other + * importers of the same NvSciBuf memory objects. + */ +#define CUDA_EXTERNAL_SEMAPHORE_WAIT_SKIP_NVSCIBUF_MEMSYNC 0x02 + +/** + * When \p flags of ::cuDeviceGetNvSciSyncAttributes is set to this, + * it indicates that application needs signaler specific NvSciSyncAttr + * to be filled by ::cuDeviceGetNvSciSyncAttributes. + */ +#define CUDA_NVSCISYNC_ATTR_SIGNAL 0x1 + +/** + * When \p flags of ::cuDeviceGetNvSciSyncAttributes is set to this, + * it indicates that application needs waiter specific NvSciSyncAttr + * to be filled by ::cuDeviceGetNvSciSyncAttributes. + */ +#define CUDA_NVSCISYNC_ATTR_WAIT 0x2 +/** + * External memory handle descriptor + */ +typedef struct CUDA_EXTERNAL_MEMORY_HANDLE_DESC_st { + /** + * Type of the handle + */ + CUexternalMemoryHandleType type; + union { + /** + * File descriptor referencing the memory object. Valid + * when type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD + */ + int fd; + /** + * Win32 handle referencing the semaphore object. Valid when + * type is one of the following: + * - ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32 + * - ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT + * - ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP + * - ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE + * - ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE + * - ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE_KMT + * Exactly one of 'handle' and 'name' must be non-NULL. If + * type is one of the following: + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE_KMT + * then 'name' must be NULL. + */ + struct { + /** + * Valid NT handle. Must be NULL if 'name' is non-NULL + */ + void *handle; + /** + * Name of a valid memory object. + * Must be NULL if 'handle' is non-NULL. + */ + const void *name; + } win32; + /** + * A handle representing an NvSciBuf Object. Valid when type + * is ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF + */ + const void *nvSciBufObject; + } handle; + /** + * Size of the memory allocation + */ + unsigned long long size; + /** + * Flags must either be zero or ::CUDA_EXTERNAL_MEMORY_DEDICATED + */ + unsigned int flags; + unsigned int reserved[16]; +} CUDA_EXTERNAL_MEMORY_HANDLE_DESC_v1; +typedef CUDA_EXTERNAL_MEMORY_HANDLE_DESC_v1 CUDA_EXTERNAL_MEMORY_HANDLE_DESC; + +/** + * External memory buffer descriptor + */ +typedef struct CUDA_EXTERNAL_MEMORY_BUFFER_DESC_st { + /** + * Offset into the memory object where the buffer's base is + */ + unsigned long long offset; + /** + * Size of the buffer + */ + unsigned long long size; + /** + * Flags reserved for future use. Must be zero. + */ + unsigned int flags; + unsigned int reserved[16]; +} CUDA_EXTERNAL_MEMORY_BUFFER_DESC_v1; +typedef CUDA_EXTERNAL_MEMORY_BUFFER_DESC_v1 CUDA_EXTERNAL_MEMORY_BUFFER_DESC; + +/** + * External memory mipmap descriptor + */ +typedef struct CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC_st { + /** + * Offset into the memory object where the base level of the + * mipmap chain is. + */ + unsigned long long offset; + /** + * Format, dimension and type of base level of the mipmap chain + */ + CUDA_ARRAY3D_DESCRIPTOR arrayDesc; + /** + * Total number of levels in the mipmap chain + */ + unsigned int numLevels; + unsigned int reserved[16]; +} CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC_v1; +typedef CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC_v1 CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC; + +/** + * External semaphore handle types + */ +typedef enum CUexternalSemaphoreHandleType_enum { + /** + * Handle is an opaque file descriptor + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD = 1, + /** + * Handle is an opaque shared NT handle + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32 = 2, + /** + * Handle is an opaque, globally shared handle + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT = 3, + /** + * Handle is a shared NT handle referencing a D3D12 fence object + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE = 4, + /** + * Handle is a shared NT handle referencing a D3D11 fence object + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_FENCE = 5, + /** + * Opaque handle to NvSciSync Object + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC = 6, + /** + * Handle is a shared NT handle referencing a D3D11 keyed mutex object + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX = 7, + /** + * Handle is a globally shared handle referencing a D3D11 keyed mutex object + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX_KMT = 8, + /** + * Handle is an opaque file descriptor referencing a timeline semaphore + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_FD = 9, + /** + * Handle is an opaque shared NT handle referencing a timeline semaphore + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_WIN32 = 10 +} CUexternalSemaphoreHandleType; + +/** + * External semaphore handle descriptor + */ +typedef struct CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC_st { + /** + * Type of the handle + */ + CUexternalSemaphoreHandleType type; + union { + /** + * File descriptor referencing the semaphore object. Valid + * when type is one of the following: + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_FD + */ + int fd; + /** + * Win32 handle referencing the semaphore object. Valid when + * type is one of the following: + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32 + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_FENCE + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_WIN32 + * Exactly one of 'handle' and 'name' must be non-NULL. If + * type is one of the following: + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX_KMT + * then 'name' must be NULL. + */ + struct { + /** + * Valid NT handle. Must be NULL if 'name' is non-NULL + */ + void *handle; + /** + * Name of a valid synchronization primitive. + * Must be NULL if 'handle' is non-NULL. + */ + const void *name; + } win32; + /** + * Valid NvSciSyncObj. Must be non NULL + */ + const void* nvSciSyncObj; + } handle; + /** + * Flags reserved for the future. Must be zero. + */ + unsigned int flags; + unsigned int reserved[16]; +} CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC_v1; +typedef CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC_v1 CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC; + +/** + * External semaphore signal parameters + */ +typedef struct CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS_st { + struct { + /** + * Parameters for fence objects + */ + struct { + /** + * Value of fence to be signaled + */ + unsigned long long value; + } fence; + union { + /** + * Pointer to NvSciSyncFence. Valid if ::CUexternalSemaphoreHandleType + * is of type ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC. + */ + void *fence; + unsigned long long reserved; + } nvSciSync; + /** + * Parameters for keyed mutex objects + */ + struct { + /** + * Value of key to release the mutex with + */ + unsigned long long key; + } keyedMutex; + unsigned int reserved[12]; + } params; + /** + * Only when ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS is used to + * signal a ::CUexternalSemaphore of type + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC, the valid flag is + * ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_SKIP_NVSCIBUF_MEMSYNC which indicates + * that while signaling the ::CUexternalSemaphore, no memory synchronization + * operations should be performed for any external memory object imported + * as ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF. + * For all other types of ::CUexternalSemaphore, flags must be zero. + */ + unsigned int flags; + unsigned int reserved[16]; +} CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS_v1; +typedef CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS_v1 CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS; + +/** + * External semaphore wait parameters + */ +typedef struct CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS_st { + struct { + /** + * Parameters for fence objects + */ + struct { + /** + * Value of fence to be waited on + */ + unsigned long long value; + } fence; + /** + * Pointer to NvSciSyncFence. Valid if CUexternalSemaphoreHandleType + * is of type CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC. + */ + union { + void *fence; + unsigned long long reserved; + } nvSciSync; + /** + * Parameters for keyed mutex objects + */ + struct { + /** + * Value of key to acquire the mutex with + */ + unsigned long long key; + /** + * Timeout in milliseconds to wait to acquire the mutex + */ + unsigned int timeoutMs; + } keyedMutex; + unsigned int reserved[10]; + } params; + /** + * Only when ::CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS is used to wait on + * a ::CUexternalSemaphore of type ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC, + * the valid flag is ::CUDA_EXTERNAL_SEMAPHORE_WAIT_SKIP_NVSCIBUF_MEMSYNC + * which indicates that while waiting for the ::CUexternalSemaphore, no memory + * synchronization operations should be performed for any external memory + * object imported as ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF. + * For all other types of ::CUexternalSemaphore, flags must be zero. + */ + unsigned int flags; + unsigned int reserved[16]; +} CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS_v1; +typedef CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS_v1 CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS; + +/** + * Semaphore signal node parameters + */ +typedef struct CUDA_EXT_SEM_SIGNAL_NODE_PARAMS_st { + CUexternalSemaphore* extSemArray; /**< Array of external semaphore handles. */ + const CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS* paramsArray; /**< Array of external semaphore signal parameters. */ + unsigned int numExtSems; /**< Number of handles and parameters supplied in extSemArray and paramsArray. */ +} CUDA_EXT_SEM_SIGNAL_NODE_PARAMS_v1; +typedef CUDA_EXT_SEM_SIGNAL_NODE_PARAMS_v1 CUDA_EXT_SEM_SIGNAL_NODE_PARAMS; + +/** + * Semaphore signal node parameters + */ +typedef struct CUDA_EXT_SEM_SIGNAL_NODE_PARAMS_v2_st { + CUexternalSemaphore* extSemArray; /**< Array of external semaphore handles. */ + const CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS* paramsArray; /**< Array of external semaphore signal parameters. */ + unsigned int numExtSems; /**< Number of handles and parameters supplied in extSemArray and paramsArray. */ +} CUDA_EXT_SEM_SIGNAL_NODE_PARAMS_v2; + +/** + * Semaphore wait node parameters + */ +typedef struct CUDA_EXT_SEM_WAIT_NODE_PARAMS_st { + CUexternalSemaphore* extSemArray; /**< Array of external semaphore handles. */ + const CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS* paramsArray; /**< Array of external semaphore wait parameters. */ + unsigned int numExtSems; /**< Number of handles and parameters supplied in extSemArray and paramsArray. */ +} CUDA_EXT_SEM_WAIT_NODE_PARAMS_v1; +typedef CUDA_EXT_SEM_WAIT_NODE_PARAMS_v1 CUDA_EXT_SEM_WAIT_NODE_PARAMS; + +/** + * Semaphore wait node parameters + */ +typedef struct CUDA_EXT_SEM_WAIT_NODE_PARAMS_v2_st { + CUexternalSemaphore* extSemArray; /**< Array of external semaphore handles. */ + const CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS* paramsArray; /**< Array of external semaphore wait parameters. */ + unsigned int numExtSems; /**< Number of handles and parameters supplied in extSemArray and paramsArray. */ +} CUDA_EXT_SEM_WAIT_NODE_PARAMS_v2; + +typedef unsigned long long CUmemGenericAllocationHandle_v1; +typedef CUmemGenericAllocationHandle_v1 CUmemGenericAllocationHandle; + +/** + * Flags for specifying particular handle types + */ +typedef enum CUmemAllocationHandleType_enum { + CU_MEM_HANDLE_TYPE_NONE = 0x0, /**< Does not allow any export mechanism. > */ + CU_MEM_HANDLE_TYPE_POSIX_FILE_DESCRIPTOR = 0x1, /**< Allows a file descriptor to be used for exporting. Permitted only on POSIX systems. (int) */ + CU_MEM_HANDLE_TYPE_WIN32 = 0x2, /**< Allows a Win32 NT handle to be used for exporting. (HANDLE) */ + CU_MEM_HANDLE_TYPE_WIN32_KMT = 0x4, /**< Allows a Win32 KMT handle to be used for exporting. (D3DKMT_HANDLE) */ + CU_MEM_HANDLE_TYPE_FABRIC = 0x8, /**< Allows a fabric handle to be used for exporting. (CUmemFabricHandle)*/ + CU_MEM_HANDLE_TYPE_MAX = 0x7FFFFFFF +} CUmemAllocationHandleType; + +/** + * Specifies the memory protection flags for mapping. + */ +typedef enum CUmemAccess_flags_enum { + CU_MEM_ACCESS_FLAGS_PROT_NONE = 0x0, /**< Default, make the address range not accessible */ + CU_MEM_ACCESS_FLAGS_PROT_READ = 0x1, /**< Make the address range read accessible */ + CU_MEM_ACCESS_FLAGS_PROT_READWRITE = 0x3, /**< Make the address range read-write accessible */ + CU_MEM_ACCESS_FLAGS_PROT_MAX = 0x7FFFFFFF +} CUmemAccess_flags; + +/** + * Specifies the type of location + */ +typedef enum CUmemLocationType_enum { + CU_MEM_LOCATION_TYPE_INVALID = 0x0, + CU_MEM_LOCATION_TYPE_DEVICE = 0x1, /**< Location is a device location, thus id is a device ordinal */ + CU_MEM_LOCATION_TYPE_HOST = 0x2, /**< Location is host, id is ignored */ + CU_MEM_LOCATION_TYPE_HOST_NUMA = 0x3, /**< Location is a host NUMA node, thus id is a host NUMA node id */ + CU_MEM_LOCATION_TYPE_HOST_NUMA_CURRENT = 0x4, /**< Location is a host NUMA node of the current thread, id is ignored */ + CU_MEM_LOCATION_TYPE_MAX = 0x7FFFFFFF +} CUmemLocationType; + +/** +* Defines the allocation types available +*/ +typedef enum CUmemAllocationType_enum { + CU_MEM_ALLOCATION_TYPE_INVALID = 0x0, + + /** This allocation type is 'pinned', i.e. cannot migrate from its current + * location while the application is actively using it + */ + CU_MEM_ALLOCATION_TYPE_PINNED = 0x1, + CU_MEM_ALLOCATION_TYPE_MAX = 0x7FFFFFFF +} CUmemAllocationType; + +/** +* Flag for requesting different optimal and required granularities for an allocation. +*/ +typedef enum CUmemAllocationGranularity_flags_enum { + CU_MEM_ALLOC_GRANULARITY_MINIMUM = 0x0, /**< Minimum required granularity for allocation */ + CU_MEM_ALLOC_GRANULARITY_RECOMMENDED = 0x1 /**< Recommended granularity for allocation for best performance */ +} CUmemAllocationGranularity_flags; + +/** +* Specifies the handle type for address range +*/ +typedef enum CUmemRangeHandleType_enum +{ + CU_MEM_RANGE_HANDLE_TYPE_DMA_BUF_FD = 0x1, + CU_MEM_RANGE_HANDLE_TYPE_MAX = 0x7FFFFFFF +} CUmemRangeHandleType; + +/** + * Sparse subresource types + */ +typedef enum CUarraySparseSubresourceType_enum { + CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_SPARSE_LEVEL = 0, + CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_MIPTAIL = 1 +} CUarraySparseSubresourceType; + +/** + * Memory operation types + */ +typedef enum CUmemOperationType_enum { + CU_MEM_OPERATION_TYPE_MAP = 1, + CU_MEM_OPERATION_TYPE_UNMAP = 2 +} CUmemOperationType; + +/** + * Memory handle types + */ +typedef enum CUmemHandleType_enum { + CU_MEM_HANDLE_TYPE_GENERIC = 0 +} CUmemHandleType; + +/** + * Specifies the CUDA array or CUDA mipmapped array memory mapping information + */ +typedef struct CUarrayMapInfo_st { + CUresourcetype resourceType; /**< Resource type */ + + union { + CUmipmappedArray mipmap; + CUarray array; + } resource; + + CUarraySparseSubresourceType subresourceType; /**< Sparse subresource type */ + + union { + struct { + unsigned int level; /**< For CUDA mipmapped arrays must a valid mipmap level. For CUDA arrays must be zero */ + unsigned int layer; /**< For CUDA layered arrays must be a valid layer index. Otherwise, must be zero */ + unsigned int offsetX; /**< Starting X offset in elements */ + unsigned int offsetY; /**< Starting Y offset in elements */ + unsigned int offsetZ; /**< Starting Z offset in elements */ + unsigned int extentWidth; /**< Width in elements */ + unsigned int extentHeight; /**< Height in elements */ + unsigned int extentDepth; /**< Depth in elements */ + } sparseLevel; + struct { + unsigned int layer; /**< For CUDA layered arrays must be a valid layer index. Otherwise, must be zero */ + unsigned long long offset; /**< Offset within mip tail */ + unsigned long long size; /**< Extent in bytes */ + } miptail; + } subresource; + + CUmemOperationType memOperationType; /**< Memory operation type */ + CUmemHandleType memHandleType; /**< Memory handle type */ + + union { + CUmemGenericAllocationHandle memHandle; + } memHandle; + + unsigned long long offset; /**< Offset within the memory */ + unsigned int deviceBitMask; /**< Device ordinal bit mask */ + unsigned int flags; /**< flags for future use, must be zero now. */ + unsigned int reserved[2]; /**< Reserved for future use, must be zero now. */ +} CUarrayMapInfo_v1; +typedef CUarrayMapInfo_v1 CUarrayMapInfo; + +/** + * Specifies a memory location. + */ +typedef struct CUmemLocation_st { + CUmemLocationType type; /**< Specifies the location type, which modifies the meaning of id. */ + int id; /**< identifier for a given this location's ::CUmemLocationType. */ +} CUmemLocation_v1; +typedef CUmemLocation_v1 CUmemLocation; + +/** + * Specifies compression attribute for an allocation. + */ +typedef enum CUmemAllocationCompType_enum { + CU_MEM_ALLOCATION_COMP_NONE = 0x0, /**< Allocating non-compressible memory */ + CU_MEM_ALLOCATION_COMP_GENERIC = 0x1 /**< Allocating compressible memory */ +} CUmemAllocationCompType; + +/** + * This flag if set indicates that the memory will be used as a tile pool. + */ +#define CU_MEM_CREATE_USAGE_TILE_POOL 0x1 + +/** +* Specifies the allocation properties for a allocation. +*/ +typedef struct CUmemAllocationProp_st { + /** Allocation type */ + CUmemAllocationType type; + /** requested ::CUmemAllocationHandleType */ + CUmemAllocationHandleType requestedHandleTypes; + /** Location of allocation */ + CUmemLocation location; + /** + * Windows-specific POBJECT_ATTRIBUTES required when + * ::CU_MEM_HANDLE_TYPE_WIN32 is specified. This object attributes structure + * includes security attributes that define + * the scope of which exported allocations may be transferred to other + * processes. In all other cases, this field is required to be zero. + */ + void *win32HandleMetaData; + struct { + /** + * Allocation hint for requesting compressible memory. + * On devices that support Compute Data Compression, compressible + * memory can be used to accelerate accesses to data with unstructured + * sparsity and other compressible data patterns. Applications are + * expected to query allocation property of the handle obtained with + * ::cuMemCreate using ::cuMemGetAllocationPropertiesFromHandle to + * validate if the obtained allocation is compressible or not. Note that + * compressed memory may not be mappable on all devices. + */ + unsigned char compressionType; + unsigned char gpuDirectRDMACapable; + /** Bitmask indicating intended usage for this allocation */ + unsigned short usage; + unsigned char reserved[4]; + } allocFlags; +} CUmemAllocationProp_v1; +typedef CUmemAllocationProp_v1 CUmemAllocationProp; + +/** +* Flags for querying different granularities for a multicast object +*/ +typedef enum CUmulticastGranularity_flags_enum { + CU_MULTICAST_GRANULARITY_MINIMUM = 0x0, /**< Minimum required granularity */ + CU_MULTICAST_GRANULARITY_RECOMMENDED = 0x1 /**< Recommended granularity for best performance */ +} CUmulticastGranularity_flags; + +/** +* Specifies the properties for a multicast object. +*/ +typedef struct CUmulticastObjectProp_st { + /** + * The number of devices in the multicast team that will bind memory to this + * object + */ + unsigned int numDevices; + /** + * The maximum amount of memory that can be bound to this multicast object + * per device + */ + size_t size; + /** + * Bitmask of exportable handle types (see ::CUmemAllocationHandleType) for + * this object + */ + unsigned long long handleTypes; + /** + * Flags for future use, must be zero now + */ + unsigned long long flags; +} CUmulticastObjectProp_v1; +typedef CUmulticastObjectProp_v1 CUmulticastObjectProp; + +/** + * Memory access descriptor + */ +typedef struct CUmemAccessDesc_st { + CUmemLocation location; /**< Location on which the request is to change it's accessibility */ + CUmemAccess_flags flags; /**< ::CUmemProt accessibility flags to set on the request */ +} CUmemAccessDesc_v1; +typedef CUmemAccessDesc_v1 CUmemAccessDesc; + +/** + * CUDA Graph Update error types + */ +typedef enum CUgraphExecUpdateResult_enum { + CU_GRAPH_EXEC_UPDATE_SUCCESS = 0x0, /**< The update succeeded */ + CU_GRAPH_EXEC_UPDATE_ERROR = 0x1, /**< The update failed for an unexpected reason which is described in the return value of the function */ + CU_GRAPH_EXEC_UPDATE_ERROR_TOPOLOGY_CHANGED = 0x2, /**< The update failed because the topology changed */ + CU_GRAPH_EXEC_UPDATE_ERROR_NODE_TYPE_CHANGED = 0x3, /**< The update failed because a node type changed */ + CU_GRAPH_EXEC_UPDATE_ERROR_FUNCTION_CHANGED = 0x4, /**< The update failed because the function of a kernel node changed (CUDA driver < 11.2) */ + CU_GRAPH_EXEC_UPDATE_ERROR_PARAMETERS_CHANGED = 0x5, /**< The update failed because the parameters changed in a way that is not supported */ + CU_GRAPH_EXEC_UPDATE_ERROR_NOT_SUPPORTED = 0x6, /**< The update failed because something about the node is not supported */ + CU_GRAPH_EXEC_UPDATE_ERROR_UNSUPPORTED_FUNCTION_CHANGE = 0x7, /**< The update failed because the function of a kernel node changed in an unsupported way */ + CU_GRAPH_EXEC_UPDATE_ERROR_ATTRIBUTES_CHANGED = 0x8 /**< The update failed because the node attributes changed in a way that is not supported */ +} CUgraphExecUpdateResult; + +/** + * Result information returned by cuGraphExecUpdate + */ +typedef struct CUgraphExecUpdateResultInfo_st { + /** + * Gives more specific detail when a cuda graph update fails. + */ + CUgraphExecUpdateResult result; + + /** + * The "to node" of the error edge when the topologies do not match. + * The error node when the error is associated with a specific node. + * NULL when the error is generic. + */ + CUgraphNode errorNode; + + /** + * The from node of error edge when the topologies do not match. Otherwise NULL. + */ + CUgraphNode errorFromNode; +} CUgraphExecUpdateResultInfo_v1; +typedef CUgraphExecUpdateResultInfo_v1 CUgraphExecUpdateResultInfo; + +/** + * CUDA memory pool attributes + */ +typedef enum CUmemPool_attribute_enum { + /** + * (value type = int) + * Allow cuMemAllocAsync to use memory asynchronously freed + * in another streams as long as a stream ordering dependency + * of the allocating stream on the free action exists. + * Cuda events and null stream interactions can create the required + * stream ordered dependencies. (default enabled) + */ + CU_MEMPOOL_ATTR_REUSE_FOLLOW_EVENT_DEPENDENCIES = 1, + + /** + * (value type = int) + * Allow reuse of already completed frees when there is no dependency + * between the free and allocation. (default enabled) + */ + CU_MEMPOOL_ATTR_REUSE_ALLOW_OPPORTUNISTIC, + + /** + * (value type = int) + * Allow cuMemAllocAsync to insert new stream dependencies + * in order to establish the stream ordering required to reuse + * a piece of memory released by cuFreeAsync (default enabled). + */ + CU_MEMPOOL_ATTR_REUSE_ALLOW_INTERNAL_DEPENDENCIES, + + /** + * (value type = cuuint64_t) + * Amount of reserved memory in bytes to hold onto before trying + * to release memory back to the OS. When more than the release + * threshold bytes of memory are held by the memory pool, the + * allocator will try to release memory back to the OS on the + * next call to stream, event or context synchronize. (default 0) + */ + CU_MEMPOOL_ATTR_RELEASE_THRESHOLD, + + /** + * (value type = cuuint64_t) + * Amount of backing memory currently allocated for the mempool. + */ + CU_MEMPOOL_ATTR_RESERVED_MEM_CURRENT, + + /** + * (value type = cuuint64_t) + * High watermark of backing memory allocated for the mempool since the + * last time it was reset. High watermark can only be reset to zero. + */ + CU_MEMPOOL_ATTR_RESERVED_MEM_HIGH, + + /** + * (value type = cuuint64_t) + * Amount of memory from the pool that is currently in use by the application. + */ + CU_MEMPOOL_ATTR_USED_MEM_CURRENT, + + /** + * (value type = cuuint64_t) + * High watermark of the amount of memory from the pool that was in use by the application since + * the last time it was reset. High watermark can only be reset to zero. + */ + CU_MEMPOOL_ATTR_USED_MEM_HIGH +} CUmemPool_attribute; + +/** + * Specifies the properties of allocations made from the pool. + */ +typedef struct CUmemPoolProps_st { + CUmemAllocationType allocType; /**< Allocation type. Currently must be specified as CU_MEM_ALLOCATION_TYPE_PINNED */ + CUmemAllocationHandleType handleTypes; /**< Handle types that will be supported by allocations from the pool. */ + CUmemLocation location; /**< Location where allocations should reside. */ + /** + * Windows-specific LPSECURITYATTRIBUTES required when + * ::CU_MEM_HANDLE_TYPE_WIN32 is specified. This security attribute defines + * the scope of which exported allocations may be transferred to other + * processes. In all other cases, this field is required to be zero. + */ + void *win32SecurityAttributes; + size_t maxSize; /**< Maximum pool size. When set to 0, defaults to a system dependent value. */ + unsigned short usage; /**< Bitmask indicating intended usage for the pool. */ + unsigned char reserved[54]; /**< reserved for future use, must be 0 */ +} CUmemPoolProps_v1; +typedef CUmemPoolProps_v1 CUmemPoolProps; + +/** + * Opaque data for exporting a pool allocation + */ +typedef struct CUmemPoolPtrExportData_st { + unsigned char reserved[64]; +} CUmemPoolPtrExportData_v1; +typedef CUmemPoolPtrExportData_v1 CUmemPoolPtrExportData; + +/** + * Memory allocation node parameters + */ +typedef struct CUDA_MEM_ALLOC_NODE_PARAMS_v1_st { + /** + * in: location where the allocation should reside (specified in ::location). + * ::handleTypes must be ::CU_MEM_HANDLE_TYPE_NONE. IPC is not supported. + */ + CUmemPoolProps poolProps; + const CUmemAccessDesc *accessDescs; /**< in: array of memory access descriptors. Used to describe peer GPU access */ + size_t accessDescCount; /**< in: number of memory access descriptors. Must not exceed the number of GPUs. */ + size_t bytesize; /**< in: size in bytes of the requested allocation */ + CUdeviceptr dptr; /**< out: address of the allocation returned by CUDA */ +} CUDA_MEM_ALLOC_NODE_PARAMS_v1; +typedef CUDA_MEM_ALLOC_NODE_PARAMS_v1 CUDA_MEM_ALLOC_NODE_PARAMS; + +/** + * Memory allocation node parameters + */ +typedef struct CUDA_MEM_ALLOC_NODE_PARAMS_v2_st { + /** + * in: location where the allocation should reside (specified in ::location). + * ::handleTypes must be ::CU_MEM_HANDLE_TYPE_NONE. IPC is not supported. + */ + CUmemPoolProps poolProps; + const CUmemAccessDesc *accessDescs; /**< in: array of memory access descriptors. Used to describe peer GPU access */ + size_t accessDescCount; /**< in: number of memory access descriptors. Must not exceed the number of GPUs. */ + size_t bytesize; /**< in: size in bytes of the requested allocation */ + CUdeviceptr dptr; /**< out: address of the allocation returned by CUDA */ +} CUDA_MEM_ALLOC_NODE_PARAMS_v2; + +/** + * Memory free node parameters + */ +typedef struct CUDA_MEM_FREE_NODE_PARAMS_st { + CUdeviceptr dptr; /**< in: the pointer to free */ +} CUDA_MEM_FREE_NODE_PARAMS; + +typedef enum CUgraphMem_attribute_enum { + /** + * (value type = cuuint64_t) + * Amount of memory, in bytes, currently associated with graphs + */ + CU_GRAPH_MEM_ATTR_USED_MEM_CURRENT, + + /** + * (value type = cuuint64_t) + * High watermark of memory, in bytes, associated with graphs since the + * last time it was reset. High watermark can only be reset to zero. + */ + CU_GRAPH_MEM_ATTR_USED_MEM_HIGH, + + /** + * (value type = cuuint64_t) + * Amount of memory, in bytes, currently allocated for use by + * the CUDA graphs asynchronous allocator. + */ + CU_GRAPH_MEM_ATTR_RESERVED_MEM_CURRENT, + + /** + * (value type = cuuint64_t) + * High watermark of memory, in bytes, currently allocated for use by + * the CUDA graphs asynchronous allocator. + */ + CU_GRAPH_MEM_ATTR_RESERVED_MEM_HIGH +} CUgraphMem_attribute; + +/** + * Child graph node parameters + */ +typedef struct CUDA_CHILD_GRAPH_NODE_PARAMS_st { + CUgraph graph; /**< The child graph to clone into the node for node creation, or + a handle to the graph owned by the node for node query */ +} CUDA_CHILD_GRAPH_NODE_PARAMS; + +/** + * Event record node parameters + */ +typedef struct CUDA_EVENT_RECORD_NODE_PARAMS_st { + CUevent event; /**< The event to record when the node executes */ +} CUDA_EVENT_RECORD_NODE_PARAMS; + +/** + * Event wait node parameters + */ +typedef struct CUDA_EVENT_WAIT_NODE_PARAMS_st { + CUevent event; /**< The event to wait on from the node */ +} CUDA_EVENT_WAIT_NODE_PARAMS; + +/** + * Graph node parameters. See ::cuGraphAddNode. + */ +typedef struct CUgraphNodeParams_st { + CUgraphNodeType type; /**< Type of the node */ + int reserved0[3]; /**< Reserved. Must be zero. */ + + union { + long long reserved1[29]; /**< Padding. Unused bytes must be zero. */ + CUDA_KERNEL_NODE_PARAMS_v3 kernel; /**< Kernel node parameters. */ + CUDA_MEMCPY_NODE_PARAMS memcpy; /**< Memcpy node parameters. */ + CUDA_MEMSET_NODE_PARAMS_v2 memset; /**< Memset node parameters. */ + CUDA_HOST_NODE_PARAMS_v2 host; /**< Host node parameters. */ + CUDA_CHILD_GRAPH_NODE_PARAMS graph; /**< Child graph node parameters. */ + CUDA_EVENT_WAIT_NODE_PARAMS eventWait; /**< Event wait node parameters. */ + CUDA_EVENT_RECORD_NODE_PARAMS eventRecord; /**< Event record node parameters. */ + CUDA_EXT_SEM_SIGNAL_NODE_PARAMS_v2 extSemSignal; /**< External semaphore signal node parameters. */ + CUDA_EXT_SEM_WAIT_NODE_PARAMS_v2 extSemWait; /**< External semaphore wait node parameters. */ + CUDA_MEM_ALLOC_NODE_PARAMS_v2 alloc; /**< Memory allocation node parameters. */ + CUDA_MEM_FREE_NODE_PARAMS free; /**< Memory free node parameters. */ + CUDA_BATCH_MEM_OP_NODE_PARAMS_v2 memOp; /**< MemOp node parameters. */ + CUDA_CONDITIONAL_NODE_PARAMS conditional; /**< Conditional node parameters. */ + }; + + long long reserved2; /**< Reserved bytes. Must be zero. */ +} CUgraphNodeParams; + +/** + * If set, each kernel launched as part of ::cuLaunchCooperativeKernelMultiDevice only + * waits for prior work in the stream corresponding to that GPU to complete before the + * kernel begins execution. + */ +#define CUDA_COOPERATIVE_LAUNCH_MULTI_DEVICE_NO_PRE_LAUNCH_SYNC 0x01 + +/** + * If set, any subsequent work pushed in a stream that participated in a call to + * ::cuLaunchCooperativeKernelMultiDevice will only wait for the kernel launched on + * the GPU corresponding to that stream to complete before it begins execution. + */ +#define CUDA_COOPERATIVE_LAUNCH_MULTI_DEVICE_NO_POST_LAUNCH_SYNC 0x02 + +/** + * If set, the CUDA array is a collection of layers, where each layer is either a 1D + * or a 2D array and the Depth member of CUDA_ARRAY3D_DESCRIPTOR specifies the number + * of layers, not the depth of a 3D array. + */ +#define CUDA_ARRAY3D_LAYERED 0x01 + +/** + * Deprecated, use CUDA_ARRAY3D_LAYERED + */ +#define CUDA_ARRAY3D_2DARRAY 0x01 + +/** + * This flag must be set in order to bind a surface reference + * to the CUDA array + */ +#define CUDA_ARRAY3D_SURFACE_LDST 0x02 + +/** + * If set, the CUDA array is a collection of six 2D arrays, representing faces of a cube. The + * width of such a CUDA array must be equal to its height, and Depth must be six. + * If ::CUDA_ARRAY3D_LAYERED flag is also set, then the CUDA array is a collection of cubemaps + * and Depth must be a multiple of six. + */ +#define CUDA_ARRAY3D_CUBEMAP 0x04 + +/** + * This flag must be set in order to perform texture gather operations + * on a CUDA array. + */ +#define CUDA_ARRAY3D_TEXTURE_GATHER 0x08 + +/** + * This flag if set indicates that the CUDA + * array is a DEPTH_TEXTURE. + */ +#define CUDA_ARRAY3D_DEPTH_TEXTURE 0x10 + +/** + * This flag indicates that the CUDA array may be bound as a color target + * in an external graphics API + */ +#define CUDA_ARRAY3D_COLOR_ATTACHMENT 0x20 + +/** + * This flag if set indicates that the CUDA array or CUDA mipmapped array + * is a sparse CUDA array or CUDA mipmapped array respectively + */ +#define CUDA_ARRAY3D_SPARSE 0x40 + +/** + * This flag if set indicates that the CUDA array or CUDA mipmapped array + * will allow deferred memory mapping + */ +#define CUDA_ARRAY3D_DEFERRED_MAPPING 0x80 + +/** + * This flag indicates that the CUDA array will be used for hardware accelerated + * video encode/decode operations. + */ +#define CUDA_ARRAY3D_VIDEO_ENCODE_DECODE 0x100 + +/** + * Override the texref format with a format inferred from the array. + * Flag for ::cuTexRefSetArray() + */ +#define CU_TRSA_OVERRIDE_FORMAT 0x01 + +/** + * Read the texture as integers rather than promoting the values to floats + * in the range [0,1]. + * Flag for ::cuTexRefSetFlags() and ::cuTexObjectCreate() + */ +#define CU_TRSF_READ_AS_INTEGER 0x01 + +/** + * Use normalized texture coordinates in the range [0,1) instead of [0,dim). + * Flag for ::cuTexRefSetFlags() and ::cuTexObjectCreate() + */ +#define CU_TRSF_NORMALIZED_COORDINATES 0x02 + +/** + * Perform sRGB->linear conversion during texture read. + * Flag for ::cuTexRefSetFlags() and ::cuTexObjectCreate() + */ +#define CU_TRSF_SRGB 0x10 + + /** + * Disable any trilinear filtering optimizations. + * Flag for ::cuTexRefSetFlags() and ::cuTexObjectCreate() + */ +#define CU_TRSF_DISABLE_TRILINEAR_OPTIMIZATION 0x20 + +/** + * Enable seamless cube map filtering. + * Flag for ::cuTexObjectCreate() + */ +#define CU_TRSF_SEAMLESS_CUBEMAP 0x40 + +/** + * C++ compile time constant for CU_LAUNCH_PARAM_END + */ +#define CU_LAUNCH_PARAM_END_AS_INT 0x00 + +/** + * End of array terminator for the \p extra parameter to + * ::cuLaunchKernel + */ +#define CU_LAUNCH_PARAM_END ((void*)CU_LAUNCH_PARAM_END_AS_INT) + +/** + * C++ compile time constant for CU_LAUNCH_PARAM_BUFFER_POINTER + */ +#define CU_LAUNCH_PARAM_BUFFER_POINTER_AS_INT 0x01 + +/** + * Indicator that the next value in the \p extra parameter to + * ::cuLaunchKernel will be a pointer to a buffer containing all kernel + * parameters used for launching kernel \p f. This buffer needs to + * honor all alignment/padding requirements of the individual parameters. + * If ::CU_LAUNCH_PARAM_BUFFER_SIZE is not also specified in the + * \p extra array, then ::CU_LAUNCH_PARAM_BUFFER_POINTER will have no + * effect. + */ +#define CU_LAUNCH_PARAM_BUFFER_POINTER ((void*)CU_LAUNCH_PARAM_BUFFER_POINTER_AS_INT) + +/** + * C++ compile time constant for CU_LAUNCH_PARAM_BUFFER_SIZE + */ +#define CU_LAUNCH_PARAM_BUFFER_SIZE_AS_INT 0x02 + +/** + * Indicator that the next value in the \p extra parameter to + * ::cuLaunchKernel will be a pointer to a size_t which contains the + * size of the buffer specified with ::CU_LAUNCH_PARAM_BUFFER_POINTER. + * It is required that ::CU_LAUNCH_PARAM_BUFFER_POINTER also be specified + * in the \p extra array if the value associated with + * ::CU_LAUNCH_PARAM_BUFFER_SIZE is not zero. + */ +#define CU_LAUNCH_PARAM_BUFFER_SIZE ((void*)CU_LAUNCH_PARAM_BUFFER_SIZE_AS_INT) + +/** + * For texture references loaded into the module, use default texunit from + * texture reference. + */ +#define CU_PARAM_TR_DEFAULT -1 + +/** + * Device that represents the CPU + */ +#define CU_DEVICE_CPU ((CUdevice)-1) + +/** + * Device that represents an invalid device + */ +#define CU_DEVICE_INVALID ((CUdevice)-2) + +/** + * Bitmasks for ::CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_FLUSH_WRITES_OPTIONS + */ +typedef enum CUflushGPUDirectRDMAWritesOptions_enum { + CU_FLUSH_GPU_DIRECT_RDMA_WRITES_OPTION_HOST = 1<<0, /**< ::cuFlushGPUDirectRDMAWrites() and its CUDA Runtime API counterpart are supported on the device. */ + CU_FLUSH_GPU_DIRECT_RDMA_WRITES_OPTION_MEMOPS = 1<<1 /**< The ::CU_STREAM_WAIT_VALUE_FLUSH flag and the ::CU_STREAM_MEM_OP_FLUSH_REMOTE_WRITES MemOp are supported on the device. */ +} CUflushGPUDirectRDMAWritesOptions; + +/** + * Platform native ordering for GPUDirect RDMA writes + */ +typedef enum CUGPUDirectRDMAWritesOrdering_enum { + CU_GPU_DIRECT_RDMA_WRITES_ORDERING_NONE = 0, /**< The device does not natively support ordering of remote writes. ::cuFlushGPUDirectRDMAWrites() can be leveraged if supported. */ + CU_GPU_DIRECT_RDMA_WRITES_ORDERING_OWNER = 100, /**< Natively, the device can consistently consume remote writes, although other CUDA devices may not. */ + CU_GPU_DIRECT_RDMA_WRITES_ORDERING_ALL_DEVICES = 200 /**< Any CUDA device in the system can consistently consume remote writes to this device. */ +} CUGPUDirectRDMAWritesOrdering; + +/** + * The scopes for ::cuFlushGPUDirectRDMAWrites + */ +typedef enum CUflushGPUDirectRDMAWritesScope_enum { + CU_FLUSH_GPU_DIRECT_RDMA_WRITES_TO_OWNER = 100, /**< Blocks until remote writes are visible to the CUDA device context owning the data. */ + CU_FLUSH_GPU_DIRECT_RDMA_WRITES_TO_ALL_DEVICES = 200 /**< Blocks until remote writes are visible to all CUDA device contexts. */ +} CUflushGPUDirectRDMAWritesScope; + +/** + * The targets for ::cuFlushGPUDirectRDMAWrites + */ +typedef enum CUflushGPUDirectRDMAWritesTarget_enum { + CU_FLUSH_GPU_DIRECT_RDMA_WRITES_TARGET_CURRENT_CTX = 0 /**< Sets the target for ::cuFlushGPUDirectRDMAWrites() to the currently active CUDA device context. */ +} CUflushGPUDirectRDMAWritesTarget; + +/** + * The additional write options for ::cuGraphDebugDotPrint + */ +typedef enum CUgraphDebugDot_flags_enum { + CU_GRAPH_DEBUG_DOT_FLAGS_VERBOSE = 1<<0, /**< Output all debug data as if every debug flag is enabled */ + CU_GRAPH_DEBUG_DOT_FLAGS_RUNTIME_TYPES = 1<<1, /**< Use CUDA Runtime structures for output */ + CU_GRAPH_DEBUG_DOT_FLAGS_KERNEL_NODE_PARAMS = 1<<2, /**< Adds CUDA_KERNEL_NODE_PARAMS values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_MEMCPY_NODE_PARAMS = 1<<3, /**< Adds CUDA_MEMCPY3D values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_MEMSET_NODE_PARAMS = 1<<4, /**< Adds CUDA_MEMSET_NODE_PARAMS values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_HOST_NODE_PARAMS = 1<<5, /**< Adds CUDA_HOST_NODE_PARAMS values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_EVENT_NODE_PARAMS = 1<<6, /**< Adds CUevent handle from record and wait nodes to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_EXT_SEMAS_SIGNAL_NODE_PARAMS = 1<<7, /**< Adds CUDA_EXT_SEM_SIGNAL_NODE_PARAMS values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_EXT_SEMAS_WAIT_NODE_PARAMS = 1<<8, /**< Adds CUDA_EXT_SEM_WAIT_NODE_PARAMS values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_KERNEL_NODE_ATTRIBUTES = 1<<9, /**< Adds CUkernelNodeAttrValue values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_HANDLES = 1<<10, /**< Adds node handles and every kernel function handle to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_MEM_ALLOC_NODE_PARAMS = 1<<11, /**< Adds memory alloc node parameters to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_MEM_FREE_NODE_PARAMS = 1<<12, /**< Adds memory free node parameters to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_BATCH_MEM_OP_NODE_PARAMS = 1<<13, /**< Adds batch mem op node parameters to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_EXTRA_TOPO_INFO = 1<<14, /**< Adds edge numbering information */ + CU_GRAPH_DEBUG_DOT_FLAGS_CONDITIONAL_NODE_PARAMS = 1<<15 /**< Adds conditional node parameters to output */ +} CUgraphDebugDot_flags; + +/** + * Flags for user objects for graphs + */ +typedef enum CUuserObject_flags_enum { + CU_USER_OBJECT_NO_DESTRUCTOR_SYNC = 1 /**< Indicates the destructor execution is not synchronized by any CUDA handle. */ +} CUuserObject_flags; + +/** + * Flags for retaining user object references for graphs + */ +typedef enum CUuserObjectRetain_flags_enum { + CU_GRAPH_USER_OBJECT_MOVE = 1 /**< Transfer references from the caller rather than creating new references. */ +} CUuserObjectRetain_flags; + +/** + * Flags for instantiating a graph + */ +typedef enum CUgraphInstantiate_flags_enum { + CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH = 1 /**< Automatically free memory allocated in a graph before relaunching. */ + , CUDA_GRAPH_INSTANTIATE_FLAG_UPLOAD = 2 /**< Automatically upload the graph after instantiation. Only supported by + ::cuGraphInstantiateWithParams. The upload will be performed using the + stream provided in \p instantiateParams. */ + , CUDA_GRAPH_INSTANTIATE_FLAG_DEVICE_LAUNCH = 4 /**< Instantiate the graph to be launchable from the device. This flag can only + be used on platforms which support unified addressing. This flag cannot be + used in conjunction with CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH. */ + , CUDA_GRAPH_INSTANTIATE_FLAG_USE_NODE_PRIORITY = 8 /**< Run the graph using the per-node priority attributes rather than the + priority of the stream it is launched into. */ +} CUgraphInstantiate_flags; + +/** + * CUDA device NUMA configuration + */ +typedef enum CUdeviceNumaConfig_enum { + CU_DEVICE_NUMA_CONFIG_NONE = 0, /**< The GPU is not a NUMA node */ + CU_DEVICE_NUMA_CONFIG_NUMA_NODE, /**< The GPU is a NUMA node, CU_DEVICE_ATTRIBUTE_NUMA_ID contains its NUMA ID */ +} CUdeviceNumaConfig; + +/** @} */ /* END CUDA_TYPES */ + +#if defined(__GNUC__) + #if defined(__CUDA_API_PUSH_VISIBILITY_DEFAULT) + #pragma GCC visibility push(default) + #endif +#endif + +#ifdef _WIN32 +#define CUDAAPI __stdcall +#else +#define CUDAAPI +#endif + +/** + * \defgroup CUDA_ERROR Error Handling + * + * ___MANBRIEF___ error handling functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the error handling functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Gets the string description of an error code + * + * Sets \p *pStr to the address of a NULL-terminated string description + * of the error code \p error. + * If the error code is not recognized, ::CUDA_ERROR_INVALID_VALUE + * will be returned and \p *pStr will be set to the NULL address. + * + * \param error - Error code to convert to string + * \param pStr - Address of the string pointer. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::CUresult, + * ::cudaGetErrorString + */ +CUresult CUDAAPI cuGetErrorString(CUresult error, const char **pStr); + +/** + * \brief Gets the string representation of an error code enum name + * + * Sets \p *pStr to the address of a NULL-terminated string representation + * of the name of the enum error code \p error. + * If the error code is not recognized, ::CUDA_ERROR_INVALID_VALUE + * will be returned and \p *pStr will be set to the NULL address. + * + * \param error - Error code to convert to string + * \param pStr - Address of the string pointer. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::CUresult, + * ::cudaGetErrorName + */ +CUresult CUDAAPI cuGetErrorName(CUresult error, const char **pStr); + +/** @} */ /* END CUDA_ERROR */ + +/** + * \defgroup CUDA_INITIALIZE Initialization + * + * ___MANBRIEF___ initialization functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the initialization functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Initialize the CUDA driver API + * Initializes the driver API and must be called before any other function from + * the driver API in the current process. Currently, the \p Flags parameter must be 0. If ::cuInit() + * has not been called, any function from the driver API will return + * ::CUDA_ERROR_NOT_INITIALIZED. + * + * \param Flags - Initialization flag for CUDA. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_SYSTEM_DRIVER_MISMATCH, + * ::CUDA_ERROR_COMPAT_NOT_SUPPORTED_ON_DEVICE + * \notefnerr + */ +CUresult CUDAAPI cuInit(unsigned int Flags); + +/** @} */ /* END CUDA_INITIALIZE */ + +/** + * \defgroup CUDA_VERSION Version Management + * + * ___MANBRIEF___ version management functions of the low-level CUDA driver + * API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the version management functions of the low-level + * CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns the latest CUDA version supported by driver + * + * Returns in \p *driverVersion the version of CUDA supported by + * the driver. The version is returned as + * (1000 × major + 10 × minor). For example, CUDA 9.2 + * would be represented by 9020. + * + * This function automatically returns ::CUDA_ERROR_INVALID_VALUE if + * \p driverVersion is NULL. + * + * \param driverVersion - Returns the CUDA driver version + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cudaDriverGetVersion, + * ::cudaRuntimeGetVersion + */ +CUresult CUDAAPI cuDriverGetVersion(int *driverVersion); + +/** @} */ /* END CUDA_VERSION */ + +/** + * \defgroup CUDA_DEVICE Device Management + * + * ___MANBRIEF___ device management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the device management functions of the low-level + * CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns a handle to a compute device + * + * Returns in \p *device a device handle given an ordinal in the range [0, + * ::cuDeviceGetCount()-1]. + * + * \param device - Returned device handle + * \param ordinal - Device number to get handle for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGetLuid, + * ::cuDeviceTotalMem, + * ::cuDeviceGetExecAffinitySupport + */ +CUresult CUDAAPI cuDeviceGet(CUdevice *device, int ordinal); + +/** + * \brief Returns the number of compute-capable devices + * + * Returns in \p *count the number of devices with compute capability greater + * than or equal to 2.0 that are available for execution. If there is no such + * device, ::cuDeviceGetCount() returns 0. + * + * \param count - Returned number of compute-capable devices + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGetLuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem, + * ::cuDeviceGetExecAffinitySupport, + * ::cudaGetDeviceCount + */ +CUresult CUDAAPI cuDeviceGetCount(int *count); + +/** + * \brief Returns an identifier string for the device + * + * Returns an ASCII string identifying the device \p dev in the NULL-terminated + * string pointed to by \p name. \p len specifies the maximum length of the + * string that may be returned. + * + * \param name - Returned identifier string for the device + * \param len - Maximum length of string to store in \p name + * \param dev - Device to get identifier string for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetUuid, + * ::cuDeviceGetLuid, + * ::cuDeviceGetCount, + * ::cuDeviceGet, + * ::cuDeviceTotalMem, + * ::cuDeviceGetExecAffinitySupport, + * ::cudaGetDeviceProperties + */ +CUresult CUDAAPI cuDeviceGetName(char *name, int len, CUdevice dev); + +/** + * \brief Return an UUID for the device + * + * Note there is a later version of this API, ::cuDeviceGetUuid_v2. It will + * supplant this version in 12.0, which is retained for minor version compatibility. + * + * Returns 16-octets identifying the device \p dev in the structure + * pointed by the \p uuid. + * + * \param uuid - Returned UUID + * \param dev - Device to get identifier string for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetUuid_v2 + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetLuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem, + * ::cuDeviceGetExecAffinitySupport, + * ::cudaGetDeviceProperties + */ +CUresult CUDAAPI cuDeviceGetUuid(CUuuid *uuid, CUdevice dev); + +/** + * \brief Return an UUID for the device (11.4+) + * + * Returns 16-octets identifying the device \p dev in the structure + * pointed by the \p uuid. If the device is in MIG mode, returns its + * MIG UUID which uniquely identifies the subscribed MIG compute instance. + * + * \param uuid - Returned UUID + * \param dev - Device to get identifier string for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetLuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem, + * ::cudaGetDeviceProperties + */ +CUresult CUDAAPI cuDeviceGetUuid_v2(CUuuid *uuid, CUdevice dev); + +/** + * \brief Return an LUID and device node mask for the device + * + * Return identifying information (\p luid and \p deviceNodeMask) to allow + * matching device with graphics APIs. + * + * \param luid - Returned LUID + * \param deviceNodeMask - Returned device node mask + * \param dev - Device to get identifier string for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGet, + * ::cuDeviceTotalMem, + * ::cuDeviceGetExecAffinitySupport, + * ::cudaGetDeviceProperties + */ +CUresult CUDAAPI cuDeviceGetLuid(char *luid, unsigned int *deviceNodeMask, CUdevice dev); + +/** + * \brief Returns the total amount of memory on the device + * + * Returns in \p *bytes the total amount of memory available on the device + * \p dev in bytes. + * + * \param bytes - Returned memory available on device in bytes + * \param dev - Device handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGet, + * ::cuDeviceGetExecAffinitySupport, + * ::cudaMemGetInfo + */ +CUresult CUDAAPI cuDeviceTotalMem(size_t *bytes, CUdevice dev); + +/** + * \brief Returns the maximum number of elements allocatable in a 1D linear texture for a given texture element size. + * + * Returns in \p maxWidthInElements the maximum number of texture elements allocatable in a 1D linear texture + * for given \p format and \p numChannels. + * + * \param maxWidthInElements - Returned maximum number of texture elements allocatable for given \p format and \p numChannels. + * \param format - Texture format. + * \param numChannels - Number of channels per texture element. + * \param dev - Device handle. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGet, + * ::cudaMemGetInfo, + * ::cuDeviceTotalMem + */ +CUresult CUDAAPI cuDeviceGetTexture1DLinearMaxWidth(size_t *maxWidthInElements, CUarray_format format, unsigned numChannels, CUdevice dev); + +/** + * \brief Returns information about the device + * + * Returns in \p *pi the integer value of the attribute \p attrib on device + * \p dev. The supported attributes are: + * - ::CU_DEVICE_ATTRIBUTE_MAX_THREADS_PER_BLOCK: Maximum number of threads per + * block; + * - ::CU_DEVICE_ATTRIBUTE_MAX_BLOCK_DIM_X: Maximum x-dimension of a block + * - ::CU_DEVICE_ATTRIBUTE_MAX_BLOCK_DIM_Y: Maximum y-dimension of a block + * - ::CU_DEVICE_ATTRIBUTE_MAX_BLOCK_DIM_Z: Maximum z-dimension of a block + * - ::CU_DEVICE_ATTRIBUTE_MAX_GRID_DIM_X: Maximum x-dimension of a grid + * - ::CU_DEVICE_ATTRIBUTE_MAX_GRID_DIM_Y: Maximum y-dimension of a grid + * - ::CU_DEVICE_ATTRIBUTE_MAX_GRID_DIM_Z: Maximum z-dimension of a grid + * - ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK: Maximum amount of + * shared memory available to a thread block in bytes + * - ::CU_DEVICE_ATTRIBUTE_TOTAL_CONSTANT_MEMORY: Memory available on device for + * __constant__ variables in a CUDA C kernel in bytes + * - ::CU_DEVICE_ATTRIBUTE_WARP_SIZE: Warp size in threads + * - ::CU_DEVICE_ATTRIBUTE_MAX_PITCH: Maximum pitch in bytes allowed by the + * memory copy functions that involve memory regions allocated through + * ::cuMemAllocPitch() + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_WIDTH: Maximum 1D + * texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LINEAR_WIDTH: Maximum width + * for a 1D texture bound to linear memory + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_MIPMAPPED_WIDTH: Maximum + * mipmapped 1D texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_WIDTH: Maximum 2D + * texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_HEIGHT: Maximum 2D + * texture height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_WIDTH: Maximum width + * for a 2D texture bound to linear memory + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_HEIGHT: Maximum height + * for a 2D texture bound to linear memory + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_PITCH: Maximum pitch + * in bytes for a 2D texture bound to linear memory + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_MIPMAPPED_WIDTH: Maximum + * mipmapped 2D texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_MIPMAPPED_HEIGHT: Maximum + * mipmapped 2D texture height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_WIDTH: Maximum 3D + * texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_HEIGHT: Maximum 3D + * texture height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_DEPTH: Maximum 3D + * texture depth + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_WIDTH_ALTERNATE: + * Alternate maximum 3D texture width, 0 if no alternate + * maximum 3D texture size is supported + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_HEIGHT_ALTERNATE: + * Alternate maximum 3D texture height, 0 if no alternate + * maximum 3D texture size is supported + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_DEPTH_ALTERNATE: + * Alternate maximum 3D texture depth, 0 if no alternate + * maximum 3D texture size is supported + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURECUBEMAP_WIDTH: + * Maximum cubemap texture width or height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LAYERED_WIDTH: + * Maximum 1D layered texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LAYERED_LAYERS: + * Maximum layers in a 1D layered texture + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_WIDTH: + * Maximum 2D layered texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_HEIGHT: + * Maximum 2D layered texture height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_LAYERS: + * Maximum layers in a 2D layered texture + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURECUBEMAP_LAYERED_WIDTH: + * Maximum cubemap layered texture width or height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURECUBEMAP_LAYERED_LAYERS: + * Maximum layers in a cubemap layered texture + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE1D_WIDTH: + * Maximum 1D surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_WIDTH: + * Maximum 2D surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_HEIGHT: + * Maximum 2D surface height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE3D_WIDTH: + * Maximum 3D surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE3D_HEIGHT: + * Maximum 3D surface height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE3D_DEPTH: + * Maximum 3D surface depth + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE1D_LAYERED_WIDTH: + * Maximum 1D layered surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE1D_LAYERED_LAYERS: + * Maximum layers in a 1D layered surface + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_LAYERED_WIDTH: + * Maximum 2D layered surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_LAYERED_HEIGHT: + * Maximum 2D layered surface height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_LAYERED_LAYERS: + * Maximum layers in a 2D layered surface + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACECUBEMAP_WIDTH: + * Maximum cubemap surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACECUBEMAP_LAYERED_WIDTH: + * Maximum cubemap layered surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACECUBEMAP_LAYERED_LAYERS: + * Maximum layers in a cubemap layered surface + * - ::CU_DEVICE_ATTRIBUTE_MAX_REGISTERS_PER_BLOCK: Maximum number of 32-bit + * registers available to a thread block + * - ::CU_DEVICE_ATTRIBUTE_CLOCK_RATE: The typical clock frequency in kilohertz + * - ::CU_DEVICE_ATTRIBUTE_TEXTURE_ALIGNMENT: Alignment requirement; texture + * base addresses aligned to ::textureAlign bytes do not need an offset + * applied to texture fetches + * - ::CU_DEVICE_ATTRIBUTE_TEXTURE_PITCH_ALIGNMENT: Pitch alignment requirement + * for 2D texture references bound to pitched memory + * - ::CU_DEVICE_ATTRIBUTE_GPU_OVERLAP: 1 if the device can concurrently copy + * memory between host and device while executing a kernel, or 0 if not + * - ::CU_DEVICE_ATTRIBUTE_MULTIPROCESSOR_COUNT: Number of multiprocessors on + * the device + * - ::CU_DEVICE_ATTRIBUTE_KERNEL_EXEC_TIMEOUT: 1 if there is a run time limit + * for kernels executed on the device, or 0 if not + * - ::CU_DEVICE_ATTRIBUTE_INTEGRATED: 1 if the device is integrated with the + * memory subsystem, or 0 if not + * - ::CU_DEVICE_ATTRIBUTE_CAN_MAP_HOST_MEMORY: 1 if the device can map host + * memory into the CUDA address space, or 0 if not + * - ::CU_DEVICE_ATTRIBUTE_COMPUTE_MODE: Compute mode that device is currently + * in. Available modes are as follows: + * - ::CU_COMPUTEMODE_DEFAULT: Default mode - Device is not restricted and + * can have multiple CUDA contexts present at a single time. + * - ::CU_COMPUTEMODE_PROHIBITED: Compute-prohibited mode - Device is + * prohibited from creating new CUDA contexts. + * - ::CU_COMPUTEMODE_EXCLUSIVE_PROCESS: Compute-exclusive-process mode - Device + * can have only one context used by a single process at a time. + * - ::CU_DEVICE_ATTRIBUTE_CONCURRENT_KERNELS: 1 if the device supports + * executing multiple kernels within the same context simultaneously, or 0 if + * not. It is not guaranteed that multiple kernels will be resident + * on the device concurrently so this feature should not be relied upon for + * correctness. + * - ::CU_DEVICE_ATTRIBUTE_ECC_ENABLED: 1 if error correction is enabled on the + * device, 0 if error correction is disabled or not supported by the device + * - ::CU_DEVICE_ATTRIBUTE_PCI_BUS_ID: PCI bus identifier of the device + * - ::CU_DEVICE_ATTRIBUTE_PCI_DEVICE_ID: PCI device (also known as slot) identifier + * of the device + * - ::CU_DEVICE_ATTRIBUTE_PCI_DOMAIN_ID: PCI domain identifier of the device + * - ::CU_DEVICE_ATTRIBUTE_TCC_DRIVER: 1 if the device is using a TCC driver. TCC + * is only available on Tesla hardware running Windows Vista or later + * - ::CU_DEVICE_ATTRIBUTE_MEMORY_CLOCK_RATE: Peak memory clock frequency in kilohertz + * - ::CU_DEVICE_ATTRIBUTE_GLOBAL_MEMORY_BUS_WIDTH: Global memory bus width in bits + * - ::CU_DEVICE_ATTRIBUTE_L2_CACHE_SIZE: Size of L2 cache in bytes. 0 if the device doesn't have L2 cache + * - ::CU_DEVICE_ATTRIBUTE_MAX_THREADS_PER_MULTIPROCESSOR: Maximum resident threads per multiprocessor + * - ::CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING: 1 if the device shares a unified address space with + * the host, or 0 if not + * - ::CU_DEVICE_ATTRIBUTE_COMPUTE_CAPABILITY_MAJOR: Major compute capability version number + * - ::CU_DEVICE_ATTRIBUTE_COMPUTE_CAPABILITY_MINOR: Minor compute capability version number + * - ::CU_DEVICE_ATTRIBUTE_GLOBAL_L1_CACHE_SUPPORTED: 1 if device supports caching globals + * in L1 cache, 0 if caching globals in L1 cache is not supported by the device + * - ::CU_DEVICE_ATTRIBUTE_LOCAL_L1_CACHE_SUPPORTED: 1 if device supports caching locals + * in L1 cache, 0 if caching locals in L1 cache is not supported by the device + * - ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_MULTIPROCESSOR: Maximum amount of + * shared memory available to a multiprocessor in bytes; this amount is shared + * by all thread blocks simultaneously resident on a multiprocessor + * - ::CU_DEVICE_ATTRIBUTE_MAX_REGISTERS_PER_MULTIPROCESSOR: Maximum number of 32-bit + * registers available to a multiprocessor; this number is shared by all thread + * blocks simultaneously resident on a multiprocessor + * - ::CU_DEVICE_ATTRIBUTE_MANAGED_MEMORY: 1 if device supports allocating managed memory + * on this system, 0 if allocating managed memory is not supported by the device on this system. + * - ::CU_DEVICE_ATTRIBUTE_MULTI_GPU_BOARD: 1 if device is on a multi-GPU board, 0 if not. + * - ::CU_DEVICE_ATTRIBUTE_MULTI_GPU_BOARD_GROUP_ID: Unique identifier for a group of devices + * associated with the same board. Devices on the same multi-GPU board will share the same identifier. + * - ::CU_DEVICE_ATTRIBUTE_HOST_NATIVE_ATOMIC_SUPPORTED: 1 if Link between the device and the host + * supports native atomic operations. + * - ::CU_DEVICE_ATTRIBUTE_SINGLE_TO_DOUBLE_PRECISION_PERF_RATIO: Ratio of single precision performance + * (in floating-point operations per second) to double precision performance. + * - ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS: Device supports coherently accessing + * pageable memory without calling cudaHostRegister on it. + * - ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS: Device can coherently access managed memory + * concurrently with the CPU. + * - ::CU_DEVICE_ATTRIBUTE_COMPUTE_PREEMPTION_SUPPORTED: Device supports Compute Preemption. + * - ::CU_DEVICE_ATTRIBUTE_CAN_USE_HOST_POINTER_FOR_REGISTERED_MEM: Device can access host registered + * memory at the same virtual address as the CPU. + * - ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK_OPTIN: The maximum per block shared memory size + * supported on this device. This is the maximum value that can be opted into when using the cuFuncSetAttribute() or cuKernelSetAttribute() call. + * For more details see ::CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES + * - ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES: Device accesses pageable memory via the host's + * page tables. + * - ::CU_DEVICE_ATTRIBUTE_DIRECT_MANAGED_MEM_ACCESS_FROM_HOST: The host can directly access managed memory on the device without migration. + * - ::CU_DEVICE_ATTRIBUTE_VIRTUAL_MEMORY_MANAGEMENT_SUPPORTED: Device supports virtual memory management APIs like ::cuMemAddressReserve, ::cuMemCreate, ::cuMemMap and related APIs + * - ::CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_POSIX_FILE_DESCRIPTOR_SUPPORTED: Device supports exporting memory to a posix file descriptor with ::cuMemExportToShareableHandle, if requested via ::cuMemCreate + * - ::CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_WIN32_HANDLE_SUPPORTED: Device supports exporting memory to a Win32 NT handle with ::cuMemExportToShareableHandle, if requested via ::cuMemCreate + * - ::CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_WIN32_KMT_HANDLE_SUPPORTED: Device supports exporting memory to a Win32 KMT handle with ::cuMemExportToShareableHandle, if requested via ::cuMemCreate + * - ::CU_DEVICE_ATTRIBUTE_MAX_BLOCKS_PER_MULTIPROCESSOR: Maximum number of thread blocks that can reside on a multiprocessor + * - ::CU_DEVICE_ATTRIBUTE_GENERIC_COMPRESSION_SUPPORTED: Device supports compressible memory allocation via ::cuMemCreate + * - ::CU_DEVICE_ATTRIBUTE_MAX_PERSISTING_L2_CACHE_SIZE: Maximum L2 persisting lines capacity setting in bytes + * - ::CU_DEVICE_ATTRIBUTE_MAX_ACCESS_POLICY_WINDOW_SIZE: Maximum value of CUaccessPolicyWindow::num_bytes + * - ::CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_WITH_CUDA_VMM_SUPPORTED: Device supports specifying the GPUDirect RDMA flag with ::cuMemCreate. + * - ::CU_DEVICE_ATTRIBUTE_RESERVED_SHARED_MEMORY_PER_BLOCK: Amount of shared memory per block reserved by CUDA driver in bytes + * - ::CU_DEVICE_ATTRIBUTE_SPARSE_CUDA_ARRAY_SUPPORTED: Device supports sparse CUDA arrays and sparse CUDA mipmapped arrays. + * - ::CU_DEVICE_ATTRIBUTE_READ_ONLY_HOST_REGISTER_SUPPORTED: Device supports using the ::cuMemHostRegister flag ::CU_MEMHOSTERGISTER_READ_ONLY to register memory that must be mapped as read-only to the GPU + * - ::CU_DEVICE_ATTRIBUTE_MEMORY_POOLS_SUPPORTED: Device supports using the ::cuMemAllocAsync and ::cuMemPool family of APIs + * - ::CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_SUPPORTED: Device supports GPUDirect RDMA APIs, like nvidia_p2p_get_pages (see https://docs.nvidia.com/cuda/gpudirect-rdma for more information) + * - ::CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_FLUSH_WRITES_OPTIONS: The returned attribute shall be interpreted as a bitmask, where the individual bits are described by the ::CUflushGPUDirectRDMAWritesOptions enum + * - ::CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_WRITES_ORDERING: GPUDirect RDMA writes to the device do not need to be flushed for consumers within the scope indicated by the returned attribute. See ::CUGPUDirectRDMAWritesOrdering for the numerical values returned here. + * - ::CU_DEVICE_ATTRIBUTE_MEMPOOL_SUPPORTED_HANDLE_TYPES: Bitmask of handle types supported with mempool based IPC + * - ::CU_DEVICE_ATTRIBUTE_DEFERRED_MAPPING_CUDA_ARRAY_SUPPORTED: Device supports deferred mapping CUDA arrays and CUDA mipmapped arrays. + * - ::CU_DEVICE_ATTRIBUTE_NUMA_CONFIG: NUMA configuration of a device: value is of type ::CUdeviceNumaConfig enum + * - ::CU_DEVICE_ATTRIBUTE_NUMA_ID: NUMA node ID of the GPU memory + * - ::CU_DEVICE_ATTRIBUTE_MULTICAST_SUPPORTED: Device supports switch multicast and reduction operations. + * + * \param pi - Returned device attribute value + * \param attrib - Device attribute to query + * \param dev - Device handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem, + * ::cuDeviceGetExecAffinitySupport, + * ::cudaDeviceGetAttribute, + * ::cudaGetDeviceProperties + */ +CUresult CUDAAPI cuDeviceGetAttribute(int *pi, CUdevice_attribute attrib, CUdevice dev); + +/** + * \brief Return NvSciSync attributes that this device can support. + * + * Returns in \p nvSciSyncAttrList, the properties of NvSciSync that + * this CUDA device, \p dev can support. The returned \p nvSciSyncAttrList + * can be used to create an NvSciSync object that matches this device's capabilities. + * + * If NvSciSyncAttrKey_RequiredPerm field in \p nvSciSyncAttrList is + * already set this API will return ::CUDA_ERROR_INVALID_VALUE. + * + * The applications should set \p nvSciSyncAttrList to a valid + * NvSciSyncAttrList failing which this API will return + * ::CUDA_ERROR_INVALID_HANDLE. + * + * The \p flags controls how applications intends to use + * the NvSciSync created from the \p nvSciSyncAttrList. The valid flags are: + * - ::CUDA_NVSCISYNC_ATTR_SIGNAL, specifies that the applications intends to + * signal an NvSciSync on this CUDA device. + * - ::CUDA_NVSCISYNC_ATTR_WAIT, specifies that the applications intends to + * wait on an NvSciSync on this CUDA device. + * + * At least one of these flags must be set, failing which the API + * returns ::CUDA_ERROR_INVALID_VALUE. Both the flags are orthogonal + * to one another: a developer may set both these flags that allows to + * set both wait and signal specific attributes in the same \p nvSciSyncAttrList. + * + * Note that this API updates the input \p nvSciSyncAttrList with values equivalent + * to the following public attribute key-values: + * NvSciSyncAttrKey_RequiredPerm is set to + * - NvSciSyncAccessPerm_SignalOnly if ::CUDA_NVSCISYNC_ATTR_SIGNAL is set in \p flags. + * - NvSciSyncAccessPerm_WaitOnly if ::CUDA_NVSCISYNC_ATTR_WAIT is set in \p flags. + * - NvSciSyncAccessPerm_WaitSignal if both ::CUDA_NVSCISYNC_ATTR_WAIT and + * ::CUDA_NVSCISYNC_ATTR_SIGNAL are set in \p flags. + * NvSciSyncAttrKey_PrimitiveInfo is set to + * - NvSciSyncAttrValPrimitiveType_SysmemSemaphore on any valid \p device. + * - NvSciSyncAttrValPrimitiveType_Syncpoint if \p device is a Tegra device. + * - NvSciSyncAttrValPrimitiveType_SysmemSemaphorePayload64b if \p device is GA10X+. + * NvSciSyncAttrKey_GpuId is set to the same UUID that is returned for this + * \p device from ::cuDeviceGetUuid. + * + * \param nvSciSyncAttrList - Return NvSciSync attributes supported. + * \param dev - Valid Cuda Device to get NvSciSync attributes for. + * \param flags - flags describing NvSciSync usage. + * + * \return + * + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa + * ::cuImportExternalSemaphore, + * ::cuDestroyExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuDeviceGetNvSciSyncAttributes(void *nvSciSyncAttrList, CUdevice dev, int flags); + +/** + * \brief Sets the current memory pool of a device + * + * The memory pool must be local to the specified device. + * ::cuMemAllocAsync allocates from the current mempool of the provided stream's device. + * By default, a device's current memory pool is its default memory pool. + * + * \note Use ::cuMemAllocFromPoolAsync to specify asynchronous allocations from a device different + * than the one the stream runs on. + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuDeviceGetDefaultMemPool, ::cuDeviceGetMemPool, ::cuMemPoolCreate, ::cuMemPoolDestroy, ::cuMemAllocFromPoolAsync + */ +CUresult CUDAAPI cuDeviceSetMemPool(CUdevice dev, CUmemoryPool pool); + +/** + * \brief Gets the current mempool for a device + * + * Returns the last pool provided to ::cuDeviceSetMemPool for this device + * or the device's default memory pool if ::cuDeviceSetMemPool has never been called. + * By default the current mempool is the default mempool for a device. + * Otherwise the returned pool must have been set with ::cuDeviceSetMemPool. + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuDeviceGetDefaultMemPool, ::cuMemPoolCreate, ::cuDeviceSetMemPool + */ +CUresult CUDAAPI cuDeviceGetMemPool(CUmemoryPool *pool, CUdevice dev); + +/** + * \brief Returns the default mempool of a device + * + * The default mempool of a device contains device memory from that device. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuMemAllocAsync, ::cuMemPoolTrimTo, ::cuMemPoolGetAttribute, ::cuMemPoolSetAttribute, cuMemPoolSetAccess, ::cuDeviceGetMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuDeviceGetDefaultMemPool(CUmemoryPool *pool_out, CUdevice dev); + +/** + * \brief Returns information about the execution affinity support of the device. + * + * Returns in \p *pi whether execution affinity type \p type is supported by device \p dev. + * The supported types are: + * - ::CU_EXEC_AFFINITY_TYPE_SM_COUNT: 1 if context with limited SMs is supported by the device, + * or 0 if not; + * + * \param pi - 1 if the execution affinity type \p type is supported by the device, or 0 if not + * \param type - Execution affinity type to query + * \param dev - Device handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem + */ +CUresult CUDAAPI cuDeviceGetExecAffinitySupport(int *pi, CUexecAffinityType type, CUdevice dev); + +/** + * \brief Blocks until remote writes are visible to the specified scope + * + * Blocks until GPUDirect RDMA writes to the target context via mappings + * created through APIs like nvidia_p2p_get_pages (see + * https://docs.nvidia.com/cuda/gpudirect-rdma for more information), are + * visible to the specified scope. + * + * If the scope equals or lies within the scope indicated by + * ::CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_WRITES_ORDERING, the call + * will be a no-op and can be safely omitted for performance. This can be + * determined by comparing the numerical values between the two enums, with + * smaller scopes having smaller values. + * + * Users may query support for this API via + * ::CU_DEVICE_ATTRIBUTE_FLUSH_FLUSH_GPU_DIRECT_RDMA_OPTIONS. + * + * \param target - The target of the operation, see ::CUflushGPUDirectRDMAWritesTarget + * \param scope - The scope of the operation, see ::CUflushGPUDirectRDMAWritesScope + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + */ +CUresult CUDAAPI cuFlushGPUDirectRDMAWrites(CUflushGPUDirectRDMAWritesTarget target, CUflushGPUDirectRDMAWritesScope scope); + +/** @} */ /* END CUDA_DEVICE */ + +/** + * \defgroup CUDA_DEVICE_DEPRECATED Device Management [DEPRECATED] + * + * ___MANBRIEF___ deprecated device management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the device management functions of the low-level + * CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns properties for a selected device + * + * \deprecated + * + * This function was deprecated as of CUDA 5.0 and replaced by ::cuDeviceGetAttribute(). + * + * Returns in \p *prop the properties of device \p dev. The ::CUdevprop + * structure is defined as: + * + * \code + typedef struct CUdevprop_st { + int maxThreadsPerBlock; + int maxThreadsDim[3]; + int maxGridSize[3]; + int sharedMemPerBlock; + int totalConstantMemory; + int SIMDWidth; + int memPitch; + int regsPerBlock; + int clockRate; + int textureAlign + } CUdevprop; + * \endcode + * where: + * + * - ::maxThreadsPerBlock is the maximum number of threads per block; + * - ::maxThreadsDim[3] is the maximum sizes of each dimension of a block; + * - ::maxGridSize[3] is the maximum sizes of each dimension of a grid; + * - ::sharedMemPerBlock is the total amount of shared memory available per + * block in bytes; + * - ::totalConstantMemory is the total amount of constant memory available on + * the device in bytes; + * - ::SIMDWidth is the warp size; + * - ::memPitch is the maximum pitch allowed by the memory copy functions that + * involve memory regions allocated through ::cuMemAllocPitch(); + * - ::regsPerBlock is the total number of registers available per block; + * - ::clockRate is the clock frequency in kilohertz; + * - ::textureAlign is the alignment requirement; texture base addresses that + * are aligned to ::textureAlign bytes do not need an offset applied to + * texture fetches. + * + * \param prop - Returned properties of device + * \param dev - Device to get properties for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuDeviceGetProperties(CUdevprop *prop, CUdevice dev); + +/** + * \brief Returns the compute capability of the device + * + * \deprecated + * + * This function was deprecated as of CUDA 5.0 and its functionality superseded + * by ::cuDeviceGetAttribute(). + * + * Returns in \p *major and \p *minor the major and minor revision numbers that + * define the compute capability of the device \p dev. + * + * \param major - Major revision number + * \param minor - Minor revision number + * \param dev - Device handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuDeviceComputeCapability(int *major, int *minor, CUdevice dev); + +/** @} */ /* END CUDA_DEVICE_DEPRECATED */ + +/** + * \defgroup CUDA_PRIMARY_CTX Primary Context Management + * + * ___MANBRIEF___ primary context management functions of the low-level CUDA driver + * API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the primary context management functions of the low-level + * CUDA driver application programming interface. + * + * The primary context is unique per device and shared with the CUDA runtime API. + * These functions allow integration with other libraries using CUDA. + * + * @{ + */ + +/** + * \brief Retain the primary context on the GPU + * + * Retains the primary context on the device. + * Once the user successfully retains the primary context, the primary context + * will be active and available to the user until the user releases it + * with ::cuDevicePrimaryCtxRelease() or resets it with ::cuDevicePrimaryCtxReset(). + * Unlike ::cuCtxCreate() the newly retained context is not pushed onto the stack. + * + * Retaining the primary context for the first time will fail with ::CUDA_ERROR_UNKNOWN + * if the compute mode of the device is ::CU_COMPUTEMODE_PROHIBITED. The function + * ::cuDeviceGetAttribute() can be used with ::CU_DEVICE_ATTRIBUTE_COMPUTE_MODE to + * determine the compute mode of the device. + * The nvidia-smi tool can be used to set the compute mode for + * devices. Documentation for nvidia-smi can be obtained by passing a + * -h option to it. + * + * Please note that the primary context always supports pinned allocations. Other + * flags can be specified by ::cuDevicePrimaryCtxSetFlags(). + * + * \param pctx - Returned context handle of the new context + * \param dev - Device for which primary context is requested + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuDevicePrimaryCtxRelease, + * ::cuDevicePrimaryCtxSetFlags, + * ::cuCtxCreate, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuDevicePrimaryCtxRetain(CUcontext *pctx, CUdevice dev); + +/** + * \brief Release the primary context on the GPU + * + * Releases the primary context interop on the device. + * A retained context should always be released once the user is done using + * it. The context is automatically reset once the last reference to it is + * released. This behavior is different when the primary context was retained + * by the CUDA runtime from CUDA 4.0 and earlier. In this case, the primary + * context remains always active. + * + * Releasing a primary context that has not been previously retained will + * fail with ::CUDA_ERROR_INVALID_CONTEXT. + * + * Please note that unlike ::cuCtxDestroy() this method does not pop the context + * from stack in any circumstances. + * + * \param dev - Device which primary context is released + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuDevicePrimaryCtxRetain, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuDevicePrimaryCtxRelease(CUdevice dev); + +/** + * \brief Set flags for the primary context + * + * Sets the flags for the primary context on the device overwriting perviously + * set ones. + * + * The three LSBs of the \p flags parameter can be used to control how the OS + * thread, which owns the CUDA context at the time of an API call, interacts + * with the OS scheduler when waiting for results from the GPU. Only one of + * the scheduling flags can be set when creating a context. + * + * - ::CU_CTX_SCHED_SPIN: Instruct CUDA to actively spin when waiting for + * results from the GPU. This can decrease latency when waiting for the GPU, + * but may lower the performance of CPU threads if they are performing work in + * parallel with the CUDA thread. + * + * - ::CU_CTX_SCHED_YIELD: Instruct CUDA to yield its thread when waiting for + * results from the GPU. This can increase latency when waiting for the GPU, + * but can increase the performance of CPU threads performing work in parallel + * with the GPU. + * + * - ::CU_CTX_SCHED_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work. + * + * - ::CU_CTX_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work.
+ * Deprecated: This flag was deprecated as of CUDA 4.0 and was + * replaced with ::CU_CTX_SCHED_BLOCKING_SYNC. + * + * - ::CU_CTX_SCHED_AUTO: The default value if the \p flags parameter is zero, + * uses a heuristic based on the number of active CUDA contexts in the + * process \e C and the number of logical processors in the system \e P. If + * \e C > \e P, then CUDA will yield to other OS threads when waiting for + * the GPU (::CU_CTX_SCHED_YIELD), otherwise CUDA will not yield while + * waiting for results and actively spin on the processor (::CU_CTX_SCHED_SPIN). + * Additionally, on Tegra devices, ::CU_CTX_SCHED_AUTO uses a heuristic based on + * the power profile of the platform and may choose ::CU_CTX_SCHED_BLOCKING_SYNC + * for low-powered devices. + * + * - ::CU_CTX_LMEM_RESIZE_TO_MAX: Instruct CUDA to not reduce local memory + * after resizing local memory for a kernel. This can prevent thrashing by + * local memory allocations when launching many kernels with high local + * memory usage at the cost of potentially increased memory usage.
+ * Deprecated: This flag is deprecated and the behavior enabled + * by this flag is now the default and cannot be disabled. + * + * - ::CU_CTX_COREDUMP_ENABLE: If GPU coredumps have not been enabled globally + * with ::cuCoredumpSetAttributeGlobal or environment variables, this flag can + * be set during context creation to instruct CUDA to create a coredump if + * this context raises an exception during execution. These environment variables + * are described in the CUDA-GDB user guide under the "GPU core dump support" + * section. + * The initial settings will be taken from the global settings at the time of + * context creation. The other settings that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * + * - ::CU_CTX_USER_COREDUMP_ENABLE: If user-triggered GPU coredumps have not + * been enabled globally with ::cuCoredumpSetAttributeGlobal or environment + * variables, this flag can be set during context creation to instruct CUDA to + * create a coredump if data is written to a certain pipe that is present in the + * OS space. These environment variables are described in the CUDA-GDB user + * guide under the "GPU core dump support" section. + * It is important to note that the pipe name *must* be set with + * ::cuCoredumpSetAttributeGlobal before creating the context if this flag is + * used. Setting this flag implies that ::CU_CTX_COREDUMP_ENABLE is set. + * The initial settings will be taken from the global settings at the time of + * context creation. The other settings that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * + * - ::CU_CTX_SYNC_MEMOPS: Ensures that synchronous memory operations initiated + * on this context will always synchronize. See further documentation in the + * section titled "API Synchronization behavior" to learn more about cases when + * synchronous memory operations can exhibit asynchronous behavior. + * + * \param dev - Device for which the primary context flags are set + * \param flags - New flags for the device + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa ::cuDevicePrimaryCtxRetain, + * ::cuDevicePrimaryCtxGetState, + * ::cuCtxCreate, + * ::cuCtxGetFlags, + * ::cuCtxSetFlags, + * ::cudaSetDeviceFlags + */ +CUresult CUDAAPI cuDevicePrimaryCtxSetFlags(CUdevice dev, unsigned int flags); + +/** + * \brief Get the state of the primary context + * + * Returns in \p *flags the flags for the primary context of \p dev, and in + * \p *active whether it is active. See ::cuDevicePrimaryCtxSetFlags for flag + * values. + * + * \param dev - Device to get primary context flags for + * \param flags - Pointer to store flags + * \param active - Pointer to store context state; 0 = inactive, 1 = active + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa + * ::cuDevicePrimaryCtxSetFlags, + * ::cuCtxGetFlags, + * ::cuCtxSetFlags, + * ::cudaGetDeviceFlags + */ +CUresult CUDAAPI cuDevicePrimaryCtxGetState(CUdevice dev, unsigned int *flags, int *active); + +/** + * \brief Destroy all allocations and reset all state on the primary context + * + * Explicitly destroys and cleans up all resources associated with the current + * device in the current process. + * + * Note that it is responsibility of the calling function to ensure that no + * other module in the process is using the device any more. For that reason + * it is recommended to use ::cuDevicePrimaryCtxRelease() in most cases. + * However it is safe for other modules to call ::cuDevicePrimaryCtxRelease() + * even after resetting the device. + * Resetting the primary context does not release it, an application that has + * retained the primary context should explicitly release its usage. + * + * \param dev - Device for which primary context is destroyed + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_PRIMARY_CONTEXT_ACTIVE + * \notefnerr + * + * \sa ::cuDevicePrimaryCtxRetain, + * ::cuDevicePrimaryCtxRelease, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cudaDeviceReset + */ +CUresult CUDAAPI cuDevicePrimaryCtxReset(CUdevice dev); + +/** @} */ /* END CUDA_PRIMARY_CTX */ + +/** + * \defgroup CUDA_CTX Context Management + * + * ___MANBRIEF___ context management functions of the low-level CUDA driver + * API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the context management functions of the low-level + * CUDA driver application programming interface. + * + * Please note that some functions are described in + * \ref CUDA_PRIMARY_CTX "Primary Context Management" section. + * + * @{ + */ + +/** + * \brief Create a CUDA context + * + * \note In most cases it is recommended to use ::cuDevicePrimaryCtxRetain. + * + * Creates a new CUDA context and associates it with the calling thread. The + * \p flags parameter is described below. The context is created with a usage + * count of 1 and the caller of ::cuCtxCreate() must call ::cuCtxDestroy() + * when done using the context. If a context is already current to the thread, + * it is supplanted by the newly created context and may be restored by a subsequent + * call to ::cuCtxPopCurrent(). + * + * The three LSBs of the \p flags parameter can be used to control how the OS + * thread, which owns the CUDA context at the time of an API call, interacts + * with the OS scheduler when waiting for results from the GPU. Only one of + * the scheduling flags can be set when creating a context. + * + * - ::CU_CTX_SCHED_SPIN: Instruct CUDA to actively spin when waiting for + * results from the GPU. This can decrease latency when waiting for the GPU, + * but may lower the performance of CPU threads if they are performing work in + * parallel with the CUDA thread. + * + * - ::CU_CTX_SCHED_YIELD: Instruct CUDA to yield its thread when waiting for + * results from the GPU. This can increase latency when waiting for the GPU, + * but can increase the performance of CPU threads performing work in parallel + * with the GPU. + * + * - ::CU_CTX_SCHED_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work. + * + * - ::CU_CTX_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work.
+ * Deprecated: This flag was deprecated as of CUDA 4.0 and was + * replaced with ::CU_CTX_SCHED_BLOCKING_SYNC. + * + * - ::CU_CTX_SCHED_AUTO: The default value if the \p flags parameter is zero, + * uses a heuristic based on the number of active CUDA contexts in the + * process \e C and the number of logical processors in the system \e P. If + * \e C > \e P, then CUDA will yield to other OS threads when waiting for + * the GPU (::CU_CTX_SCHED_YIELD), otherwise CUDA will not yield while + * waiting for results and actively spin on the processor (::CU_CTX_SCHED_SPIN). + * Additionally, on Tegra devices, ::CU_CTX_SCHED_AUTO uses a heuristic based on + * the power profile of the platform and may choose ::CU_CTX_SCHED_BLOCKING_SYNC + * for low-powered devices. + * + * - ::CU_CTX_MAP_HOST: Instruct CUDA to support mapped pinned allocations. + * This flag must be set in order to allocate pinned host memory that is + * accessible to the GPU. + * + * - ::CU_CTX_LMEM_RESIZE_TO_MAX: Instruct CUDA to not reduce local memory + * after resizing local memory for a kernel. This can prevent thrashing by + * local memory allocations when launching many kernels with high local + * memory usage at the cost of potentially increased memory usage.
+ * Deprecated: This flag is deprecated and the behavior enabled + * by this flag is now the default and cannot be disabled. + * Instead, the per-thread stack size can be controlled with ::cuCtxSetLimit(). + * + * - ::CU_CTX_COREDUMP_ENABLE: If GPU coredumps have not been enabled globally + * with ::cuCoredumpSetAttributeGlobal or environment variables, this flag can + * be set during context creation to instruct CUDA to create a coredump if + * this context raises an exception during execution. These environment variables + * are described in the CUDA-GDB user guide under the "GPU core dump support" + * section. + * The initial attributes will be taken from the global attributes at the time of + * context creation. The other attributes that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * + * - ::CU_CTX_USER_COREDUMP_ENABLE: If user-triggered GPU coredumps have not + * been enabled globally with ::cuCoredumpSetAttributeGlobal or environment + * variables, this flag can be set during context creation to instruct CUDA to + * create a coredump if data is written to a certain pipe that is present in the + * OS space. These environment variables are described in the CUDA-GDB user + * guide under the "GPU core dump support" section. + * It is important to note that the pipe name *must* be set with + * ::cuCoredumpSetAttributeGlobal before creating the context if this flag is + * used. Setting this flag implies that ::CU_CTX_COREDUMP_ENABLE is set. + * The initial attributes will be taken from the global attributes at the time of + * context creation. The other attributes that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * Setting this flag on any context creation is equivalent to setting the + * ::CU_COREDUMP_ENABLE_USER_TRIGGER attribute to \p true globally. + * + * - ::CU_CTX_SYNC_MEMOPS: Ensures that synchronous memory operations initiated + * on this context will always synchronize. See further documentation in the + * section titled "API Synchronization behavior" to learn more about cases when + * synchronous memory operations can exhibit asynchronous behavior. + * + * Context creation will fail with ::CUDA_ERROR_UNKNOWN if the compute mode of + * the device is ::CU_COMPUTEMODE_PROHIBITED. The function ::cuDeviceGetAttribute() + * can be used with ::CU_DEVICE_ATTRIBUTE_COMPUTE_MODE to determine the + * compute mode of the device. The nvidia-smi tool can be used to set + * the compute mode for * devices. + * Documentation for nvidia-smi can be obtained by passing a + * -h option to it. + * + * \param pctx - Returned context handle of the new context + * \param flags - Context creation flags + * \param dev - Device to create context on + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCoredumpSetAttributeGlobal, + * ::cuCoredumpSetAttribute, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuCtxCreate(CUcontext *pctx, unsigned int flags, CUdevice dev); + +/** + * \brief Create a CUDA context with execution affinity + * + * Creates a new CUDA context with execution affinity and associates it with + * the calling thread. The \p paramsArray and \p flags parameter are described below. + * The context is created with a usage count of 1 and the caller of ::cuCtxCreate() must + * call ::cuCtxDestroy() when done using the context. If a context is already + * current to the thread, it is supplanted by the newly created context and may + * be restored by a subsequent call to ::cuCtxPopCurrent(). + * + * The type and the amount of execution resource the context can use is limited by \p paramsArray + * and \p numParams. The \p paramsArray is an array of \p CUexecAffinityParam and the \p numParams + * describes the size of the array. If two \p CUexecAffinityParam in the array have the same type, + * the latter execution affinity parameter overrides the former execution affinity parameter. + * The supported execution affinity types are: + * - ::CU_EXEC_AFFINITY_TYPE_SM_COUNT limits the portion of SMs that the context can use. The portion + * of SMs is specified as the number of SMs via \p CUexecAffinitySmCount. This limit will be internally + * rounded up to the next hardware-supported amount. Hence, it is imperative to query the actual execution + * affinity of the context via \p cuCtxGetExecAffinity after context creation. Currently, this attribute + * is only supported under Volta+ MPS. + * + * The three LSBs of the \p flags parameter can be used to control how the OS + * thread, which owns the CUDA context at the time of an API call, interacts + * with the OS scheduler when waiting for results from the GPU. Only one of + * the scheduling flags can be set when creating a context. + * + * - ::CU_CTX_SCHED_SPIN: Instruct CUDA to actively spin when waiting for + * results from the GPU. This can decrease latency when waiting for the GPU, + * but may lower the performance of CPU threads if they are performing work in + * parallel with the CUDA thread. + * + * - ::CU_CTX_SCHED_YIELD: Instruct CUDA to yield its thread when waiting for + * results from the GPU. This can increase latency when waiting for the GPU, + * but can increase the performance of CPU threads performing work in parallel + * with the GPU. + * + * - ::CU_CTX_SCHED_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work. + * + * - ::CU_CTX_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work.
+ * Deprecated: This flag was deprecated as of CUDA 4.0 and was + * replaced with ::CU_CTX_SCHED_BLOCKING_SYNC. + * + * - ::CU_CTX_SCHED_AUTO: The default value if the \p flags parameter is zero, + * uses a heuristic based on the number of active CUDA contexts in the + * process \e C and the number of logical processors in the system \e P. If + * \e C > \e P, then CUDA will yield to other OS threads when waiting for + * the GPU (::CU_CTX_SCHED_YIELD), otherwise CUDA will not yield while + * waiting for results and actively spin on the processor (::CU_CTX_SCHED_SPIN). + * Additionally, on Tegra devices, ::CU_CTX_SCHED_AUTO uses a heuristic based on + * the power profile of the platform and may choose ::CU_CTX_SCHED_BLOCKING_SYNC + * for low-powered devices. + * + * - ::CU_CTX_MAP_HOST: Instruct CUDA to support mapped pinned allocations. + * This flag must be set in order to allocate pinned host memory that is + * accessible to the GPU. + * + * - ::CU_CTX_LMEM_RESIZE_TO_MAX: Instruct CUDA to not reduce local memory + * after resizing local memory for a kernel. This can prevent thrashing by + * local memory allocations when launching many kernels with high local + * memory usage at the cost of potentially increased memory usage.
+ * Deprecated: This flag is deprecated and the behavior enabled + * by this flag is now the default and cannot be disabled. + * Instead, the per-thread stack size can be controlled with ::cuCtxSetLimit(). + * + * - ::CU_CTX_COREDUMP_ENABLE: If GPU coredumps have not been enabled globally + * with ::cuCoredumpSetAttributeGlobal or environment variables, this flag can + * be set during context creation to instruct CUDA to create a coredump if + * this context raises an exception during execution. These environment variables + * are described in the CUDA-GDB user guide under the "GPU core dump support" + * section. + * The initial attributes will be taken from the global attributes at the time of + * context creation. The other attributes that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * + * - ::CU_CTX_USER_COREDUMP_ENABLE: If user-triggered GPU coredumps have not + * been enabled globally with ::cuCoredumpSetAttributeGlobal or environment + * variables, this flag can be set during context creation to instruct CUDA to + * create a coredump if data is written to a certain pipe that is present in the + * OS space. These environment variables are described in the CUDA-GDB user + * guide under the "GPU core dump support" section. + * It is important to note that the pipe name *must* be set with + * ::cuCoredumpSetAttributeGlobal before creating the context if this flag is + * used. Setting this flag implies that ::CU_CTX_COREDUMP_ENABLE is set. + * The initial attributes will be taken from the global attributes at the time of + * context creation. The other attributes that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * Setting this flag on any context creation is equivalent to setting the + * ::CU_COREDUMP_ENABLE_USER_TRIGGER attribute to \p true globally. + * + * Context creation will fail with ::CUDA_ERROR_UNKNOWN if the compute mode of + * the device is ::CU_COMPUTEMODE_PROHIBITED. The function ::cuDeviceGetAttribute() + * can be used with ::CU_DEVICE_ATTRIBUTE_COMPUTE_MODE to determine the + * compute mode of the device. The nvidia-smi tool can be used to set + * the compute mode for * devices. + * Documentation for nvidia-smi can be obtained by passing a + * -h option to it. + * + * \param pctx - Returned context handle of the new context + * \param paramsArray - Execution affinity parameters + * \param numParams - Number of execution affinity parameters + * \param flags - Context creation flags + * \param dev - Device to create context on + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNSUPPORTED_EXEC_AFFINITY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cuCoredumpSetAttributeGlobal, + * ::cuCoredumpSetAttribute, + * ::CUexecAffinityParam + */ +CUresult CUDAAPI cuCtxCreate_v3(CUcontext *pctx, CUexecAffinityParam *paramsArray, int numParams, unsigned int flags, CUdevice dev); + +/** + * \brief Create a CUDA context + * + * Creates a new CUDA context and associates it with the calling thread. The + * \p flags parameter is described below. The context is created with a usage + * count of 1 and the caller of ::cuCtxCreate() must call ::cuCtxDestroy() + * when done using the context. If a context is already current to the thread, + * it is supplanted by the newly created context and may be restored by a subsequent + * call to ::cuCtxPopCurrent(). + * + * CUDA context can be created with execution affinity. The type and the amount of + execution resource the context can use is limited by \p paramsArray and \p numExecAffinityParams + in \p execAffinity. The \p paramsArray is an array of \p CUexecAffinityParam and the \p numExecAffinityParams + * describes the size of the paramsArray. If two \p CUexecAffinityParam in the array have the same type, + * the latter execution affinity parameter overrides the former execution affinity parameter. + * The supported execution affinity types are: + * - ::CU_EXEC_AFFINITY_TYPE_SM_COUNT limits the portion of SMs that the context can use. The portion + * of SMs is specified as the number of SMs via \p CUexecAffinitySmCount. This limit will be internally + * rounded up to the next hardware-supported amount. Hence, it is imperative to query the actual execution + * affinity of the context via \p cuCtxGetExecAffinity after context creation. Currently, this attribute + * is only supported under Volta+ MPS. + * + * CUDA context can be created in CIG(CUDA in Graphics) mode by setting /p cigParams. Hardware support + * and software support for graphics clients can be determined using ::cuDeviceGetAttribute() with + * ::CU_DEVICE_ATTRIBUTE_D3D12_CIG_SUPPORTED. Data from graphics client is shared with CUDA via + * the /p sharedData in /pcigParams. For D3D12, /p sharedData is a ID3D12CommandQueue handle. + * + * Either /p execAffinityParams or /p cigParams can be set to a non-null value. Setting both to a + * non-null value will result in an undefined behavior. + * + * The three LSBs of the \p flags parameter can be used to control how the OS + * thread, which owns the CUDA context at the time of an API call, interacts + * with the OS scheduler when waiting for results from the GPU. Only one of + * the scheduling flags can be set when creating a context. + * + * - ::CU_CTX_SCHED_SPIN: Instruct CUDA to actively spin when waiting for + * results from the GPU. This can decrease latency when waiting for the GPU, + * but may lower the performance of CPU threads if they are performing work in + * parallel with the CUDA thread. + * + * - ::CU_CTX_SCHED_YIELD: Instruct CUDA to yield its thread when waiting for + * results from the GPU. This can increase latency when waiting for the GPU, + * but can increase the performance of CPU threads performing work in parallel + * with the GPU. + * + * - ::CU_CTX_SCHED_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work. + * + * - ::CU_CTX_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work.
+ * Deprecated: This flag was deprecated as of CUDA 4.0 and was + * replaced with ::CU_CTX_SCHED_BLOCKING_SYNC. + * + * - ::CU_CTX_SCHED_AUTO: The default value if the \p flags parameter is zero, + * uses a heuristic based on the number of active CUDA contexts in the + * process \e C and the number of logical processors in the system \e P. If + * \e C > \e P, then CUDA will yield to other OS threads when waiting for + * the GPU (::CU_CTX_SCHED_YIELD), otherwise CUDA will not yield while + * waiting for results and actively spin on the processor (::CU_CTX_SCHED_SPIN). + * Additionally, on Tegra devices, ::CU_CTX_SCHED_AUTO uses a heuristic based on + * the power profile of the platform and may choose ::CU_CTX_SCHED_BLOCKING_SYNC + * for low-powered devices. + * + * - ::CU_CTX_MAP_HOST: Instruct CUDA to support mapped pinned allocations. + * This flag must be set in order to allocate pinned host memory that is + * accessible to the GPU. + * + * - ::CU_CTX_LMEM_RESIZE_TO_MAX: Instruct CUDA to not reduce local memory + * after resizing local memory for a kernel. This can prevent thrashing by + * local memory allocations when launching many kernels with high local + * memory usage at the cost of potentially increased memory usage.
+ * Deprecated: This flag is deprecated and the behavior enabled + * by this flag is now the default and cannot be disabled. + * Instead, the per-thread stack size can be controlled with ::cuCtxSetLimit(). + * + * - ::CU_CTX_COREDUMP_ENABLE: If GPU coredumps have not been enabled globally + * with ::cuCoredumpSetAttributeGlobal or environment variables, this flag can + * be set during context creation to instruct CUDA to create a coredump if + * this context raises an exception during execution. These environment variables + * are described in the CUDA-GDB user guide under the "GPU core dump support" + * section. + * The initial attributes will be taken from the global attributes at the time of + * context creation. The other attributes that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. This flag is not supported when CUDA context is created in + * CIG(CUDA in Graphics) mode. + * + * - ::CU_CTX_USER_COREDUMP_ENABLE: If user-triggered GPU coredumps have not + * been enabled globally with ::cuCoredumpSetAttributeGlobal or environment + * variables, this flag can be set during context creation to instruct CUDA to + * create a coredump if data is written to a certain pipe that is present in the + * OS space. These environment variables are described in the CUDA-GDB user + * guide under the "GPU core dump support" section. + * It is important to note that the pipe name *must* be set with + * ::cuCoredumpSetAttributeGlobal before creating the context if this flag is + * used. Setting this flag implies that ::CU_CTX_COREDUMP_ENABLE is set. + * The initial attributes will be taken from the global attributes at the time of + * context creation. The other attributes that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * Setting this flag on any context creation is equivalent to setting the + * ::CU_COREDUMP_ENABLE_USER_TRIGGER attribute to \p true globally. + * This flag is not supported when CUDA context is created in + * CIG(CUDA in Graphics) mode. + * + * - ::CU_CTX_SYNC_MEMOPS: Ensures that synchronous memory operations initiated + * on this context will always synchronize. See further documentation in the + * section titled "API Synchronization behavior" to learn more about cases when + * synchronous memory operations can exhibit asynchronous behavior. + * + * Context creation will fail with ::CUDA_ERROR_UNKNOWN if the compute mode of + * the device is ::CU_COMPUTEMODE_PROHIBITED. The function ::cuDeviceGetAttribute() + * can be used with ::CU_DEVICE_ATTRIBUTE_COMPUTE_MODE to determine the + * compute mode of the device. The nvidia-smi tool can be used to set + * the compute mode for * devices. + * Documentation for nvidia-smi can be obtained by passing a + * -h option to it. + * + * Context creation will fail with :: CUDA_ERROR_INVALID_VALUE if invalid parameter was + * passed by client to create the CUDA context. + * + * Context creation in CIG mode will fail with ::CUDA_ERROR_NOT_SUPPORTED if CIG is not supported + * by the device or the driver. + * + * \param pctx - Returned context handle of the new context + * \param ctxCreateParams - Context creation parameters + * \param flags - Context creation flags + * \param dev - Device to create context on + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCoredumpSetAttributeGlobal, + * ::cuCoredumpSetAttribute, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuCtxCreate_v4(CUcontext *pctx, CUctxCreateParams *ctxCreateParams, unsigned int flags, CUdevice dev); + +/** + * \brief Destroy a CUDA context + * + * Destroys the CUDA context specified by \p ctx. The context \p ctx will be + * destroyed regardless of how many threads it is current to. + * It is the responsibility of the calling function to ensure that no API + * call issues using \p ctx while ::cuCtxDestroy() is executing. + * + * Destroys and cleans up all resources associated with the context. + * It is the caller's responsibility to ensure that the context or its resources + * are not accessed or passed in subsequent API calls and doing so will result in undefined behavior. + * These resources include CUDA types ::CUmodule, ::CUfunction, ::CUstream, ::CUevent, + * ::CUarray, ::CUmipmappedArray, ::CUtexObject, ::CUsurfObject, ::CUtexref, ::CUsurfref, + * ::CUgraphicsResource, ::CUlinkState, ::CUexternalMemory and ::CUexternalSemaphore. + * These resources also include memory allocations by ::cuMemAlloc(), ::cuMemAllocHost(), + * ::cuMemAllocManaged() and ::cuMemAllocPitch(). + * + * If \p ctx is current to the calling thread then \p ctx will also be + * popped from the current thread's context stack (as though ::cuCtxPopCurrent() + * were called). If \p ctx is current to other threads, then \p ctx will + * remain current to those threads, and attempting to access \p ctx from + * those threads will result in the error ::CUDA_ERROR_CONTEXT_IS_DESTROYED. + * + * \note ::cuCtxDestroy() will not destroy memory allocations by ::cuMemCreate(), ::cuMemAllocAsync() and + * ::cuMemAllocFromPoolAsync(). These memory allocations are not associated with any CUDA context and need to + * be destroyed explicitly. + * + * \param ctx - Context to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuCtxDestroy(CUcontext ctx); + +/** + * \brief Pushes a context on the current CPU thread + * + * Pushes the given context \p ctx onto the CPU thread's stack of current + * contexts. The specified context becomes the CPU thread's current context, so + * all CUDA functions that operate on the current context are affected. + * + * The previous current context may be made current again by calling + * ::cuCtxDestroy() or ::cuCtxPopCurrent(). + * + * \param ctx - Context to push + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuCtxPushCurrent(CUcontext ctx); + +/** + * \brief Pops the current CUDA context from the current CPU thread. + * + * Pops the current CUDA context from the CPU thread and passes back the + * old context handle in \p *pctx. That context may then be made current + * to a different CPU thread by calling ::cuCtxPushCurrent(). + * + * If a context was current to the CPU thread before ::cuCtxCreate() or + * ::cuCtxPushCurrent() was called, this function makes that context current to + * the CPU thread again. + * + * \param pctx - Returned popped context handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuCtxPopCurrent(CUcontext *pctx); + +/** + * \brief Binds the specified CUDA context to the calling CPU thread + * + * Binds the specified CUDA context to the calling CPU thread. + * If \p ctx is NULL then the CUDA context previously bound to the + * calling CPU thread is unbound and ::CUDA_SUCCESS is returned. + * + * If there exists a CUDA context stack on the calling CPU thread, this + * will replace the top of that stack with \p ctx. + * If \p ctx is NULL then this will be equivalent to popping the top + * of the calling CPU thread's CUDA context stack (or a no-op if the + * calling CPU thread's CUDA context stack is empty). + * + * \param ctx - Context to bind to the calling CPU thread + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa + * ::cuCtxGetCurrent, + * ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cudaSetDevice + */ +CUresult CUDAAPI cuCtxSetCurrent(CUcontext ctx); + +/** + * \brief Returns the CUDA context bound to the calling CPU thread. + * + * Returns in \p *pctx the CUDA context bound to the calling CPU thread. + * If no context is bound to the calling CPU thread then \p *pctx is + * set to NULL and ::CUDA_SUCCESS is returned. + * + * \param pctx - Returned context handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * \notefnerr + * + * \sa + * ::cuCtxSetCurrent, + * ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cudaGetDevice + */ +CUresult CUDAAPI cuCtxGetCurrent(CUcontext *pctx); + +/** + * \brief Returns the device ID for the current context + * + * Returns in \p *device the ordinal of the current context's device. + * + * \param device - Returned device ID for the current context + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cudaGetDevice + */ +CUresult CUDAAPI cuCtxGetDevice(CUdevice *device); + +/** + * \brief Returns the flags for the current context + * + * Returns in \p *flags the flags of the current context. See ::cuCtxCreate + * for flag values. + * + * \param flags - Pointer to store flags of current context + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetCurrent, + * ::cuCtxGetDevice, + * ::cuCtxGetLimit, + * ::cuCtxGetSharedMemConfig, + * ::cuCtxGetStreamPriorityRange, + * ::cuCtxSetFlags, + * ::cudaGetDeviceFlags + */ +CUresult CUDAAPI cuCtxGetFlags(unsigned int *flags); + +/** + * \brief Sets the flags for the current context + * + * Sets the flags for the current context overwriting previously set ones. See + * ::cuDevicePrimaryCtxSetFlags for flag values. + * + * \param flags - Flags to set on the current context + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetCurrent, + * ::cuCtxGetDevice, + * ::cuCtxGetLimit, + * ::cuCtxGetSharedMemConfig, + * ::cuCtxGetStreamPriorityRange, + * ::cuCtxGetFlags, + * ::cudaGetDeviceFlags, + * ::cuDevicePrimaryCtxSetFlags, + */ +CUresult CUDAAPI cuCtxSetFlags(unsigned int flags); + +/** + * \brief Returns the unique Id associated with the context supplied + * + * Returns in \p ctxId the unique Id which is associated with a given context. + * The Id is unique for the life of the program for this instance of CUDA. + * If context is supplied as NULL and there is one current, the Id of the + * current context is returned. + * + * \param ctx - Context for which to obtain the Id + * \param ctxId - Pointer to store the Id of the context + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPushCurrent + */ +CUresult CUDAAPI cuCtxGetId(CUcontext ctx, unsigned long long *ctxId); + +/** + * \brief Block for the current context's tasks to complete + * + * Blocks until the current context has completed all preceding requested tasks. + * If the current context is the primary context, green contexts that have been + * created will also be synchronized. + * ::cuCtxSynchronize() returns an error if one of the preceding tasks failed. + * If the context was created with the ::CU_CTX_SCHED_BLOCKING_SYNC flag, the + * CPU thread will block until the GPU context has finished its work. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cudaDeviceSynchronize + */ +CUresult CUDAAPI cuCtxSynchronize(void); + +/** + * \brief Set resource limits + * + * Setting \p limit to \p value is a request by the application to update + * the current limit maintained by the context. The driver is free to + * modify the requested value to meet h/w requirements (this could be + * clamping to minimum or maximum values, rounding up to nearest element + * size, etc). The application can use ::cuCtxGetLimit() to find out exactly + * what the limit has been set to. + * + * Setting each ::CUlimit has its own specific restrictions, so each is + * discussed here. + * + * - ::CU_LIMIT_STACK_SIZE controls the stack size in bytes of each GPU thread. + * The driver automatically increases the per-thread stack size + * for each kernel launch as needed. This size isn't reset back to the + * original value after each launch. Setting this value will take effect + * immediately, and if necessary, the device will block until all preceding + * requested tasks are complete. + * + * - ::CU_LIMIT_PRINTF_FIFO_SIZE controls the size in bytes of the FIFO used + * by the ::printf() device system call. Setting ::CU_LIMIT_PRINTF_FIFO_SIZE + * must be performed before launching any kernel that uses the ::printf() + * device system call, otherwise ::CUDA_ERROR_INVALID_VALUE will be returned. + * + * - ::CU_LIMIT_MALLOC_HEAP_SIZE controls the size in bytes of the heap used + * by the ::malloc() and ::free() device system calls. Setting + * ::CU_LIMIT_MALLOC_HEAP_SIZE must be performed before launching any kernel + * that uses the ::malloc() or ::free() device system calls, otherwise + * ::CUDA_ERROR_INVALID_VALUE will be returned. + * + * - ::CU_LIMIT_DEV_RUNTIME_SYNC_DEPTH controls the maximum nesting depth of + * a grid at which a thread can safely call ::cudaDeviceSynchronize(). Setting + * this limit must be performed before any launch of a kernel that uses the + * device runtime and calls ::cudaDeviceSynchronize() above the default sync + * depth, two levels of grids. Calls to ::cudaDeviceSynchronize() will fail + * with error code ::cudaErrorSyncDepthExceeded if the limitation is + * violated. This limit can be set smaller than the default or up the maximum + * launch depth of 24. When setting this limit, keep in mind that additional + * levels of sync depth require the driver to reserve large amounts of device + * memory which can no longer be used for user allocations. If these + * reservations of device memory fail, ::cuCtxSetLimit() will return + * ::CUDA_ERROR_OUT_OF_MEMORY, and the limit can be reset to a lower value. + * This limit is only applicable to devices of compute capability < 9.0. + * Attempting to set this limit on devices of other compute capability + * versions will result in the error ::CUDA_ERROR_UNSUPPORTED_LIMIT being + * returned. + * + * - ::CU_LIMIT_DEV_RUNTIME_PENDING_LAUNCH_COUNT controls the maximum number of + * outstanding device runtime launches that can be made from the current + * context. A grid is outstanding from the point of launch up until the grid + * is known to have been completed. Device runtime launches which violate + * this limitation fail and return ::cudaErrorLaunchPendingCountExceeded when + * ::cudaGetLastError() is called after launch. If more pending launches than + * the default (2048 launches) are needed for a module using the device + * runtime, this limit can be increased. Keep in mind that being able to + * sustain additional pending launches will require the driver to reserve + * larger amounts of device memory upfront which can no longer be used for + * allocations. If these reservations fail, ::cuCtxSetLimit() will return + * ::CUDA_ERROR_OUT_OF_MEMORY, and the limit can be reset to a lower value. + * This limit is only applicable to devices of compute capability 3.5 and + * higher. Attempting to set this limit on devices of compute capability less + * than 3.5 will result in the error ::CUDA_ERROR_UNSUPPORTED_LIMIT being + * returned. + * + * - ::CU_LIMIT_MAX_L2_FETCH_GRANULARITY controls the L2 cache fetch granularity. + * Values can range from 0B to 128B. This is purely a performance hint and + * it can be ignored or clamped depending on the platform. + * + * - ::CU_LIMIT_PERSISTING_L2_CACHE_SIZE controls size in bytes available for + * persisting L2 cache. This is purely a performance hint and it can be + * ignored or clamped depending on the platform. + * + * \param limit - Limit to set + * \param value - Size of limit + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNSUPPORTED_LIMIT, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSynchronize, + * ::cudaDeviceSetLimit + */ +CUresult CUDAAPI cuCtxSetLimit(CUlimit limit, size_t value); + +/** + * \brief Returns resource limits + * + * Returns in \p *pvalue the current size of \p limit. The supported + * ::CUlimit values are: + * - ::CU_LIMIT_STACK_SIZE: stack size in bytes of each GPU thread. + * - ::CU_LIMIT_PRINTF_FIFO_SIZE: size in bytes of the FIFO used by the + * ::printf() device system call. + * - ::CU_LIMIT_MALLOC_HEAP_SIZE: size in bytes of the heap used by the + * ::malloc() and ::free() device system calls. + * - ::CU_LIMIT_DEV_RUNTIME_SYNC_DEPTH: maximum grid depth at which a thread + * can issue the device runtime call ::cudaDeviceSynchronize() to wait on + * child grid launches to complete. + * - ::CU_LIMIT_DEV_RUNTIME_PENDING_LAUNCH_COUNT: maximum number of outstanding + * device runtime launches that can be made from this context. + * - ::CU_LIMIT_MAX_L2_FETCH_GRANULARITY: L2 cache fetch granularity. + * - ::CU_LIMIT_PERSISTING_L2_CACHE_SIZE: Persisting L2 cache size in bytes + * + * \param limit - Limit to query + * \param pvalue - Returned size of limit + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNSUPPORTED_LIMIT + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cudaDeviceGetLimit + */ +CUresult CUDAAPI cuCtxGetLimit(size_t *pvalue, CUlimit limit); + +/** + * \brief Returns the preferred cache configuration for the current context. + * + * On devices where the L1 cache and shared memory use the same hardware + * resources, this function returns through \p pconfig the preferred cache configuration + * for the current context. This is only a preference. The driver will use + * the requested configuration if possible, but it is free to choose a different + * configuration if required to execute functions. + * + * This will return a \p pconfig of ::CU_FUNC_CACHE_PREFER_NONE on devices + * where the size of the L1 cache and shared memory are fixed. + * + * The supported cache configurations are: + * - ::CU_FUNC_CACHE_PREFER_NONE: no preference for shared memory or L1 (default) + * - ::CU_FUNC_CACHE_PREFER_SHARED: prefer larger shared memory and smaller L1 cache + * - ::CU_FUNC_CACHE_PREFER_L1: prefer larger L1 cache and smaller shared memory + * - ::CU_FUNC_CACHE_PREFER_EQUAL: prefer equal sized L1 cache and shared memory + * + * \param pconfig - Returned cache configuration + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cuFuncSetCacheConfig, + * ::cudaDeviceGetCacheConfig + */ +CUresult CUDAAPI cuCtxGetCacheConfig(CUfunc_cache *pconfig); + +/** + * \brief Sets the preferred cache configuration for the current context. + * + * On devices where the L1 cache and shared memory use the same hardware + * resources, this sets through \p config the preferred cache configuration for + * the current context. This is only a preference. The driver will use + * the requested configuration if possible, but it is free to choose a different + * configuration if required to execute the function. Any function preference + * set via ::cuFuncSetCacheConfig() or ::cuKernelSetCacheConfig() will be preferred over this context-wide + * setting. Setting the context-wide cache configuration to + * ::CU_FUNC_CACHE_PREFER_NONE will cause subsequent kernel launches to prefer + * to not change the cache configuration unless required to launch the kernel. + * + * This setting does nothing on devices where the size of the L1 cache and + * shared memory are fixed. + * + * Launching a kernel with a different preference than the most recent + * preference setting may insert a device-side synchronization point. + * + * The supported cache configurations are: + * - ::CU_FUNC_CACHE_PREFER_NONE: no preference for shared memory or L1 (default) + * - ::CU_FUNC_CACHE_PREFER_SHARED: prefer larger shared memory and smaller L1 cache + * - ::CU_FUNC_CACHE_PREFER_L1: prefer larger L1 cache and smaller shared memory + * - ::CU_FUNC_CACHE_PREFER_EQUAL: prefer equal sized L1 cache and shared memory + * + * \param config - Requested cache configuration + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cuFuncSetCacheConfig, + * ::cudaDeviceSetCacheConfig, + * ::cuKernelSetCacheConfig + */ +CUresult CUDAAPI cuCtxSetCacheConfig(CUfunc_cache config); + +/** + * \brief Gets the context's API version. + * + * Returns a version number in \p version corresponding to the capabilities of + * the context (e.g. 3010 or 3020), which library developers can use to direct + * callers to a specific API version. If \p ctx is NULL, returns the API version + * used to create the currently bound context. + * + * Note that new API versions are only introduced when context capabilities are + * changed that break binary compatibility, so the API version and driver version + * may be different. For example, it is valid for the API version to be 3020 while + * the driver version is 4020. + * + * \param ctx - Context to check + * \param version - Pointer to version + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuCtxGetApiVersion(CUcontext ctx, unsigned int *version); + +/** + * \brief Returns numerical values that correspond to the least and + * greatest stream priorities. + * + * Returns in \p *leastPriority and \p *greatestPriority the numerical values that correspond + * to the least and greatest stream priorities respectively. Stream priorities + * follow a convention where lower numbers imply greater priorities. The range of + * meaningful stream priorities is given by [\p *greatestPriority, \p *leastPriority]. + * If the user attempts to create a stream with a priority value that is + * outside the meaningful range as specified by this API, the priority is + * automatically clamped down or up to either \p *leastPriority or \p *greatestPriority + * respectively. See ::cuStreamCreateWithPriority for details on creating a + * priority stream. + * A NULL may be passed in for \p *leastPriority or \p *greatestPriority if the value + * is not desired. + * + * This function will return '0' in both \p *leastPriority and \p *greatestPriority if + * the current context's device does not support stream priorities + * (see ::cuDeviceGetAttribute). + * + * \param leastPriority - Pointer to an int in which the numerical value for least + * stream priority is returned + * \param greatestPriority - Pointer to an int in which the numerical value for greatest + * stream priority is returned + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa ::cuStreamCreateWithPriority, + * ::cuStreamGetPriority, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cudaDeviceGetStreamPriorityRange + */ +CUresult CUDAAPI cuCtxGetStreamPriorityRange(int *leastPriority, int *greatestPriority); + +/** + * \brief Resets all persisting lines in cache to normal status. + * + * ::cuCtxResetPersistingL2Cache Resets all persisting lines in cache to normal + * status. Takes effect on function return. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuCtxResetPersistingL2Cache(void); + +/** + * \brief Returns the execution affinity setting for the current context. + * + * Returns in \p *pExecAffinity the current value of \p type. The supported + * ::CUexecAffinityType values are: + * - ::CU_EXEC_AFFINITY_TYPE_SM_COUNT: number of SMs the context is limited to use. + * + * \param type - Execution affinity type to query + * \param pExecAffinity - Returned execution affinity + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNSUPPORTED_EXEC_AFFINITY + * \notefnerr + * + * \sa + * ::CUexecAffinityParam + */ +CUresult CUDAAPI cuCtxGetExecAffinity(CUexecAffinityParam *pExecAffinity, CUexecAffinityType type); + +/** + * \brief Records an event. + * + * Captures in \p hEvent all the activities of the context \p hCtx + * at the time of this call. \p hEvent and \p hCtx must be from the same + * CUDA context, otherwise ::CUDA_ERROR_INVALID_HANDLE will be returned. + * Calls such as ::cuEventQuery() or ::cuCtxWaitEvent() will then examine + * or wait for completion of the work that was captured. + * Uses of \p hCtx after this call do not modify \p hEvent. + * If the context passed to \p hCtx is the primary context, \p hEvent will + * capture all the activities of the primary context and its green contexts. + * If the context passed to \p hCtx is a context converted from green context + * via ::cuCtxFromGreenCtx(), \p hEvent will capture only the activities of the green context. + * + * \note The API will return ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED if the + * specified context \p hCtx has a stream in the capture mode. In such a case, + * the call will invalidate all the conflicting captures. + * + * \param hCtx - Context to record event for + * \param hEvent - Event to record + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED + * + * \sa + * ::cuCtxWaitEvent, + * ::cuGreenCtxRecordEvent, + * ::cuGreenCtxWaitEvent, + * ::cuEventRecord + */ +CUresult CUDAAPI cuCtxRecordEvent(CUcontext hCtx, CUevent hEvent); + +/** + * \brief Make a context wait on an event + * + * Makes all future work submitted to context \p hCtx wait for all work + * captured in \p hEvent. The synchronization will be performed on the device + * and will not block the calling CPU thread. See ::cuCtxRecordEvent() + * for details on what is captured by an event. + * If the context passed to \p hCtx is the primary context, the primary context + * and its green contexts will wait for \p hEvent. + * If the context passed to \p hCtx is a context converted from green context + * via ::cuCtxFromGreenCtx(), the green context will wait for \p hEvent. + * + * \note \p hEvent may be from a different context or device than \p hCtx. + * + * \note The API will return ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED and + * invalidate the capture if the specified event \p hEvent is part of an ongoing + * capture sequence or if the specified context \p hCtx has a stream in the capture mode. + * + * \param hCtx - Context to wait + * \param hEvent - Event to wait on + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED + * + * \sa + * ::cuCtxRecordEvent, + * ::cuGreenCtxRecordEvent, + * ::cuGreenCtxWaitEvent, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuCtxWaitEvent(CUcontext hCtx, CUevent hEvent); + +/** @} */ /* END CUDA_CTX */ + +/** + * \defgroup CUDA_CTX_DEPRECATED Context Management [DEPRECATED] + * + * ___MANBRIEF___ deprecated context management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the deprecated context management functions of the low-level + * CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Increment a context's usage-count + * + * \deprecated + * + * Note that this function is deprecated and should not be used. + * + * Increments the usage count of the context and passes back a context handle + * in \p *pctx that must be passed to ::cuCtxDetach() when the application is + * done with the context. ::cuCtxAttach() fails if there is no context current + * to the thread. + * + * Currently, the \p flags parameter must be 0. + * + * \param pctx - Returned context handle of the current context + * \param flags - Context attach flags (must be 0) + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxDetach, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuCtxAttach(CUcontext *pctx, unsigned int flags); + +/** + * \brief Decrement a context's usage-count + * + * \deprecated + * + * Note that this function is deprecated and should not be used. + * + * Decrements the usage count of the context \p ctx, and destroys the context + * if the usage count goes to 0. The context must be a handle that was passed + * back by ::cuCtxCreate() or ::cuCtxAttach(), and must be current to the + * calling thread. + * + * \param ctx - Context to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuCtxDetach(CUcontext ctx); + + +/** + * \brief Returns the current shared memory configuration for the current context. + * + * \deprecated + * + * This function will return in \p pConfig the current size of shared memory banks + * in the current context. On devices with configurable shared memory banks, + * ::cuCtxSetSharedMemConfig can be used to change this setting, so that all + * subsequent kernel launches will by default use the new bank size. When + * ::cuCtxGetSharedMemConfig is called on devices without configurable shared + * memory, it will return the fixed bank size of the hardware. + * + * The returned bank configurations can be either: + * - ::CU_SHARED_MEM_CONFIG_FOUR_BYTE_BANK_SIZE: shared memory bank width is + * four bytes. + * - ::CU_SHARED_MEM_CONFIG_EIGHT_BYTE_BANK_SIZE: shared memory bank width will + * eight bytes. + * + * \param pConfig - returned shared memory configuration + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cuCtxGetSharedMemConfig, + * ::cuFuncSetCacheConfig, + * ::cudaDeviceGetSharedMemConfig + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuCtxGetSharedMemConfig(CUsharedconfig *pConfig); + +/** + * \brief Sets the shared memory configuration for the current context. + * + * \deprecated + * + * On devices with configurable shared memory banks, this function will set + * the context's shared memory bank size which is used for subsequent kernel + * launches. + * + * Changed the shared memory configuration between launches may insert a device + * side synchronization point between those launches. + * + * Changing the shared memory bank size will not increase shared memory usage + * or affect occupancy of kernels, but may have major effects on performance. + * Larger bank sizes will allow for greater potential bandwidth to shared memory, + * but will change what kinds of accesses to shared memory will result in bank + * conflicts. + * + * This function will do nothing on devices with fixed shared memory bank size. + * + * The supported bank configurations are: + * - ::CU_SHARED_MEM_CONFIG_DEFAULT_BANK_SIZE: set bank width to the default initial + * setting (currently, four bytes). + * - ::CU_SHARED_MEM_CONFIG_FOUR_BYTE_BANK_SIZE: set shared memory bank width to + * be natively four bytes. + * - ::CU_SHARED_MEM_CONFIG_EIGHT_BYTE_BANK_SIZE: set shared memory bank width to + * be natively eight bytes. + * + * \param config - requested shared memory configuration + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cuCtxGetSharedMemConfig, + * ::cuFuncSetCacheConfig, + * ::cudaDeviceSetSharedMemConfig + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuCtxSetSharedMemConfig(CUsharedconfig config); + +/** @} */ /* END CUDA_CTX_DEPRECATED */ + + +/** + * \defgroup CUDA_MODULE Module Management + * + * ___MANBRIEF___ module management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the module management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Loads a compute module + * + * Takes a filename \p fname and loads the corresponding module \p module into + * the current context. The CUDA driver API does not attempt to lazily + * allocate the resources needed by a module; if the memory for functions and + * data (constant and global) needed by the module cannot be allocated, + * ::cuModuleLoad() fails. The file should be a \e cubin file as output by + * \b nvcc, or a \e PTX file either as output by \b nvcc or handwritten, or + * a \e fatbin file as output by \b nvcc from toolchain 4.0 or later. + * + * \param module - Returned module + * \param fname - Filename of module to load + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_NOT_FOUND, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_FILE_NOT_FOUND, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU, + * ::CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND + * \notefnerr + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload + */ +CUresult CUDAAPI cuModuleLoad(CUmodule *module, const char *fname); + +/** + * \brief Load a module's data + * + * Takes a pointer \p image and loads the corresponding module \p module into + * the current context. The \p image may be a \e cubin or \e fatbin + * as output by \b nvcc, or a NULL-terminated \e PTX, either as output by \b nvcc + * or hand-written. + * + * \param module - Returned module + * \param image - Module data to load + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU, + * ::CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND + * \notefnerr + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload + */ +CUresult CUDAAPI cuModuleLoadData(CUmodule *module, const void *image); + +/** + * \brief Load a module's data with options + * + * Takes a pointer \p image and loads the corresponding module \p module into + * the current context. The \p image may be a \e cubin or \e fatbin + * as output by \b nvcc, or a NULL-terminated \e PTX, either as output by \b nvcc + * or hand-written. + * + * \param module - Returned module + * \param image - Module data to load + * \param numOptions - Number of options + * \param options - Options for JIT + * \param optionValues - Option values for JIT + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU, + * ::CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND + * \notefnerr + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload + */ +CUresult CUDAAPI cuModuleLoadDataEx(CUmodule *module, const void *image, unsigned int numOptions, CUjit_option *options, void **optionValues); + +/** + * \brief Load a module's data + * + * Takes a pointer \p fatCubin and loads the corresponding module \p module + * into the current context. The pointer represents a fat binary object, + * which is a collection of different \e cubin and/or \e PTX files, all + * representing the same device code, but compiled and optimized for different + * architectures. + * + * Prior to CUDA 4.0, there was no documented API for constructing and using + * fat binary objects by programmers. Starting with CUDA 4.0, fat binary + * objects can be constructed by providing the -fatbin option to \b nvcc. + * More information can be found in the \b nvcc document. + * + * \param module - Returned module + * \param fatCubin - Fat binary to load + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_NOT_FOUND, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU, + * ::CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND + * \notefnerr + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleUnload + */ +CUresult CUDAAPI cuModuleLoadFatBinary(CUmodule *module, const void *fatCubin); + +/** + * \brief Unloads a module + * + * Unloads a module \p hmod from the current context. Attempting to unload + * a module which was obtained from the Library Management API such as + * ::cuLibraryGetModule will return ::CUDA_ERROR_NOT_PERMITTED. + * + * \param hmod - Module to unload + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_PERMITTED + * \notefnerr + * \note_destroy_ub + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary + */ +CUresult CUDAAPI cuModuleUnload(CUmodule hmod); + +/** + * CUDA Lazy Loading status + */ +typedef enum CUmoduleLoadingMode_enum { + CU_MODULE_EAGER_LOADING = 0x1, /**< Lazy Kernel Loading is not enabled */ + CU_MODULE_LAZY_LOADING = 0x2, /**< Lazy Kernel Loading is enabled */ +} CUmoduleLoadingMode; + +/** + * \brief Query lazy loading mode + * + * Returns lazy loading mode + * Module loading mode is controlled by CUDA_MODULE_LOADING env variable + * + * \param mode - Returns the lazy loading mode + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa + * ::cuModuleLoad, + */ +CUresult CUDAAPI cuModuleGetLoadingMode(CUmoduleLoadingMode *mode); + +/** + * \brief Returns a function handle + * + * Returns in \p *hfunc the handle of the function of name \p name located in + * module \p hmod. If no function of that name exists, ::cuModuleGetFunction() + * returns ::CUDA_ERROR_NOT_FOUND. + * + * \param hfunc - Returned function handle + * \param hmod - Module to retrieve function from + * \param name - Name of function to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_FOUND + * \notefnerr + * + * \sa ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload + */ +CUresult CUDAAPI cuModuleGetFunction(CUfunction *hfunc, CUmodule hmod, const char *name); + +/** + * \brief Returns the number of functions within a module + * + * Returns in \p count the number of functions in \p mod. + * + * \param count - Number of functions found within the module + * \param mod - Module to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + */ +CUresult CUDAAPI cuModuleGetFunctionCount(unsigned int *count, CUmodule mod); + +/** + * \brief Returns the function handles within a module. + * + * Returns in \p functions a maximum number of \p numFunctions function handles within \p mod. When + * function loading mode is set to LAZY the function retrieved may be partially loaded. The loading + * state of a function can be queried using ::cuFunctionIsLoaded. CUDA APIs may load the function + * automatically when called with partially loaded function handle which may incur additional + * latency. Alternatively, ::cuFunctionLoad can be used to explicitly load a function. The returned + * function handles become invalid when the module is unloaded. + * + * \param functions - Buffer where the function handles are returned to + * \param numFunctions - Maximum number of function handles may be returned to the buffer + * \param mod - Module to query from + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetFunctionCount, + * ::cuFuncIsLoaded, + * ::cuFuncLoad + */ +CUresult CUDAAPI cuModuleEnumerateFunctions(CUfunction *functions, unsigned int numFunctions, CUmodule mod); + +/** + * \brief Returns a global pointer from a module + * + * Returns in \p *dptr and \p *bytes the base pointer and size of the + * global of name \p name located in module \p hmod. If no variable of that name + * exists, ::cuModuleGetGlobal() returns ::CUDA_ERROR_NOT_FOUND. + * One of the parameters \p dptr or \p bytes (not both) can be NULL in which + * case it is ignored. + * + * \param dptr - Returned global device pointer + * \param bytes - Returned global size in bytes + * \param hmod - Module to retrieve global from + * \param name - Name of global to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_FOUND + * \notefnerr + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload, + * ::cudaGetSymbolAddress, + * ::cudaGetSymbolSize + */ +CUresult CUDAAPI cuModuleGetGlobal(CUdeviceptr *dptr, size_t *bytes, CUmodule hmod, const char *name); + +/** + * \brief Creates a pending JIT linker invocation. + * + * If the call is successful, the caller owns the returned CUlinkState, which + * should eventually be destroyed with ::cuLinkDestroy. The + * device code machine size (32 or 64 bit) will match the calling application. + * + * Both linker and compiler options may be specified. Compiler options will + * be applied to inputs to this linker action which must be compiled from PTX. + * The options ::CU_JIT_WALL_TIME, + * ::CU_JIT_INFO_LOG_BUFFER_SIZE_BYTES, and ::CU_JIT_ERROR_LOG_BUFFER_SIZE_BYTES + * will accumulate data until the CUlinkState is destroyed. + * + * The data passed in via ::cuLinkAddData and ::cuLinkAddFile will be treated + * as relocatable (-rdc=true to nvcc) when linking the final cubin during + * ::cuLinkComplete and will have similar consequences as offline relocatable + * device code linking. + * + * \p optionValues must remain valid for the life of the CUlinkState if output + * options are used. No other references to inputs are maintained after this + * call returns. + * + * \note For LTO-IR input, only LTO-IR compiled with toolkits prior to CUDA 12.0 will be accepted + * + * \param numOptions Size of options arrays + * \param options Array of linker and compiler options + * \param optionValues Array of option values, each cast to void * + * \param stateOut On success, this will contain a CUlinkState to specify + * and complete this action + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND + * \notefnerr + * + * \sa ::cuLinkAddData, + * ::cuLinkAddFile, + * ::cuLinkComplete, + * ::cuLinkDestroy + */ +CUresult CUDAAPI +cuLinkCreate(unsigned int numOptions, CUjit_option *options, void **optionValues, CUlinkState *stateOut); + +/** + * \brief Add an input to a pending linker invocation + * + * Ownership of \p data is retained by the caller. No reference is retained to any + * inputs after this call returns. + * + * This method accepts only compiler options, which are used if the data must + * be compiled from PTX, and does not accept any of + * ::CU_JIT_WALL_TIME, ::CU_JIT_INFO_LOG_BUFFER, ::CU_JIT_ERROR_LOG_BUFFER, + * ::CU_JIT_TARGET_FROM_CUCONTEXT, or ::CU_JIT_TARGET. + * + * \note For LTO-IR input, only LTO-IR compiled with toolkits prior to CUDA 12.0 will be accepted + * + * \param state A pending linker action. + * \param type The type of the input data. + * \param data The input data. PTX must be NULL-terminated. + * \param size The length of the input data. + * \param name An optional name for this input in log messages. + * \param numOptions Size of options. + * \param options Options to be applied only for this input (overrides options from ::cuLinkCreate). + * \param optionValues Array of option values, each cast to void *. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_IMAGE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU + * + * \sa ::cuLinkCreate, + * ::cuLinkAddFile, + * ::cuLinkComplete, + * ::cuLinkDestroy + */ +CUresult CUDAAPI +cuLinkAddData(CUlinkState state, CUjitInputType type, void *data, size_t size, const char *name, + unsigned int numOptions, CUjit_option *options, void **optionValues); + +/** + * \brief Add a file input to a pending linker invocation + * + * No reference is retained to any inputs after this call returns. + * + * This method accepts only compiler options, which are used if the input + * must be compiled from PTX, and does not accept any of + * ::CU_JIT_WALL_TIME, ::CU_JIT_INFO_LOG_BUFFER, ::CU_JIT_ERROR_LOG_BUFFER, + * ::CU_JIT_TARGET_FROM_CUCONTEXT, or ::CU_JIT_TARGET. + * + * This method is equivalent to invoking ::cuLinkAddData on the contents + * of the file. + * + * \note For LTO-IR input, only LTO-IR compiled with toolkits prior to CUDA 12.0 will be accepted + * + * \param state A pending linker action + * \param type The type of the input data + * \param path Path to the input file + * \param numOptions Size of options + * \param options Options to be applied only for this input (overrides options from ::cuLinkCreate) + * \param optionValues Array of option values, each cast to void * + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_FILE_NOT_FOUND + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_IMAGE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU + * + * \sa ::cuLinkCreate, + * ::cuLinkAddData, + * ::cuLinkComplete, + * ::cuLinkDestroy + */ +CUresult CUDAAPI +cuLinkAddFile(CUlinkState state, CUjitInputType type, const char *path, + unsigned int numOptions, CUjit_option *options, void **optionValues); + +/** + * \brief Complete a pending linker invocation + * + * Completes the pending linker action and returns the cubin image for the linked + * device code, which can be used with ::cuModuleLoadData. The cubin is owned by + * \p state, so it should be loaded before \p state is destroyed via ::cuLinkDestroy. + * This call does not destroy \p state. + * + * \param state A pending linker invocation + * \param cubinOut On success, this will point to the output image + * \param sizeOut Optional parameter to receive the size of the generated image + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuLinkCreate, + * ::cuLinkAddData, + * ::cuLinkAddFile, + * ::cuLinkDestroy, + * ::cuModuleLoadData + */ +CUresult CUDAAPI +cuLinkComplete(CUlinkState state, void **cubinOut, size_t *sizeOut); + +/** + * \brief Destroys state for a JIT linker invocation. + * + * \param state State object for the linker invocation + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE + * + * \sa ::cuLinkCreate + */ +CUresult CUDAAPI +cuLinkDestroy(CUlinkState state); + +/** @} */ /* END CUDA_MODULE */ + +/** + * \defgroup CUDA_MODULE_DEPRECATED Module Management [DEPRECATED] + * + * ___MANBRIEF___ deprecated module management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the deprecated module management functions of the low-level + * CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns a handle to a texture reference + * + * \deprecated + * + * Returns in \p *pTexRef the handle of the texture reference of name \p name + * in the module \p hmod. If no texture reference of that name exists, + * ::cuModuleGetTexRef() returns ::CUDA_ERROR_NOT_FOUND. This texture reference + * handle should not be destroyed, since it will be destroyed when the module + * is unloaded. + * + * \param pTexRef - Returned texture reference + * \param hmod - Module to retrieve texture reference from + * \param name - Name of texture reference to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_FOUND + * \notefnerr + * + * \sa + * ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetSurfRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuModuleGetTexRef(CUtexref *pTexRef, CUmodule hmod, const char *name); + +/** + * \brief Returns a handle to a surface reference + * + * \deprecated + * + * Returns in \p *pSurfRef the handle of the surface reference of name \p name + * in the module \p hmod. If no surface reference of that name exists, + * ::cuModuleGetSurfRef() returns ::CUDA_ERROR_NOT_FOUND. + * + * \param pSurfRef - Returned surface reference + * \param hmod - Module to retrieve surface reference from + * \param name - Name of surface reference to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_FOUND + * \notefnerr + * + * \sa + * ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuModuleGetSurfRef(CUsurfref *pSurfRef, CUmodule hmod, const char *name); + +/** @} */ /* END CUDA_MODULE_DEPRECATED */ + +/** + * \defgroup CUDA_LIBRARY Library Management + * + * ___MANBRIEF___ library management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the library management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Load a library with specified code and options + * + * Takes a pointer \p code and loads the corresponding library \p library based on + * the application defined library loading mode: + * - If module loading is set to EAGER, via the environment variables described in "Module loading", + * \p library is loaded eagerly into all contexts at the time of the call and future contexts + * at the time of creation until the library is unloaded with ::cuLibraryUnload(). + * - If the environment variables are set to LAZY, \p library + * is not immediately loaded onto all existent contexts and will only be + * loaded when a function is needed for that context, such as a kernel launch. + * + * These environment variables are described in the CUDA programming guide under the + * "CUDA environment variables" section. + * + * The \p code may be a \e cubin or \e fatbin as output by \b nvcc, + * or a NULL-terminated \e PTX, either as output by \b nvcc or hand-written. + * A fatbin should also contain relocatable code when doing separate compilation. + * + * Options are passed as an array via \p jitOptions and any corresponding parameters are passed in + * \p jitOptionsValues. The number of total JIT options is supplied via \p numJitOptions. + * Any outputs will be returned via \p jitOptionsValues. + * + * Library load options are passed as an array via \p libraryOptions and any corresponding parameters are passed in + * \p libraryOptionValues. The number of total library load options is supplied via \p numLibraryOptions. + * + * \note If the library contains managed variables and no device in the system + * supports managed variables this call is expected to return ::CUDA_ERROR_NOT_SUPPORTED + * + * \param library - Returned library + * \param code - Code to load + * \param jitOptions - Options for JIT + * \param jitOptionsValues - Option values for JIT + * \param numJitOptions - Number of options + * \param libraryOptions - Options for loading + * \param libraryOptionValues - Option values for loading + * \param numLibraryOptions - Number of options for loading + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU, + * ::CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND, + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx + */ +CUresult CUDAAPI cuLibraryLoadData(CUlibrary *library, const void *code, + CUjit_option *jitOptions, void **jitOptionsValues, unsigned int numJitOptions, + CUlibraryOption *libraryOptions, void** libraryOptionValues, unsigned int numLibraryOptions); + +/** + * \brief Load a library with specified file and options + * + * Takes a pointer \p code and loads the corresponding library \p library based on + * the application defined library loading mode: + * - If module loading is set to EAGER, via the environment variables described in "Module loading", + * \p library is loaded eagerly into all contexts at the time of the call and future contexts + * at the time of creation until the library is unloaded with ::cuLibraryUnload(). + * - If the environment variables are set to LAZY, \p library + * is not immediately loaded onto all existent contexts and will only be + * loaded when a function is needed for that context, such as a kernel launch. + * + * These environment variables are described in the CUDA programming guide under the + * "CUDA environment variables" section. + * + * The file should be a \e cubin file as output by \b nvcc, or a \e PTX file either + * as output by \b nvcc or handwritten, or a \e fatbin file as output by \b nvcc. + * A fatbin should also contain relocatable code when doing separate compilation. + * + * Options are passed as an array via \p jitOptions and any corresponding parameters are + * passed in \p jitOptionsValues. The number of total options is supplied via \p numJitOptions. + * Any outputs will be returned via \p jitOptionsValues. + * + * Library load options are passed as an array via \p libraryOptions and any corresponding parameters are passed in + * \p libraryOptionValues. The number of total library load options is supplied via \p numLibraryOptions. + * + * \note If the library contains managed variables and no device in the system + * supports managed variables this call is expected to return ::CUDA_ERROR_NOT_SUPPORTED + * + * \param library - Returned library + * \param fileName - File to load from + * \param jitOptions - Options for JIT + * \param jitOptionsValues - Option values for JIT + * \param numJitOptions - Number of options + * \param libraryOptions - Options for loading + * \param libraryOptionValues - Option values for loading + * \param numLibraryOptions - Number of options for loading + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU, + * ::CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND, + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryUnload, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx + */ +CUresult CUDAAPI cuLibraryLoadFromFile(CUlibrary *library, const char *fileName, + CUjit_option *jitOptions, void **jitOptionsValues, unsigned int numJitOptions, + CUlibraryOption *libraryOptions, void **libraryOptionValues, unsigned int numLibraryOptions); + +/** + * \brief Unloads a library + * + * Unloads the library specified with \p library + * + * \param library - Library to unload + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuModuleUnload + */ +CUresult CUDAAPI cuLibraryUnload(CUlibrary library); + +/** + * \brief Returns a kernel handle + * + * Returns in \p pKernel the handle of the kernel with name \p name located in library \p library. + * If kernel handle is not found, the call returns ::CUDA_ERROR_NOT_FOUND. + * + * \param pKernel - Returned kernel handle + * \param library - Library to retrieve kernel from + * \param name - Name of kernel to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuKernelGetFunction, + * ::cuLibraryGetModule, + * ::cuModuleGetFunction + */ +CUresult CUDAAPI cuLibraryGetKernel(CUkernel *pKernel, CUlibrary library, const char *name); + +/** + * \brief Returns the number of kernels within a library + * + * Returns in \p count the number of kernels in \p lib. + * + * \param count - Number of kernels found within the library + * \param lib - Library to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + */ +CUresult CUDAAPI cuLibraryGetKernelCount(unsigned int *count, CUlibrary lib); + +/** + * \brief Retrieve the kernel handles within a library. + * + * Returns in \p kernels a maximum number of \p numKernels kernel handles within \p lib. + * The returned kernel handle becomes invalid when the library is unloaded. + * + * \param kernels - Buffer where the kernel handles are returned to + * \param numKernels - Maximum number of kernel handles may be returned to the buffer + * \param lib - Library to query from + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuLibraryGetKernelCount + */ +CUresult CUDAAPI cuLibraryEnumerateKernels(CUkernel *kernels, unsigned int numKernels, CUlibrary lib); + +/** + * \brief Returns a module handle + * + * Returns in \p pMod the module handle associated with the current context located in + * library \p library. If module handle is not found, the call returns ::CUDA_ERROR_NOT_FOUND. + * + * \param pMod - Returned module handle + * \param library - Library to retrieve module from + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuModuleGetFunction + */ +CUresult CUDAAPI cuLibraryGetModule(CUmodule *pMod, CUlibrary library); + +/** + * \brief Returns a function handle + * + * Returns in \p pFunc the handle of the function for the requested kernel \p kernel and + * the current context. If function handle is not found, the call returns ::CUDA_ERROR_NOT_FOUND. + * + * \param pFunc - Returned function handle + * \param kernel - Kernel to retrieve function for the requested context + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuLibraryGetKernel, + * ::cuLibraryGetModule, + * ::cuModuleGetFunction + */ +CUresult CUDAAPI cuKernelGetFunction(CUfunction *pFunc, CUkernel kernel); + +/** + * \brief Returns a library handle + * + * Returns in \p pLib the handle of the library for the requested kernel \p kernel + * + * \param pLib - Returned library handle + * \param kernel - Kernel to retrieve library handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuLibraryGetKernel + */ +CUresult CUDAAPI cuKernelGetLibrary(CUlibrary *pLib, CUkernel kernel); + +/** + * \brief Returns a global device pointer + * + * Returns in \p *dptr and \p *bytes the base pointer and size of the global with + * name \p name for the requested library \p library and the current context. + * If no global for the requested name \p name exists, the call returns ::CUDA_ERROR_NOT_FOUND. + * One of the parameters \p dptr or \p bytes (not both) can be NULL in which + * case it is ignored. + * + * \param dptr - Returned global device pointer for the requested context + * \param bytes - Returned global size in bytes + * \param library - Library to retrieve global from + * \param name - Name of global to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuLibraryGetModule, + * cuModuleGetGlobal + */ +CUresult CUDAAPI cuLibraryGetGlobal(CUdeviceptr *dptr, size_t *bytes, CUlibrary library, const char *name); + +/** + * \brief Returns a pointer to managed memory + * + * Returns in \p *dptr and \p *bytes the base pointer and size of the managed memory with + * name \p name for the requested library \p library. If no managed memory with the + * requested name \p name exists, the call returns ::CUDA_ERROR_NOT_FOUND. One of the parameters + * \p dptr or \p bytes (not both) can be NULL in which case it is ignored. + * Note that managed memory for library \p library is shared across devices and is registered + * when the library is loaded into atleast one context. + * + * \param dptr - Returned pointer to the managed memory + * \param bytes - Returned memory size in bytes + * \param library - Library to retrieve managed memory from + * \param name - Name of managed memory to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload + */ +CUresult CUDAAPI cuLibraryGetManaged(CUdeviceptr *dptr, size_t *bytes, CUlibrary library, const char *name); + +/** + * \brief Returns a pointer to a unified function + * + * Returns in \p *fptr the function pointer to a unified function denoted by \p symbol. + * If no unified function with name \p symbol exists, the call returns ::CUDA_ERROR_NOT_FOUND. + * If there is no device with attribute ::CU_DEVICE_ATTRIBUTE_UNIFIED_FUNCTION_POINTERS present in the system, + * the call may return ::CUDA_ERROR_NOT_FOUND. + * + * \param fptr - Returned pointer to a unified function + * \param library - Library to retrieve function pointer memory from + * \param symbol - Name of function pointer to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload + */ +CUresult CUDAAPI cuLibraryGetUnifiedFunction(void **fptr, CUlibrary library, const char *symbol); + +/** + * \brief Returns information about a kernel + * + * Returns in \p *pi the integer value of the attribute \p attrib for the kernel + * \p kernel for the requested device \p dev. The supported attributes are: + * - ::CU_FUNC_ATTRIBUTE_MAX_THREADS_PER_BLOCK: The maximum number of threads + * per block, beyond which a launch of the kernel would fail. This number + * depends on both the kernel and the requested device. + * - ::CU_FUNC_ATTRIBUTE_SHARED_SIZE_BYTES: The size in bytes of + * statically-allocated shared memory per block required by this kernel. + * This does not include dynamically-allocated shared memory requested by + * the user at runtime. + * - ::CU_FUNC_ATTRIBUTE_CONST_SIZE_BYTES: The size in bytes of user-allocated + * constant memory required by this kernel. + * - ::CU_FUNC_ATTRIBUTE_LOCAL_SIZE_BYTES: The size in bytes of local memory + * used by each thread of this kernel. + * - ::CU_FUNC_ATTRIBUTE_NUM_REGS: The number of registers used by each thread + * of this kernel. + * - ::CU_FUNC_ATTRIBUTE_PTX_VERSION: The PTX virtual architecture version for + * which the kernel was compiled. This value is the major PTX version * 10 + * + the minor PTX version, so a PTX version 1.3 function would return the + * value 13. Note that this may return the undefined value of 0 for cubins + * compiled prior to CUDA 3.0. + * - ::CU_FUNC_ATTRIBUTE_BINARY_VERSION: The binary architecture version for + * which the kernel was compiled. This value is the major binary + * version * 10 + the minor binary version, so a binary version 1.3 function + * would return the value 13. Note that this will return a value of 10 for + * legacy cubins that do not have a properly-encoded binary architecture + * version. + * - ::CU_FUNC_CACHE_MODE_CA: The attribute to indicate whether the kernel has + * been compiled with user specified option "-Xptxas --dlcm=ca" set. + * - ::CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES: The maximum size in bytes of + * dynamically-allocated shared memory. + * - ::CU_FUNC_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT: Preferred shared memory-L1 + * cache split ratio in percent of total shared memory. + * - ::CU_FUNC_ATTRIBUTE_CLUSTER_SIZE_MUST_BE_SET: If this attribute is set, the + * kernel must launch with a valid cluster size specified. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_WIDTH: The required cluster width in + * blocks. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_HEIGHT: The required cluster height in + * blocks. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_DEPTH: The required cluster depth in + * blocks. + * - ::CU_FUNC_ATTRIBUTE_NON_PORTABLE_CLUSTER_SIZE_ALLOWED: Indicates whether + * the function can be launched with non-portable cluster size. 1 is allowed, + * 0 is disallowed. A non-portable cluster size may only function on the + * specific SKUs the program is tested on. The launch might fail if the + * program is run on a different hardware platform. CUDA API provides + * cudaOccupancyMaxActiveClusters to assist with checking whether the desired + * size can be launched on the current device. A portable cluster size is + * guaranteed to be functional on all compute capabilities higher than the + * target compute capability. The portable cluster size for sm_90 is 8 blocks + * per cluster. This value may increase for future compute capabilities. The + * specific hardware unit may support higher cluster sizes that’s not + * guaranteed to be portable. + * - ::CU_FUNC_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE: The block + * scheduling policy of a function. The value type is CUclusterSchedulingPolicy. + * + * \note If another thread is trying to set the same attribute on the same device using + * ::cuKernelSetAttribute() simultaneously, the attribute query will give the old or new + * value depending on the interleavings chosen by the OS scheduler and memory consistency. + * + * \param pi - Returned attribute value + * \param attrib - Attribute requested + * \param kernel - Kernel to query attribute of + * \param dev - Device to query attribute of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuKernelSetAttribute, + * ::cuLibraryGetKernel, + * ::cuLaunchKernel, + * ::cuKernelGetFunction, + * ::cuLibraryGetModule, + * ::cuModuleGetFunction, + * ::cuFuncGetAttribute + */ +CUresult CUDAAPI cuKernelGetAttribute(int *pi, CUfunction_attribute attrib, CUkernel kernel, CUdevice dev); + +/** + * \brief Sets information about a kernel + * + * This call sets the value of a specified attribute \p attrib on the kernel \p kernel + * for the requested device \p dev to an integer value specified by \p val. + * This function returns CUDA_SUCCESS if the new value of the attribute could be + * successfully set. If the set fails, this call will return an error. + * Not all attributes can have values set. Attempting to set a value on a read-only + * attribute will result in an error (CUDA_ERROR_INVALID_VALUE) + * + * Note that attributes set using ::cuFuncSetAttribute() will override the attribute + * set by this API irrespective of whether the call to ::cuFuncSetAttribute() is made + * before or after this API call. However, ::cuKernelGetAttribute() will always + * return the attribute value set by this API. + * + * Supported attributes are: + * - ::CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES: This is the maximum size in bytes of + * dynamically-allocated shared memory. The value should contain the requested + * maximum size of dynamically-allocated shared memory. The sum of this value and + * the function attribute ::CU_FUNC_ATTRIBUTE_SHARED_SIZE_BYTES cannot exceed the + * device attribute ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK_OPTIN. + * The maximal size of requestable dynamic shared memory may differ by GPU + * architecture. + * - ::CU_FUNC_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT: On devices where the L1 + * cache and shared memory use the same hardware resources, this sets the shared memory + * carveout preference, in percent of the total shared memory. + * See ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_MULTIPROCESSOR + * This is only a hint, and the driver can choose a different ratio if required to execute the function. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_WIDTH: The required cluster width in + * blocks. The width, height, and depth values must either all be 0 or all be + * positive. The validity of the cluster dimensions is checked at launch time. + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_HEIGHT: The required cluster height in + * blocks. The width, height, and depth values must either all be 0 or all be + * positive. The validity of the cluster dimensions is checked at launch time. + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_DEPTH: The required cluster depth in + * blocks. The width, height, and depth values must either all be 0 or all be + * positive. The validity of the cluster dimensions is checked at launch time. + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * - ::CU_FUNC_ATTRIBUTE_NON_PORTABLE_CLUSTER_SIZE_ALLOWED: Indicates whether + * the function can be launched with non-portable cluster size. 1 is allowed, + * 0 is disallowed. + * - ::CU_FUNC_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE: The block + * scheduling policy of a function. The value type is CUclusterSchedulingPolicy. + * + * \note The API has stricter locking requirements in comparison to its legacy counterpart + * ::cuFuncSetAttribute() due to device-wide semantics. If multiple threads are trying to + * set the same attribute on the same device simultaneously, the attribute setting will depend + * on the interleavings chosen by the OS scheduler and memory consistency. + * + * \param attrib - Attribute requested + * \param val - Value to set + * \param kernel - Kernel to set attribute of + * \param dev - Device to set attribute of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuKernelGetAttribute, + * ::cuLibraryGetKernel, + * ::cuLaunchKernel, + * ::cuKernelGetFunction, + * ::cuLibraryGetModule, + * ::cuModuleGetFunction, + * ::cuFuncSetAttribute + */ +CUresult CUDAAPI cuKernelSetAttribute(CUfunction_attribute attrib, int val, CUkernel kernel, CUdevice dev); + +/** + * \brief Sets the preferred cache configuration for a device kernel. + * + * On devices where the L1 cache and shared memory use the same hardware + * resources, this sets through \p config the preferred cache configuration for + * the device kernel \p kernel on the requested device \p dev. This is only a preference. + * The driver will use the requested configuration if possible, but it is free to choose a different + * configuration if required to execute \p kernel. Any context-wide preference + * set via ::cuCtxSetCacheConfig() will be overridden by this per-kernel + * setting. + * + * Note that attributes set using ::cuFuncSetCacheConfig() will override the attribute + * set by this API irrespective of whether the call to ::cuFuncSetCacheConfig() is made + * before or after this API call. + * + * This setting does nothing on devices where the size of the L1 cache and + * shared memory are fixed. + * + * Launching a kernel with a different preference than the most recent + * preference setting may insert a device-side synchronization point. + * + * + * The supported cache configurations are: + * - ::CU_FUNC_CACHE_PREFER_NONE: no preference for shared memory or L1 (default) + * - ::CU_FUNC_CACHE_PREFER_SHARED: prefer larger shared memory and smaller L1 cache + * - ::CU_FUNC_CACHE_PREFER_L1: prefer larger L1 cache and smaller shared memory + * - ::CU_FUNC_CACHE_PREFER_EQUAL: prefer equal sized L1 cache and shared memory + * + * \note The API has stricter locking requirements in comparison to its legacy counterpart + * ::cuFuncSetCacheConfig() due to device-wide semantics. If multiple threads are trying to + * set a config on the same device simultaneously, the cache config setting will depend + * on the interleavings chosen by the OS scheduler and memory consistency. + * + * \param kernel - Kernel to configure cache for + * \param config - Requested cache configuration + * \param dev - Device to set attribute of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuLibraryGetKernel, + * ::cuKernelGetFunction, + * ::cuLibraryGetModule, + * ::cuModuleGetFunction, + * ::cuFuncSetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuLaunchKernel + */ +CUresult CUDAAPI cuKernelSetCacheConfig(CUkernel kernel, CUfunc_cache config, CUdevice dev); + +/** + * \brief Returns the function name for a ::CUkernel handle + * + * Returns in \p **name the function name associated with the kernel handle \p hfunc . + * The function name is returned as a null-terminated string. The returned name is only + * valid when the kernel handle is valid. If the library is unloaded or reloaded, one + * must call the API again to get the updated name. This API may return a mangled name if + * the function is not declared as having C linkage. If either \p **name or \p hfunc + * is NULL, ::CUDA_ERROR_INVALID_VALUE is returned. + * + * \param name - The returned name of the function + * \param hfunc - The function handle to retrieve the name for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + */ +CUresult CUDAAPI cuKernelGetName(const char **name, CUkernel hfunc); + +/** + * \brief Returns the offset and size of a kernel parameter in the device-side parameter layout + * + * Queries the kernel parameter at \p paramIndex into \p kernel's list of parameters, and returns + * in \p paramOffset and \p paramSize the offset and size, respectively, where the parameter + * will reside in the device-side parameter layout. This information can be used to update kernel + * node parameters from the device via ::cudaGraphKernelNodeSetParam() and + * ::cudaGraphKernelNodeUpdatesApply(). \p paramIndex must be less than the number of parameters + * that \p kernel takes. \p paramSize can be set to NULL if only the parameter offset is desired. + * + * \param kernel - The kernel to query + * \param paramIndex - The parameter index to query + * \param paramOffset - Returns the offset into the device-side parameter layout at which the parameter resides + * \param paramSize - Optionally returns the size of the parameter in the device-side parameter layout + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * +* \sa ::cuFuncGetParamInfo + */ +CUresult CUDAAPI cuKernelGetParamInfo(CUkernel kernel, size_t paramIndex, size_t *paramOffset, size_t *paramSize); +/** @} */ /* END CUDA_LIBRARY */ + +/** + * \defgroup CUDA_MEM Memory Management + * + * ___MANBRIEF___ memory management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the memory management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Gets free and total memory + * + * Returns in \p *total the total amount of memory available to the the current context. + * Returns in \p *free the amount of memory on the device that is free according to the OS. + * CUDA is not guaranteed to be able to allocate all of the memory that the OS reports as free. + * In a multi-tenet situation, free estimate returned is prone to race condition where + * a new allocation/free done by a different process or a different thread in the same + * process between the time when free memory was estimated and reported, will result in + * deviation in free value reported and actual free memory. + * + * The integrated GPU on Tegra shares memory with CPU and other component + * of the SoC. The free and total values returned by the API excludes + * the SWAP memory space maintained by the OS on some platforms. + * The OS may move some of the memory pages into swap area as the GPU or + * CPU allocate or access memory. See Tegra app note on how to calculate + * total and free memory on Tegra. + * + * \param free - Returned free memory in bytes + * \param total - Returned total memory in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemGetInfo + */ +CUresult CUDAAPI cuMemGetInfo(size_t *free, size_t *total); + +/** + * \brief Allocates device memory + * + * Allocates \p bytesize bytes of linear memory on the device and returns in + * \p *dptr a pointer to the allocated memory. The allocated memory is suitably + * aligned for any kind of variable. The memory is not cleared. If \p bytesize + * is 0, ::cuMemAlloc() returns ::CUDA_ERROR_INVALID_VALUE. + * + * \param dptr - Returned device pointer + * \param bytesize - Requested allocation size in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMalloc + */ +CUresult CUDAAPI cuMemAlloc(CUdeviceptr *dptr, size_t bytesize); + +/** + * \brief Allocates pitched device memory + * + * Allocates at least \p WidthInBytes * \p Height bytes of linear memory on + * the device and returns in \p *dptr a pointer to the allocated memory. The + * function may pad the allocation to ensure that corresponding pointers in + * any given row will continue to meet the alignment requirements for + * coalescing as the address is updated from row to row. \p ElementSizeBytes + * specifies the size of the largest reads and writes that will be performed + * on the memory range. \p ElementSizeBytes may be 4, 8 or 16 (since coalesced + * memory transactions are not possible on other data sizes). If + * \p ElementSizeBytes is smaller than the actual read/write size of a kernel, + * the kernel will run correctly, but possibly at reduced speed. The pitch + * returned in \p *pPitch by ::cuMemAllocPitch() is the width in bytes of the + * allocation. The intended usage of pitch is as a separate parameter of the + * allocation, used to compute addresses within the 2D array. Given the row + * and column of an array element of type \b T, the address is computed as: + * \code + T* pElement = (T*)((char*)BaseAddress + Row * Pitch) + Column; + * \endcode + * + * The pitch returned by ::cuMemAllocPitch() is guaranteed to work with + * ::cuMemcpy2D() under all circumstances. For allocations of 2D arrays, it is + * recommended that programmers consider performing pitch allocations using + * ::cuMemAllocPitch(). Due to alignment restrictions in the hardware, this is + * especially true if the application will be performing 2D memory copies + * between different regions of device memory (whether linear memory or CUDA + * arrays). + * + * The byte alignment of the pitch returned by ::cuMemAllocPitch() is guaranteed + * to match or exceed the alignment requirement for texture binding with + * ::cuTexRefSetAddress2D(). + * + * \param dptr - Returned device pointer + * \param pPitch - Returned pitch of allocation in bytes + * \param WidthInBytes - Requested allocation width in bytes + * \param Height - Requested allocation height in rows + * \param ElementSizeBytes - Size of largest reads/writes for range + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMallocPitch + */ +CUresult CUDAAPI cuMemAllocPitch(CUdeviceptr *dptr, size_t *pPitch, size_t WidthInBytes, size_t Height, unsigned int ElementSizeBytes); + +/** + * \brief Frees device memory + * + * Frees the memory space pointed to by \p dptr, which must have been returned + * by a previous call to one of the following memory allocation APIs - ::cuMemAlloc(), + * ::cuMemAllocPitch(), ::cuMemAllocManaged(), ::cuMemAllocAsync(), ::cuMemAllocFromPoolAsync() + * + * Note - This API will not perform any implict synchronization when the pointer was allocated with + * ::cuMemAllocAsync or ::cuMemAllocFromPoolAsync. Callers must ensure that all accesses to these + * pointer have completed before invoking ::cuMemFree. For best performance and memory reuse, users + * should use ::cuMemFreeAsync to free memory allocated via the stream ordered memory allocator. + * For all other pointers, this API may perform implicit synchronization. + * + * \param dptr - Pointer to memory to free + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemAllocManaged, ::cuMemAllocAsync, ::cuMemAllocFromPoolAsync, + * ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, ::cuMemcpy3D, ::cuMemcpy3DAsync, + * ::cuMemcpyAtoA, ::cuMemcpyAtoD, ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, + * ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, + * ::cuMemcpyHtoAAsync, ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, ::cuMemFreeAsync, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaFree + */ +CUresult CUDAAPI cuMemFree(CUdeviceptr dptr); + +/** + * \brief Get information on memory allocations + * + * Returns the base address in \p *pbase and size in \p *psize of the + * allocation by ::cuMemAlloc() or ::cuMemAllocPitch() that contains the input + * pointer \p dptr. Both parameters \p pbase and \p psize are optional. If one + * of them is NULL, it is ignored. + * + * \param pbase - Returned base address + * \param psize - Returned size of device memory allocation + * \param dptr - Device pointer to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_NOT_FOUND, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32 + */ +CUresult CUDAAPI cuMemGetAddressRange(CUdeviceptr *pbase, size_t *psize, CUdeviceptr dptr); + +/** + * \brief Allocates page-locked host memory + * + * Allocates \p bytesize bytes of host memory that is page-locked and + * accessible to the device. The driver tracks the virtual memory ranges + * allocated with this function and automatically accelerates calls to + * functions such as ::cuMemcpy(). Since the memory can be accessed directly by + * the device, it can be read or written with much higher bandwidth than + * pageable memory obtained with functions such as ::malloc(). + * + * On systems where ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES + * is true, ::cuMemAllocHost may not page-lock the allocated memory. + * + * Page-locking excessive amounts of memory with ::cuMemAllocHost() may degrade system + * performance, since it reduces the amount of memory available to the system + * for paging. As a result, this function is best used sparingly to allocate + * staging areas for data exchange between host and device. + * + * Note all host memory allocated using ::cuMemAllocHost() will automatically + * be immediately accessible to all contexts on all devices which support unified + * addressing (as may be queried using ::CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING). + * The device pointer that may be used to access this host memory from those + * contexts is always equal to the returned host pointer \p *pp. + * See \ref CUDA_UNIFIED for additional details. + * + * \param pp - Returned pointer to host memory + * \param bytesize - Requested allocation size in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMallocHost + */ +CUresult CUDAAPI cuMemAllocHost(void **pp, size_t bytesize); + +/** + * \brief Frees page-locked host memory + * + * Frees the memory space pointed to by \p p, which must have been returned by + * a previous call to ::cuMemAllocHost(). + * + * \param p - Pointer to memory to free + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaFreeHost + */ +CUresult CUDAAPI cuMemFreeHost(void *p); + +/** + * \brief Allocates page-locked host memory + * + * Allocates \p bytesize bytes of host memory that is page-locked and accessible + * to the device. The driver tracks the virtual memory ranges allocated with + * this function and automatically accelerates calls to functions such as + * ::cuMemcpyHtoD(). Since the memory can be accessed directly by the device, + * it can be read or written with much higher bandwidth than pageable memory + * obtained with functions such as ::malloc(). + * + * On systems where ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES + * is true, ::cuMemHostAlloc may not page-lock the allocated memory. + * + * Page-locking excessive amounts of memory may degrade system performance, + * since it reduces the amount of memory available to the system for paging. + * As a result, this function is best used sparingly to allocate staging areas + * for data exchange between host and device. + * + * The \p Flags parameter enables different options to be specified that + * affect the allocation, as follows. + * + * - ::CU_MEMHOSTALLOC_PORTABLE: The memory returned by this call will be + * considered as pinned memory by all CUDA contexts, not just the one that + * performed the allocation. + * + * - ::CU_MEMHOSTALLOC_DEVICEMAP: Maps the allocation into the CUDA address + * space. The device pointer to the memory may be obtained by calling + * ::cuMemHostGetDevicePointer(). + * + * - ::CU_MEMHOSTALLOC_WRITECOMBINED: Allocates the memory as write-combined + * (WC). WC memory can be transferred across the PCI Express bus more + * quickly on some system configurations, but cannot be read efficiently by + * most CPUs. WC memory is a good option for buffers that will be written by + * the CPU and read by the GPU via mapped pinned memory or host->device + * transfers. + * + * All of these flags are orthogonal to one another: a developer may allocate + * memory that is portable, mapped and/or write-combined with no restrictions. + * + * The ::CU_MEMHOSTALLOC_DEVICEMAP flag may be specified on CUDA contexts for + * devices that do not support mapped pinned memory. The failure is deferred + * to ::cuMemHostGetDevicePointer() because the memory may be mapped into + * other CUDA contexts via the ::CU_MEMHOSTALLOC_PORTABLE flag. + * + * The memory allocated by this function must be freed with ::cuMemFreeHost(). + * + * Note all host memory allocated using ::cuMemHostAlloc() will automatically + * be immediately accessible to all contexts on all devices which support unified + * addressing (as may be queried using ::CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING). + * Unless the flag ::CU_MEMHOSTALLOC_WRITECOMBINED is specified, the device pointer + * that may be used to access this host memory from those contexts is always equal + * to the returned host pointer \p *pp. If the flag ::CU_MEMHOSTALLOC_WRITECOMBINED + * is specified, then the function ::cuMemHostGetDevicePointer() must be used + * to query the device pointer, even if the context supports unified addressing. + * See \ref CUDA_UNIFIED for additional details. + * + * \param pp - Returned pointer to host memory + * \param bytesize - Requested allocation size in bytes + * \param Flags - Flags for allocation request + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaHostAlloc + */ +CUresult CUDAAPI cuMemHostAlloc(void **pp, size_t bytesize, unsigned int Flags); + +/** + * \brief Passes back device pointer of mapped pinned memory + * + * Passes back the device pointer \p pdptr corresponding to the mapped, pinned + * host buffer \p p allocated by ::cuMemHostAlloc. + * + * ::cuMemHostGetDevicePointer() will fail if the ::CU_MEMHOSTALLOC_DEVICEMAP + * flag was not specified at the time the memory was allocated, or if the + * function is called on a GPU that does not support mapped pinned memory. + * + * For devices that have a non-zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_HOST_POINTER_FOR_REGISTERED_MEM, the memory + * can also be accessed from the device using the host pointer \p p. + * The device pointer returned by ::cuMemHostGetDevicePointer() may or may not + * match the original host pointer \p p and depends on the devices visible to the + * application. If all devices visible to the application have a non-zero value for the + * device attribute, the device pointer returned by ::cuMemHostGetDevicePointer() + * will match the original pointer \p p. If any device visible to the application + * has a zero value for the device attribute, the device pointer returned by + * ::cuMemHostGetDevicePointer() will not match the original host pointer \p p, + * but it will be suitable for use on all devices provided Unified Virtual Addressing + * is enabled. In such systems, it is valid to access the memory using either pointer + * on devices that have a non-zero value for the device attribute. Note however that + * such devices should access the memory using only one of the two pointers and not both. + * + * \p Flags provides for future releases. For now, it must be set to 0. + * + * \param pdptr - Returned device pointer + * \param p - Host pointer + * \param Flags - Options (must be 0) + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaHostGetDevicePointer + */ +CUresult CUDAAPI cuMemHostGetDevicePointer(CUdeviceptr *pdptr, void *p, unsigned int Flags); + +/** + * \brief Passes back flags that were used for a pinned allocation + * + * Passes back the flags \p pFlags that were specified when allocating + * the pinned host buffer \p p allocated by ::cuMemHostAlloc. + * + * ::cuMemHostGetFlags() will fail if the pointer does not reside in + * an allocation performed by ::cuMemAllocHost() or ::cuMemHostAlloc(). + * + * \param pFlags - Returned flags word + * \param p - Host pointer + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuMemAllocHost, + * ::cuMemHostAlloc, + * ::cudaHostGetFlags + */ +CUresult CUDAAPI cuMemHostGetFlags(unsigned int *pFlags, void *p); + +/** + * \brief Allocates memory that will be automatically managed by the Unified Memory system + * + * Allocates \p bytesize bytes of managed memory on the device and returns in + * \p *dptr a pointer to the allocated memory. If the device doesn't support + * allocating managed memory, ::CUDA_ERROR_NOT_SUPPORTED is returned. Support + * for managed memory can be queried using the device attribute + * ::CU_DEVICE_ATTRIBUTE_MANAGED_MEMORY. The allocated memory is suitably + * aligned for any kind of variable. The memory is not cleared. If \p bytesize + * is 0, ::cuMemAllocManaged returns ::CUDA_ERROR_INVALID_VALUE. The pointer + * is valid on the CPU and on all GPUs in the system that support managed memory. + * All accesses to this pointer must obey the Unified Memory programming model. + * + * \p flags specifies the default stream association for this allocation. + * \p flags must be one of ::CU_MEM_ATTACH_GLOBAL or ::CU_MEM_ATTACH_HOST. If + * ::CU_MEM_ATTACH_GLOBAL is specified, then this memory is accessible from + * any stream on any device. If ::CU_MEM_ATTACH_HOST is specified, then the + * allocation should not be accessed from devices that have a zero value for the + * device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS; an explicit call to + * ::cuStreamAttachMemAsync will be required to enable access on such devices. + * + * If the association is later changed via ::cuStreamAttachMemAsync to + * a single stream, the default association as specified during ::cuMemAllocManaged + * is restored when that stream is destroyed. For __managed__ variables, the + * default association is always ::CU_MEM_ATTACH_GLOBAL. Note that destroying a + * stream is an asynchronous operation, and as a result, the change to default + * association won't happen until all work in the stream has completed. + * + * Memory allocated with ::cuMemAllocManaged should be released with ::cuMemFree. + * + * Device memory oversubscription is possible for GPUs that have a non-zero value for the + * device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. Managed memory on + * such GPUs may be evicted from device memory to host memory at any time by the Unified + * Memory driver in order to make room for other allocations. + * + * In a system where all GPUs have a non-zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS, managed memory may not be populated when this + * API returns and instead may be populated on access. In such systems, managed memory can + * migrate to any processor's memory at any time. The Unified Memory driver will employ heuristics to + * maintain data locality and prevent excessive page faults to the extent possible. The application + * can also guide the driver about memory usage patterns via ::cuMemAdvise. The application + * can also explicitly migrate memory to a desired processor's memory via + * ::cuMemPrefetchAsync. + * + * In a multi-GPU system where all of the GPUs have a zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS and all the GPUs have peer-to-peer support + * with each other, the physical storage for managed memory is created on the GPU which is active + * at the time ::cuMemAllocManaged is called. All other GPUs will reference the data at reduced + * bandwidth via peer mappings over the PCIe bus. The Unified Memory driver does not migrate + * memory among such GPUs. + * + * In a multi-GPU system where not all GPUs have peer-to-peer support with each other and + * where the value of the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS + * is zero for at least one of those GPUs, the location chosen for physical storage of managed + * memory is system-dependent. + * - On Linux, the location chosen will be device memory as long as the current set of active + * contexts are on devices that either have peer-to-peer support with each other or have a + * non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * If there is an active context on a GPU that does not have a non-zero value for that device + * attribute and it does not have peer-to-peer support with the other devices that have active + * contexts on them, then the location for physical storage will be 'zero-copy' or host memory. + * Note that this means that managed memory that is located in device memory is migrated to + * host memory if a new context is created on a GPU that doesn't have a non-zero value for + * the device attribute and does not support peer-to-peer with at least one of the other devices + * that has an active context. This in turn implies that context creation may fail if there is + * insufficient host memory to migrate all managed allocations. + * - On Windows, the physical storage is always created in 'zero-copy' or host memory. + * All GPUs will reference the data at reduced bandwidth over the PCIe bus. In these + * circumstances, use of the environment variable CUDA_VISIBLE_DEVICES is recommended to + * restrict CUDA to only use those GPUs that have peer-to-peer support. + * Alternatively, users can also set CUDA_MANAGED_FORCE_DEVICE_ALLOC to a + * non-zero value to force the driver to always use device memory for physical storage. + * When this environment variable is set to a non-zero value, all contexts created in + * that process on devices that support managed memory have to be peer-to-peer compatible + * with each other. Context creation will fail if a context is created on a device that + * supports managed memory and is not peer-to-peer compatible with any of the other + * managed memory supporting devices on which contexts were previously created, even if + * those contexts have been destroyed. These environment variables are described + * in the CUDA programming guide under the "CUDA environment variables" section. + * - On ARM, managed memory is not available on discrete gpu with Drive PX-2. + * + * \param dptr - Returned device pointer + * \param bytesize - Requested allocation size in bytes + * \param flags - Must be one of ::CU_MEM_ATTACH_GLOBAL or ::CU_MEM_ATTACH_HOST + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cuDeviceGetAttribute, ::cuStreamAttachMemAsync, + * ::cudaMallocManaged + */ +CUresult CUDAAPI cuMemAllocManaged(CUdeviceptr *dptr, size_t bytesize, unsigned int flags); + +/** +* \brief Registers a callback function to receive async notifications +* +* Registers \p callbackFunc to receive async notifications. +* +* The \p userData parameter is passed to the callback function at async notification time. +* Likewise, \p callback is also passed to the callback function to distinguish between +* multiple registered callbacks. +* +* The callback function being registered should be designed to return quickly (~10ms). +* Any long running tasks should be queued for execution on an application thread. +* +* Callbacks may not call cuDeviceRegisterAsyncNotification or cuDeviceUnregisterAsyncNotification. +* Doing so will result in ::CUDA_ERROR_NOT_PERMITTED. Async notification callbacks execute +* in an undefined order and may be serialized. +* +* Returns in \p *callback a handle representing the registered callback instance. +* +* \param device - The device on which to register the callback +* \param callbackFunc - The function to register as a callback +* \param userData - A generic pointer to user data. This is passed into the callback function. +* \param callback - A handle representing the registered callback instance +* +* \return +* ::CUDA_SUCCESS +* ::CUDA_ERROR_NOT_SUPPORTED +* ::CUDA_ERROR_INVALID_DEVICE +* ::CUDA_ERROR_INVALID_VALUE +* ::CUDA_ERROR_NOT_PERMITTED +* ::CUDA_ERROR_UNKNOWN +* \notefnerr +* +* \sa +* ::cuDeviceUnregisterAsyncNotification +*/ +CUresult CUDAAPI cuDeviceRegisterAsyncNotification(CUdevice device, CUasyncCallback callbackFunc, void *userData, CUasyncCallbackHandle *callback); + +/** +* \brief Unregisters an async notification callback +* +* Unregisters \p callback so that the corresponding callback function will stop receiving +* async notifications. +* +* \param device - The device from which to remove \p callback. +* \param callback - The callback instance to unregister from receiving async notifications. +* +* \return +* ::CUDA_SUCCESS +* ::CUDA_ERROR_NOT_SUPPORTED +* ::CUDA_ERROR_INVALID_DEVICE +* ::CUDA_ERROR_INVALID_VALUE +* ::CUDA_ERROR_NOT_PERMITTED +* ::CUDA_ERROR_UNKNOWN +* \notefnerr +* +* \sa +* ::cuDeviceRegisterAsyncNotification +*/ +CUresult CUDAAPI cuDeviceUnregisterAsyncNotification(CUdevice device, CUasyncCallbackHandle callback); + +/** + * \brief Returns a handle to a compute device + * + * Returns in \p *device a device handle given a PCI bus ID string. + * + * \param dev - Returned device handle + * + * \param pciBusId - String in one of the following forms: + * [domain]:[bus]:[device].[function] + * [domain]:[bus]:[device] + * [bus]:[device].[function] + * where \p domain, \p bus, \p device, and \p function are all hexadecimal values + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGet, + * ::cuDeviceGetAttribute, + * ::cuDeviceGetPCIBusId, + * ::cudaDeviceGetByPCIBusId + */ +CUresult CUDAAPI cuDeviceGetByPCIBusId(CUdevice *dev, const char *pciBusId); + +/** + * \brief Returns a PCI Bus Id string for the device + * + * Returns an ASCII string identifying the device \p dev in the NULL-terminated + * string pointed to by \p pciBusId. \p len specifies the maximum length of the + * string that may be returned. + * + * \param pciBusId - Returned identifier string for the device in the following format + * [domain]:[bus]:[device].[function] + * where \p domain, \p bus, \p device, and \p function are all hexadecimal values. + * pciBusId should be large enough to store 13 characters including the NULL-terminator. + * + * \param len - Maximum length of string to store in \p name + * + * \param dev - Device to get identifier string for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGet, + * ::cuDeviceGetAttribute, + * ::cuDeviceGetByPCIBusId, + * ::cudaDeviceGetPCIBusId + */ +CUresult CUDAAPI cuDeviceGetPCIBusId(char *pciBusId, int len, CUdevice dev); + +/** + * \brief Gets an interprocess handle for a previously allocated event + * + * Takes as input a previously allocated event. This event must have been + * created with the ::CU_EVENT_INTERPROCESS and ::CU_EVENT_DISABLE_TIMING + * flags set. This opaque handle may be copied into other processes and + * opened with ::cuIpcOpenEventHandle to allow efficient hardware + * synchronization between GPU work in different processes. + * + * After the event has been opened in the importing process, + * ::cuEventRecord, ::cuEventSynchronize, ::cuStreamWaitEvent and + * ::cuEventQuery may be used in either process. Performing operations + * on the imported event after the exported event has been freed + * with ::cuEventDestroy will result in undefined behavior. + * + * IPC functionality is restricted to devices with support for unified + * addressing on Linux and Windows operating systems. + * IPC functionality on Windows is supported for compatibility purposes + * but not recommended as it comes with performance cost. + * Users can test their device for IPC functionality by calling + * ::cuapiDeviceGetAttribute with ::CU_DEVICE_ATTRIBUTE_IPC_EVENT_SUPPORTED + * + * \param pHandle - Pointer to a user allocated CUipcEventHandle + * in which to return the opaque event handle + * \param event - Event allocated with ::CU_EVENT_INTERPROCESS and + * ::CU_EVENT_DISABLE_TIMING flags. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_MAP_FAILED, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuEventCreate, + * ::cuEventDestroy, + * ::cuEventSynchronize, + * ::cuEventQuery, + * ::cuStreamWaitEvent, + * ::cuIpcOpenEventHandle, + * ::cuIpcGetMemHandle, + * ::cuIpcOpenMemHandle, + * ::cuIpcCloseMemHandle, + * ::cudaIpcGetEventHandle + */ +CUresult CUDAAPI cuIpcGetEventHandle(CUipcEventHandle *pHandle, CUevent event); + +/** + * \brief Opens an interprocess event handle for use in the current process + * + * Opens an interprocess event handle exported from another process with + * ::cuIpcGetEventHandle. This function returns a ::CUevent that behaves like + * a locally created event with the ::CU_EVENT_DISABLE_TIMING flag specified. + * This event must be freed with ::cuEventDestroy. + * + * Performing operations on the imported event after the exported event has + * been freed with ::cuEventDestroy will result in undefined behavior. + * + * IPC functionality is restricted to devices with support for unified + * addressing on Linux and Windows operating systems. + * IPC functionality on Windows is supported for compatibility purposes + * but not recommended as it comes with performance cost. + * Users can test their device for IPC functionality by calling + * ::cuapiDeviceGetAttribute with ::CU_DEVICE_ATTRIBUTE_IPC_EVENT_SUPPORTED + * + * \param phEvent - Returns the imported event + * \param handle - Interprocess handle to open + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_MAP_FAILED, + * ::CUDA_ERROR_PEER_ACCESS_UNSUPPORTED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuEventCreate, + * ::cuEventDestroy, + * ::cuEventSynchronize, + * ::cuEventQuery, + * ::cuStreamWaitEvent, + * ::cuIpcGetEventHandle, + * ::cuIpcGetMemHandle, + * ::cuIpcOpenMemHandle, + * ::cuIpcCloseMemHandle, + * ::cudaIpcOpenEventHandle + */ +CUresult CUDAAPI cuIpcOpenEventHandle(CUevent *phEvent, CUipcEventHandle handle); + +/** + * \brief Gets an interprocess memory handle for an existing device memory + * allocation + * + * Takes a pointer to the base of an existing device memory allocation created + * with ::cuMemAlloc and exports it for use in another process. This is a + * lightweight operation and may be called multiple times on an allocation + * without adverse effects. + * + * If a region of memory is freed with ::cuMemFree and a subsequent call + * to ::cuMemAlloc returns memory with the same device address, + * ::cuIpcGetMemHandle will return a unique handle for the + * new memory. + * + * IPC functionality is restricted to devices with support for unified + * addressing on Linux and Windows operating systems. + * IPC functionality on Windows is supported for compatibility purposes + * but not recommended as it comes with performance cost. + * Users can test their device for IPC functionality by calling + * ::cuapiDeviceGetAttribute with ::CU_DEVICE_ATTRIBUTE_IPC_EVENT_SUPPORTED + * + * \param pHandle - Pointer to user allocated ::CUipcMemHandle to return + * the handle in. + * \param dptr - Base pointer to previously allocated device memory + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_MAP_FAILED, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuMemAlloc, + * ::cuMemFree, + * ::cuIpcGetEventHandle, + * ::cuIpcOpenEventHandle, + * ::cuIpcOpenMemHandle, + * ::cuIpcCloseMemHandle, + * ::cudaIpcGetMemHandle + */ +CUresult CUDAAPI cuIpcGetMemHandle(CUipcMemHandle *pHandle, CUdeviceptr dptr); + +/** + * \brief Opens an interprocess memory handle exported from another process + * and returns a device pointer usable in the local process. + * + * Maps memory exported from another process with ::cuIpcGetMemHandle into + * the current device address space. For contexts on different devices + * ::cuIpcOpenMemHandle can attempt to enable peer access between the + * devices as if the user called ::cuCtxEnablePeerAccess. This behavior is + * controlled by the ::CU_IPC_MEM_LAZY_ENABLE_PEER_ACCESS flag. + * ::cuDeviceCanAccessPeer can determine if a mapping is possible. + * + * Contexts that may open ::CUipcMemHandles are restricted in the following way. + * ::CUipcMemHandles from each ::CUdevice in a given process may only be opened + * by one ::CUcontext per ::CUdevice per other process. + * + * If the memory handle has already been opened by the current context, the + * reference count on the handle is incremented by 1 and the existing device pointer + * is returned. + * + * Memory returned from ::cuIpcOpenMemHandle must be freed with + * ::cuIpcCloseMemHandle. + * + * Calling ::cuMemFree on an exported memory region before calling + * ::cuIpcCloseMemHandle in the importing context will result in undefined + * behavior. + * + * IPC functionality is restricted to devices with support for unified + * addressing on Linux and Windows operating systems. + * IPC functionality on Windows is supported for compatibility purposes + * but not recommended as it comes with performance cost. + * Users can test their device for IPC functionality by calling + * ::cuapiDeviceGetAttribute with ::CU_DEVICE_ATTRIBUTE_IPC_EVENT_SUPPORTED + * + * \param pdptr - Returned device pointer + * \param handle - ::CUipcMemHandle to open + * \param Flags - Flags for this operation. Must be specified as ::CU_IPC_MEM_LAZY_ENABLE_PEER_ACCESS + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_MAP_FAILED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_TOO_MANY_PEERS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \note No guarantees are made about the address returned in \p *pdptr. + * In particular, multiple processes may not receive the same address for the same \p handle. + * + * \sa + * ::cuMemAlloc, + * ::cuMemFree, + * ::cuIpcGetEventHandle, + * ::cuIpcOpenEventHandle, + * ::cuIpcGetMemHandle, + * ::cuIpcCloseMemHandle, + * ::cuCtxEnablePeerAccess, + * ::cuDeviceCanAccessPeer, + * ::cudaIpcOpenMemHandle + */ +CUresult CUDAAPI cuIpcOpenMemHandle(CUdeviceptr *pdptr, CUipcMemHandle handle, unsigned int Flags); + +/** + * \brief Attempts to close memory mapped with ::cuIpcOpenMemHandle + * + * Decrements the reference count of the memory returned by ::cuIpcOpenMemHandle by 1. + * When the reference count reaches 0, this API unmaps the memory. The original allocation + * in the exporting process as well as imported mappings in other processes + * will be unaffected. + * + * Any resources used to enable peer access will be freed if this is the + * last mapping using them. + * + * IPC functionality is restricted to devices with support for unified + * addressing on Linux and Windows operating systems. + * IPC functionality on Windows is supported for compatibility purposes + * but not recommended as it comes with performance cost. + * Users can test their device for IPC functionality by calling + * ::cuapiDeviceGetAttribute with ::CU_DEVICE_ATTRIBUTE_IPC_EVENT_SUPPORTED + * + * \param dptr - Device pointer returned by ::cuIpcOpenMemHandle + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_MAP_FAILED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * \sa + * ::cuMemAlloc, + * ::cuMemFree, + * ::cuIpcGetEventHandle, + * ::cuIpcOpenEventHandle, + * ::cuIpcGetMemHandle, + * ::cuIpcOpenMemHandle, + * ::cudaIpcCloseMemHandle + */ +CUresult CUDAAPI cuIpcCloseMemHandle(CUdeviceptr dptr); + +/** + * \brief Registers an existing host memory range for use by CUDA + * + * Page-locks the memory range specified by \p p and \p bytesize and maps it + * for the device(s) as specified by \p Flags. This memory range also is added + * to the same tracking mechanism as ::cuMemHostAlloc to automatically accelerate + * calls to functions such as ::cuMemcpyHtoD(). Since the memory can be accessed + * directly by the device, it can be read or written with much higher bandwidth + * than pageable memory that has not been registered. Page-locking excessive + * amounts of memory may degrade system performance, since it reduces the amount + * of memory available to the system for paging. As a result, this function is + * best used sparingly to register staging areas for data exchange between + * host and device. + * + * On systems where ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES + * is true, ::cuMemHostRegister will not page-lock the memory range specified + * by \p ptr but only populate unpopulated pages. + * + * The \p Flags parameter enables different options to be specified that + * affect the allocation, as follows. + * + * - ::CU_MEMHOSTREGISTER_PORTABLE: The memory returned by this call will be + * considered as pinned memory by all CUDA contexts, not just the one that + * performed the allocation. + * + * - ::CU_MEMHOSTREGISTER_DEVICEMAP: Maps the allocation into the CUDA address + * space. The device pointer to the memory may be obtained by calling + * ::cuMemHostGetDevicePointer(). + * + * - ::CU_MEMHOSTREGISTER_IOMEMORY: The pointer is treated as pointing to some + * I/O memory space, e.g. the PCI Express resource of a 3rd party device. + * + * - ::CU_MEMHOSTREGISTER_READ_ONLY: The pointer is treated as pointing to memory + * that is considered read-only by the device. On platforms without + * ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, this flag is + * required in order to register memory mapped to the CPU as read-only. Support + * for the use of this flag can be queried from the device attribute + * ::CU_DEVICE_ATTRIBUTE_READ_ONLY_HOST_REGISTER_SUPPORTED. Using this flag with + * a current context associated with a device that does not have this attribute + * set will cause ::cuMemHostRegister to error with CUDA_ERROR_NOT_SUPPORTED. + * + * All of these flags are orthogonal to one another: a developer may page-lock + * memory that is portable or mapped with no restrictions. + * + * The ::CU_MEMHOSTREGISTER_DEVICEMAP flag may be specified on CUDA contexts for + * devices that do not support mapped pinned memory. The failure is deferred + * to ::cuMemHostGetDevicePointer() because the memory may be mapped into + * other CUDA contexts via the ::CU_MEMHOSTREGISTER_PORTABLE flag. + * + * For devices that have a non-zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_HOST_POINTER_FOR_REGISTERED_MEM, the memory + * can also be accessed from the device using the host pointer \p p. + * The device pointer returned by ::cuMemHostGetDevicePointer() may or may not + * match the original host pointer \p ptr and depends on the devices visible to the + * application. If all devices visible to the application have a non-zero value for the + * device attribute, the device pointer returned by ::cuMemHostGetDevicePointer() + * will match the original pointer \p ptr. If any device visible to the application + * has a zero value for the device attribute, the device pointer returned by + * ::cuMemHostGetDevicePointer() will not match the original host pointer \p ptr, + * but it will be suitable for use on all devices provided Unified Virtual Addressing + * is enabled. In such systems, it is valid to access the memory using either pointer + * on devices that have a non-zero value for the device attribute. Note however that + * such devices should access the memory using only of the two pointers and not both. + * + * The memory page-locked by this function must be unregistered with + * ::cuMemHostUnregister(). + * + * \param p - Host pointer to memory to page-lock + * \param bytesize - Size in bytes of the address range to page-lock + * \param Flags - Flags for allocation request + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_HOST_MEMORY_ALREADY_REGISTERED, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa + * ::cuMemHostUnregister, + * ::cuMemHostGetFlags, + * ::cuMemHostGetDevicePointer, + * ::cudaHostRegister + */ +CUresult CUDAAPI cuMemHostRegister(void *p, size_t bytesize, unsigned int Flags); + +/** + * \brief Unregisters a memory range that was registered with cuMemHostRegister. + * + * Unmaps the memory range whose base address is specified by \p p, and makes + * it pageable again. + * + * The base address must be the same one specified to ::cuMemHostRegister(). + * + * \param p - Host pointer to memory to unregister + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_HOST_MEMORY_NOT_REGISTERED, + * \notefnerr + * + * \sa + * ::cuMemHostRegister, + * ::cudaHostUnregister + */ +CUresult CUDAAPI cuMemHostUnregister(void *p); + +/** + * \brief Copies memory + * + * Copies data between two pointers. + * \p dst and \p src are base pointers of the destination and source, respectively. + * \p ByteCount specifies the number of bytes to copy. + * Note that this function infers the type of the transfer (host to host, host to + * device, device to device, or device to host) from the pointer values. This + * function is only allowed in contexts which support unified addressing. + * + * \param dst - Destination unified virtual address space pointer + * \param src - Source unified virtual address space pointer + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy, + * ::cudaMemcpyToSymbol, + * ::cudaMemcpyFromSymbol + */ +CUresult CUDAAPI cuMemcpy(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount); + +/** + * \brief Copies device memory between two contexts + * + * Copies from device memory in one context to device memory in another + * context. \p dstDevice is the base device pointer of the destination memory + * and \p dstContext is the destination context. \p srcDevice is the base + * device pointer of the source memory and \p srcContext is the source pointer. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstDevice - Destination device pointer + * \param dstContext - Destination context + * \param srcDevice - Source device pointer + * \param srcContext - Source context + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuMemcpyDtoD, ::cuMemcpy3DPeer, ::cuMemcpyDtoDAsync, ::cuMemcpyPeerAsync, + * ::cuMemcpy3DPeerAsync, + * ::cudaMemcpyPeer + */ +CUresult CUDAAPI cuMemcpyPeer(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount); + +/** + * \brief Copies memory from Host to Device + * + * Copies from host memory to device memory. \p dstDevice and \p srcHost are + * the base addresses of the destination and source, respectively. \p ByteCount + * specifies the number of bytes to copy. + * + * \param dstDevice - Destination device pointer + * \param srcHost - Source host pointer + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy, + * ::cudaMemcpyToSymbol + */ +CUresult CUDAAPI cuMemcpyHtoD(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount); + +/** + * \brief Copies memory from Device to Host + * + * Copies from device to host memory. \p dstHost and \p srcDevice specify the + * base pointers of the destination and source, respectively. \p ByteCount + * specifies the number of bytes to copy. + * + * \param dstHost - Destination host pointer + * \param srcDevice - Source device pointer + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy, + * ::cudaMemcpyFromSymbol + */ +CUresult CUDAAPI cuMemcpyDtoH(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount); + +/** + * \brief Copies memory from Device to Device + * + * Copies from device memory to device memory. \p dstDevice and \p srcDevice + * are the base pointers of the destination and source, respectively. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstDevice - Destination device pointer + * \param srcDevice - Source device pointer + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy, + * ::cudaMemcpyToSymbol, + * ::cudaMemcpyFromSymbol + */ +CUresult CUDAAPI cuMemcpyDtoD(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount); + +/** + * \brief Copies memory from Device to Array + * + * Copies from device memory to a 1D CUDA array. \p dstArray and \p dstOffset + * specify the CUDA array handle and starting index of the destination data. + * \p srcDevice specifies the base pointer of the source. \p ByteCount + * specifies the number of bytes to copy. + * + * \param dstArray - Destination array + * \param dstOffset - Offset in bytes of destination array + * \param srcDevice - Source device pointer + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpyToArray + */ +CUresult CUDAAPI cuMemcpyDtoA(CUarray dstArray, size_t dstOffset, CUdeviceptr srcDevice, size_t ByteCount); + +/** + * \brief Copies memory from Array to Device + * + * Copies from one 1D CUDA array to device memory. \p dstDevice specifies the + * base pointer of the destination and must be naturally aligned with the CUDA + * array elements. \p srcArray and \p srcOffset specify the CUDA array handle + * and the offset in bytes into the array where the copy is to begin. + * \p ByteCount specifies the number of bytes to copy and must be evenly + * divisible by the array element size. + * + * \param dstDevice - Destination device pointer + * \param srcArray - Source array + * \param srcOffset - Offset in bytes of source array + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpyFromArray + */ +CUresult CUDAAPI cuMemcpyAtoD(CUdeviceptr dstDevice, CUarray srcArray, size_t srcOffset, size_t ByteCount); + +/** + * \brief Copies memory from Host to Array + * + * Copies from host memory to a 1D CUDA array. \p dstArray and \p dstOffset + * specify the CUDA array handle and starting offset in bytes of the destination + * data. \p pSrc specifies the base address of the source. \p ByteCount specifies + * the number of bytes to copy. + * + * \param dstArray - Destination array + * \param dstOffset - Offset in bytes of destination array + * \param srcHost - Source host pointer + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpyToArray + */ +CUresult CUDAAPI cuMemcpyHtoA(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount); + +/** + * \brief Copies memory from Array to Host + * + * Copies from one 1D CUDA array to host memory. \p dstHost specifies the base + * pointer of the destination. \p srcArray and \p srcOffset specify the CUDA + * array handle and starting offset in bytes of the source data. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstHost - Destination device pointer + * \param srcArray - Source array + * \param srcOffset - Offset in bytes of source array + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpyFromArray + */ +CUresult CUDAAPI cuMemcpyAtoH(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount); + +/** + * \brief Copies memory from Array to Array + * + * Copies from one 1D CUDA array to another. \p dstArray and \p srcArray + * specify the handles of the destination and source CUDA arrays for the copy, + * respectively. \p dstOffset and \p srcOffset specify the destination and + * source offsets in bytes into the CUDA arrays. \p ByteCount is the number of + * bytes to be copied. The size of the elements in the CUDA arrays need not be + * the same format, but the elements must be the same size; and count must be + * evenly divisible by that size. + * + * \param dstArray - Destination array + * \param dstOffset - Offset in bytes of destination array + * \param srcArray - Source array + * \param srcOffset - Offset in bytes of source array + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpyArrayToArray + */ +CUresult CUDAAPI cuMemcpyAtoA(CUarray dstArray, size_t dstOffset, CUarray srcArray, size_t srcOffset, size_t ByteCount); + +/** + * \brief Copies memory for 2D arrays + * + * Perform a 2D memory copy according to the parameters specified in \p pCopy. + * The ::CUDA_MEMCPY2D structure is defined as: + * + * \code + typedef struct CUDA_MEMCPY2D_st { + unsigned int srcXInBytes, srcY; + CUmemorytype srcMemoryType; + const void *srcHost; + CUdeviceptr srcDevice; + CUarray srcArray; + unsigned int srcPitch; + + unsigned int dstXInBytes, dstY; + CUmemorytype dstMemoryType; + void *dstHost; + CUdeviceptr dstDevice; + CUarray dstArray; + unsigned int dstPitch; + + unsigned int WidthInBytes; + unsigned int Height; + } CUDA_MEMCPY2D; + * \endcode + * where: + * - ::srcMemoryType and ::dstMemoryType specify the type of memory of the + * source and destination, respectively; ::CUmemorytype_enum is defined as: + * + * \code + typedef enum CUmemorytype_enum { + CU_MEMORYTYPE_HOST = 0x01, + CU_MEMORYTYPE_DEVICE = 0x02, + CU_MEMORYTYPE_ARRAY = 0x03, + CU_MEMORYTYPE_UNIFIED = 0x04 + } CUmemorytype; + * \endcode + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::srcDevice and ::srcPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::srcArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_HOST, ::srcHost and ::srcPitch + * specify the (host) base address of the source data and the bytes per row to + * apply. ::srcArray is ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_DEVICE, ::srcDevice and ::srcPitch + * specify the (device) base address of the source data and the bytes per row + * to apply. ::srcArray is ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_ARRAY, ::srcArray specifies the + * handle of the source data. ::srcHost, ::srcDevice and ::srcPitch are + * ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_HOST, ::dstHost and ::dstPitch + * specify the (host) base address of the destination data and the bytes per + * row to apply. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::dstDevice and ::dstPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::dstArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_DEVICE, ::dstDevice and ::dstPitch + * specify the (device) base address of the destination data and the bytes per + * row to apply. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_ARRAY, ::dstArray specifies the + * handle of the destination data. ::dstHost, ::dstDevice and ::dstPitch are + * ignored. + * + * - ::srcXInBytes and ::srcY specify the base address of the source data for + * the copy. + * + * \par + * For host pointers, the starting address is + * \code + void* Start = (void*)((char*)srcHost+srcY*srcPitch + srcXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr Start = srcDevice+srcY*srcPitch+srcXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::srcXInBytes must be evenly divisible by the array + * element size. + * + * - ::dstXInBytes and ::dstY specify the base address of the destination data + * for the copy. + * + * \par + * For host pointers, the base address is + * \code + void* dstStart = (void*)((char*)dstHost+dstY*dstPitch + dstXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr dstStart = dstDevice+dstY*dstPitch+dstXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::dstXInBytes must be evenly divisible by the array + * element size. + * + * - ::WidthInBytes and ::Height specify the width (in bytes) and height of + * the 2D copy being performed. + * - If specified, ::srcPitch must be greater than or equal to ::WidthInBytes + + * ::srcXInBytes, and ::dstPitch must be greater than or equal to + * ::WidthInBytes + dstXInBytes. + * + * \par + * ::cuMemcpy2D() returns an error if any pitch is greater than the maximum + * allowed (::CU_DEVICE_ATTRIBUTE_MAX_PITCH). ::cuMemAllocPitch() passes back + * pitches that always work with ::cuMemcpy2D(). On intra-device memory copies + * (device to device, CUDA array to device, CUDA array to CUDA array), + * ::cuMemcpy2D() may fail for pitches not computed by ::cuMemAllocPitch(). + * ::cuMemcpy2DUnaligned() does not have this restriction, but may run + * significantly slower in the cases where ::cuMemcpy2D() would have returned + * an error code. + * + * \param pCopy - Parameters for the memory copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy2D, + * ::cudaMemcpy2DToArray, + * ::cudaMemcpy2DFromArray + */ +CUresult CUDAAPI cuMemcpy2D(const CUDA_MEMCPY2D *pCopy); + +/** + * \brief Copies memory for 2D arrays + * + * Perform a 2D memory copy according to the parameters specified in \p pCopy. + * The ::CUDA_MEMCPY2D structure is defined as: + * + * \code + typedef struct CUDA_MEMCPY2D_st { + unsigned int srcXInBytes, srcY; + CUmemorytype srcMemoryType; + const void *srcHost; + CUdeviceptr srcDevice; + CUarray srcArray; + unsigned int srcPitch; + unsigned int dstXInBytes, dstY; + CUmemorytype dstMemoryType; + void *dstHost; + CUdeviceptr dstDevice; + CUarray dstArray; + unsigned int dstPitch; + unsigned int WidthInBytes; + unsigned int Height; + } CUDA_MEMCPY2D; + * \endcode + * where: + * - ::srcMemoryType and ::dstMemoryType specify the type of memory of the + * source and destination, respectively; ::CUmemorytype_enum is defined as: + * + * \code + typedef enum CUmemorytype_enum { + CU_MEMORYTYPE_HOST = 0x01, + CU_MEMORYTYPE_DEVICE = 0x02, + CU_MEMORYTYPE_ARRAY = 0x03, + CU_MEMORYTYPE_UNIFIED = 0x04 + } CUmemorytype; + * \endcode + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::srcDevice and ::srcPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::srcArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_HOST, ::srcHost and ::srcPitch + * specify the (host) base address of the source data and the bytes per row to + * apply. ::srcArray is ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_DEVICE, ::srcDevice and ::srcPitch + * specify the (device) base address of the source data and the bytes per row + * to apply. ::srcArray is ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_ARRAY, ::srcArray specifies the + * handle of the source data. ::srcHost, ::srcDevice and ::srcPitch are + * ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::dstDevice and ::dstPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::dstArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_HOST, ::dstHost and ::dstPitch + * specify the (host) base address of the destination data and the bytes per + * row to apply. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_DEVICE, ::dstDevice and ::dstPitch + * specify the (device) base address of the destination data and the bytes per + * row to apply. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_ARRAY, ::dstArray specifies the + * handle of the destination data. ::dstHost, ::dstDevice and ::dstPitch are + * ignored. + * + * - ::srcXInBytes and ::srcY specify the base address of the source data for + * the copy. + * + * \par + * For host pointers, the starting address is + * \code + void* Start = (void*)((char*)srcHost+srcY*srcPitch + srcXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr Start = srcDevice+srcY*srcPitch+srcXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::srcXInBytes must be evenly divisible by the array + * element size. + * + * - ::dstXInBytes and ::dstY specify the base address of the destination data + * for the copy. + * + * \par + * For host pointers, the base address is + * \code + void* dstStart = (void*)((char*)dstHost+dstY*dstPitch + dstXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr dstStart = dstDevice+dstY*dstPitch+dstXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::dstXInBytes must be evenly divisible by the array + * element size. + * + * - ::WidthInBytes and ::Height specify the width (in bytes) and height of + * the 2D copy being performed. + * - If specified, ::srcPitch must be greater than or equal to ::WidthInBytes + + * ::srcXInBytes, and ::dstPitch must be greater than or equal to + * ::WidthInBytes + dstXInBytes. + * + * \par + * ::cuMemcpy2D() returns an error if any pitch is greater than the maximum + * allowed (::CU_DEVICE_ATTRIBUTE_MAX_PITCH). ::cuMemAllocPitch() passes back + * pitches that always work with ::cuMemcpy2D(). On intra-device memory copies + * (device to device, CUDA array to device, CUDA array to CUDA array), + * ::cuMemcpy2D() may fail for pitches not computed by ::cuMemAllocPitch(). + * ::cuMemcpy2DUnaligned() does not have this restriction, but may run + * significantly slower in the cases where ::cuMemcpy2D() would have returned + * an error code. + * + * \param pCopy - Parameters for the memory copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy2D, + * ::cudaMemcpy2DToArray, + * ::cudaMemcpy2DFromArray + */ +CUresult CUDAAPI cuMemcpy2DUnaligned(const CUDA_MEMCPY2D *pCopy); + +/** + * \brief Copies memory for 3D arrays + * + * Perform a 3D memory copy according to the parameters specified in + * \p pCopy. The ::CUDA_MEMCPY3D structure is defined as: + * + * \code + typedef struct CUDA_MEMCPY3D_st { + + unsigned int srcXInBytes, srcY, srcZ; + unsigned int srcLOD; + CUmemorytype srcMemoryType; + const void *srcHost; + CUdeviceptr srcDevice; + CUarray srcArray; + unsigned int srcPitch; // ignored when src is array + unsigned int srcHeight; // ignored when src is array; may be 0 if Depth==1 + + unsigned int dstXInBytes, dstY, dstZ; + unsigned int dstLOD; + CUmemorytype dstMemoryType; + void *dstHost; + CUdeviceptr dstDevice; + CUarray dstArray; + unsigned int dstPitch; // ignored when dst is array + unsigned int dstHeight; // ignored when dst is array; may be 0 if Depth==1 + + unsigned int WidthInBytes; + unsigned int Height; + unsigned int Depth; + } CUDA_MEMCPY3D; + * \endcode + * where: + * - ::srcMemoryType and ::dstMemoryType specify the type of memory of the + * source and destination, respectively; ::CUmemorytype_enum is defined as: + * + * \code + typedef enum CUmemorytype_enum { + CU_MEMORYTYPE_HOST = 0x01, + CU_MEMORYTYPE_DEVICE = 0x02, + CU_MEMORYTYPE_ARRAY = 0x03, + CU_MEMORYTYPE_UNIFIED = 0x04 + } CUmemorytype; + * \endcode + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::srcDevice and ::srcPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::srcArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_HOST, ::srcHost, ::srcPitch and + * ::srcHeight specify the (host) base address of the source data, the bytes + * per row, and the height of each 2D slice of the 3D array. ::srcArray is + * ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_DEVICE, ::srcDevice, ::srcPitch and + * ::srcHeight specify the (device) base address of the source data, the bytes + * per row, and the height of each 2D slice of the 3D array. ::srcArray is + * ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_ARRAY, ::srcArray specifies the + * handle of the source data. ::srcHost, ::srcDevice, ::srcPitch and + * ::srcHeight are ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::dstDevice and ::dstPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::dstArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_HOST, ::dstHost and ::dstPitch + * specify the (host) base address of the destination data, the bytes per row, + * and the height of each 2D slice of the 3D array. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_DEVICE, ::dstDevice and ::dstPitch + * specify the (device) base address of the destination data, the bytes per + * row, and the height of each 2D slice of the 3D array. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_ARRAY, ::dstArray specifies the + * handle of the destination data. ::dstHost, ::dstDevice, ::dstPitch and + * ::dstHeight are ignored. + * + * - ::srcXInBytes, ::srcY and ::srcZ specify the base address of the source + * data for the copy. + * + * \par + * For host pointers, the starting address is + * \code + void* Start = (void*)((char*)srcHost+(srcZ*srcHeight+srcY)*srcPitch + srcXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr Start = srcDevice+(srcZ*srcHeight+srcY)*srcPitch+srcXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::srcXInBytes must be evenly divisible by the array + * element size. + * + * - dstXInBytes, ::dstY and ::dstZ specify the base address of the + * destination data for the copy. + * + * \par + * For host pointers, the base address is + * \code + void* dstStart = (void*)((char*)dstHost+(dstZ*dstHeight+dstY)*dstPitch + dstXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr dstStart = dstDevice+(dstZ*dstHeight+dstY)*dstPitch+dstXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::dstXInBytes must be evenly divisible by the array + * element size. + * + * - ::WidthInBytes, ::Height and ::Depth specify the width (in bytes), height + * and depth of the 3D copy being performed. + * - If specified, ::srcPitch must be greater than or equal to ::WidthInBytes + + * ::srcXInBytes, and ::dstPitch must be greater than or equal to + * ::WidthInBytes + dstXInBytes. + * - If specified, ::srcHeight must be greater than or equal to ::Height + + * ::srcY, and ::dstHeight must be greater than or equal to ::Height + ::dstY. + * + * \par + * ::cuMemcpy3D() returns an error if any pitch is greater than the maximum + * allowed (::CU_DEVICE_ATTRIBUTE_MAX_PITCH). + * + * The ::srcLOD and ::dstLOD members of the ::CUDA_MEMCPY3D structure must be + * set to 0. + * + * \param pCopy - Parameters for the memory copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy3D + */ +CUresult CUDAAPI cuMemcpy3D(const CUDA_MEMCPY3D *pCopy); + +/** + * \brief Copies memory between contexts + * + * Perform a 3D memory copy according to the parameters specified in + * \p pCopy. See the definition of the ::CUDA_MEMCPY3D_PEER structure + * for documentation of its parameters. + * + * \param pCopy - Parameters for the memory copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuMemcpyDtoD, ::cuMemcpyPeer, ::cuMemcpyDtoDAsync, ::cuMemcpyPeerAsync, + * ::cuMemcpy3DPeerAsync, + * ::cudaMemcpy3DPeer + */ +CUresult CUDAAPI cuMemcpy3DPeer(const CUDA_MEMCPY3D_PEER *pCopy); + +/** + * \brief Copies memory asynchronously + * + * Copies data between two pointers. + * \p dst and \p src are base pointers of the destination and source, respectively. + * \p ByteCount specifies the number of bytes to copy. + * Note that this function infers the type of the transfer (host to host, host to + * device, device to device, or device to host) from the pointer values. This + * function is only allowed in contexts which support unified addressing. + * + * \param dst - Destination unified virtual address space pointer + * \param src - Source unified virtual address space pointer + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpyAsync, + * ::cudaMemcpyToSymbolAsync, + * ::cudaMemcpyFromSymbolAsync + */ +CUresult CUDAAPI cuMemcpyAsync(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies device memory between two contexts asynchronously. + * + * Copies from device memory in one context to device memory in another + * context. \p dstDevice is the base device pointer of the destination memory + * and \p dstContext is the destination context. \p srcDevice is the base + * device pointer of the source memory and \p srcContext is the source pointer. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstDevice - Destination device pointer + * \param dstContext - Destination context + * \param srcDevice - Source device pointer + * \param srcContext - Source context + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemcpyDtoD, ::cuMemcpyPeer, ::cuMemcpy3DPeer, ::cuMemcpyDtoDAsync, + * ::cuMemcpy3DPeerAsync, + * ::cudaMemcpyPeerAsync + */ +CUresult CUDAAPI cuMemcpyPeerAsync(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies memory from Host to Device + * + * Copies from host memory to device memory. \p dstDevice and \p srcHost are + * the base addresses of the destination and source, respectively. \p ByteCount + * specifies the number of bytes to copy. + * + * \param dstDevice - Destination device pointer + * \param srcHost - Source host pointer + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpyAsync, + * ::cudaMemcpyToSymbolAsync + */ +CUresult CUDAAPI cuMemcpyHtoDAsync(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies memory from Device to Host + * + * Copies from device to host memory. \p dstHost and \p srcDevice specify the + * base pointers of the destination and source, respectively. \p ByteCount + * specifies the number of bytes to copy. + * + * \param dstHost - Destination host pointer + * \param srcDevice - Source device pointer + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpyAsync, + * ::cudaMemcpyFromSymbolAsync + */ +CUresult CUDAAPI cuMemcpyDtoHAsync(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies memory from Device to Device + * + * Copies from device memory to device memory. \p dstDevice and \p srcDevice + * are the base pointers of the destination and source, respectively. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstDevice - Destination device pointer + * \param srcDevice - Source device pointer + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpyAsync, + * ::cudaMemcpyToSymbolAsync, + * ::cudaMemcpyFromSymbolAsync + */ +CUresult CUDAAPI cuMemcpyDtoDAsync(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies memory from Host to Array + * + * Copies from host memory to a 1D CUDA array. \p dstArray and \p dstOffset + * specify the CUDA array handle and starting offset in bytes of the + * destination data. \p srcHost specifies the base address of the source. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstArray - Destination array + * \param dstOffset - Offset in bytes of destination array + * \param srcHost - Source host pointer + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpyToArrayAsync + */ +CUresult CUDAAPI cuMemcpyHtoAAsync(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies memory from Array to Host + * + * Copies from one 1D CUDA array to host memory. \p dstHost specifies the base + * pointer of the destination. \p srcArray and \p srcOffset specify the CUDA + * array handle and starting offset in bytes of the source data. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstHost - Destination pointer + * \param srcArray - Source array + * \param srcOffset - Offset in bytes of source array + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpyFromArrayAsync + */ +CUresult CUDAAPI cuMemcpyAtoHAsync(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies memory for 2D arrays + * + * Perform a 2D memory copy according to the parameters specified in \p pCopy. + * The ::CUDA_MEMCPY2D structure is defined as: + * + * \code + typedef struct CUDA_MEMCPY2D_st { + unsigned int srcXInBytes, srcY; + CUmemorytype srcMemoryType; + const void *srcHost; + CUdeviceptr srcDevice; + CUarray srcArray; + unsigned int srcPitch; + unsigned int dstXInBytes, dstY; + CUmemorytype dstMemoryType; + void *dstHost; + CUdeviceptr dstDevice; + CUarray dstArray; + unsigned int dstPitch; + unsigned int WidthInBytes; + unsigned int Height; + } CUDA_MEMCPY2D; + * \endcode + * where: + * - ::srcMemoryType and ::dstMemoryType specify the type of memory of the + * source and destination, respectively; ::CUmemorytype_enum is defined as: + * + * \code + typedef enum CUmemorytype_enum { + CU_MEMORYTYPE_HOST = 0x01, + CU_MEMORYTYPE_DEVICE = 0x02, + CU_MEMORYTYPE_ARRAY = 0x03, + CU_MEMORYTYPE_UNIFIED = 0x04 + } CUmemorytype; + * \endcode + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_HOST, ::srcHost and ::srcPitch + * specify the (host) base address of the source data and the bytes per row to + * apply. ::srcArray is ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::srcDevice and ::srcPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::srcArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_DEVICE, ::srcDevice and ::srcPitch + * specify the (device) base address of the source data and the bytes per row + * to apply. ::srcArray is ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_ARRAY, ::srcArray specifies the + * handle of the source data. ::srcHost, ::srcDevice and ::srcPitch are + * ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::dstDevice and ::dstPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::dstArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_HOST, ::dstHost and ::dstPitch + * specify the (host) base address of the destination data and the bytes per + * row to apply. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_DEVICE, ::dstDevice and ::dstPitch + * specify the (device) base address of the destination data and the bytes per + * row to apply. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_ARRAY, ::dstArray specifies the + * handle of the destination data. ::dstHost, ::dstDevice and ::dstPitch are + * ignored. + * + * - ::srcXInBytes and ::srcY specify the base address of the source data for + * the copy. + * + * \par + * For host pointers, the starting address is + * \code + void* Start = (void*)((char*)srcHost+srcY*srcPitch + srcXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr Start = srcDevice+srcY*srcPitch+srcXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::srcXInBytes must be evenly divisible by the array + * element size. + * + * - ::dstXInBytes and ::dstY specify the base address of the destination data + * for the copy. + * + * \par + * For host pointers, the base address is + * \code + void* dstStart = (void*)((char*)dstHost+dstY*dstPitch + dstXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr dstStart = dstDevice+dstY*dstPitch+dstXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::dstXInBytes must be evenly divisible by the array + * element size. + * + * - ::WidthInBytes and ::Height specify the width (in bytes) and height of + * the 2D copy being performed. + * - If specified, ::srcPitch must be greater than or equal to ::WidthInBytes + + * ::srcXInBytes, and ::dstPitch must be greater than or equal to + * ::WidthInBytes + dstXInBytes. + * - If specified, ::srcPitch must be greater than or equal to ::WidthInBytes + + * ::srcXInBytes, and ::dstPitch must be greater than or equal to + * ::WidthInBytes + dstXInBytes. + * - If specified, ::srcHeight must be greater than or equal to ::Height + + * ::srcY, and ::dstHeight must be greater than or equal to ::Height + ::dstY. + * + * \par + * ::cuMemcpy2DAsync() returns an error if any pitch is greater than the maximum + * allowed (::CU_DEVICE_ATTRIBUTE_MAX_PITCH). ::cuMemAllocPitch() passes back + * pitches that always work with ::cuMemcpy2D(). On intra-device memory copies + * (device to device, CUDA array to device, CUDA array to CUDA array), + * ::cuMemcpy2DAsync() may fail for pitches not computed by ::cuMemAllocPitch(). + * + * \param pCopy - Parameters for the memory copy + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpy2DAsync, + * ::cudaMemcpy2DToArrayAsync, + * ::cudaMemcpy2DFromArrayAsync + */ +CUresult CUDAAPI cuMemcpy2DAsync(const CUDA_MEMCPY2D *pCopy, CUstream hStream); + +/** + * \brief Copies memory for 3D arrays + * + * Perform a 3D memory copy according to the parameters specified in + * \p pCopy. The ::CUDA_MEMCPY3D structure is defined as: + * + * \code + typedef struct CUDA_MEMCPY3D_st { + + unsigned int srcXInBytes, srcY, srcZ; + unsigned int srcLOD; + CUmemorytype srcMemoryType; + const void *srcHost; + CUdeviceptr srcDevice; + CUarray srcArray; + unsigned int srcPitch; // ignored when src is array + unsigned int srcHeight; // ignored when src is array; may be 0 if Depth==1 + + unsigned int dstXInBytes, dstY, dstZ; + unsigned int dstLOD; + CUmemorytype dstMemoryType; + void *dstHost; + CUdeviceptr dstDevice; + CUarray dstArray; + unsigned int dstPitch; // ignored when dst is array + unsigned int dstHeight; // ignored when dst is array; may be 0 if Depth==1 + + unsigned int WidthInBytes; + unsigned int Height; + unsigned int Depth; + } CUDA_MEMCPY3D; + * \endcode + * where: + * - ::srcMemoryType and ::dstMemoryType specify the type of memory of the + * source and destination, respectively; ::CUmemorytype_enum is defined as: + * + * \code + typedef enum CUmemorytype_enum { + CU_MEMORYTYPE_HOST = 0x01, + CU_MEMORYTYPE_DEVICE = 0x02, + CU_MEMORYTYPE_ARRAY = 0x03, + CU_MEMORYTYPE_UNIFIED = 0x04 + } CUmemorytype; + * \endcode + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::srcDevice and ::srcPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::srcArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_HOST, ::srcHost, ::srcPitch and + * ::srcHeight specify the (host) base address of the source data, the bytes + * per row, and the height of each 2D slice of the 3D array. ::srcArray is + * ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_DEVICE, ::srcDevice, ::srcPitch and + * ::srcHeight specify the (device) base address of the source data, the bytes + * per row, and the height of each 2D slice of the 3D array. ::srcArray is + * ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_ARRAY, ::srcArray specifies the + * handle of the source data. ::srcHost, ::srcDevice, ::srcPitch and + * ::srcHeight are ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::dstDevice and ::dstPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::dstArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_HOST, ::dstHost and ::dstPitch + * specify the (host) base address of the destination data, the bytes per row, + * and the height of each 2D slice of the 3D array. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_DEVICE, ::dstDevice and ::dstPitch + * specify the (device) base address of the destination data, the bytes per + * row, and the height of each 2D slice of the 3D array. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_ARRAY, ::dstArray specifies the + * handle of the destination data. ::dstHost, ::dstDevice, ::dstPitch and + * ::dstHeight are ignored. + * + * - ::srcXInBytes, ::srcY and ::srcZ specify the base address of the source + * data for the copy. + * + * \par + * For host pointers, the starting address is + * \code + void* Start = (void*)((char*)srcHost+(srcZ*srcHeight+srcY)*srcPitch + srcXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr Start = srcDevice+(srcZ*srcHeight+srcY)*srcPitch+srcXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::srcXInBytes must be evenly divisible by the array + * element size. + * + * - dstXInBytes, ::dstY and ::dstZ specify the base address of the + * destination data for the copy. + * + * \par + * For host pointers, the base address is + * \code + void* dstStart = (void*)((char*)dstHost+(dstZ*dstHeight+dstY)*dstPitch + dstXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr dstStart = dstDevice+(dstZ*dstHeight+dstY)*dstPitch+dstXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::dstXInBytes must be evenly divisible by the array + * element size. + * + * - ::WidthInBytes, ::Height and ::Depth specify the width (in bytes), height + * and depth of the 3D copy being performed. + * - If specified, ::srcPitch must be greater than or equal to ::WidthInBytes + + * ::srcXInBytes, and ::dstPitch must be greater than or equal to + * ::WidthInBytes + dstXInBytes. + * - If specified, ::srcHeight must be greater than or equal to ::Height + + * ::srcY, and ::dstHeight must be greater than or equal to ::Height + ::dstY. + * + * \par + * ::cuMemcpy3DAsync() returns an error if any pitch is greater than the maximum + * allowed (::CU_DEVICE_ATTRIBUTE_MAX_PITCH). + * + * The ::srcLOD and ::dstLOD members of the ::CUDA_MEMCPY3D structure must be + * set to 0. + * + * \param pCopy - Parameters for the memory copy + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpy3DAsync + */ +CUresult CUDAAPI cuMemcpy3DAsync(const CUDA_MEMCPY3D *pCopy, CUstream hStream); + +/** + * \brief Copies memory between contexts asynchronously. + * + * Perform a 3D memory copy according to the parameters specified in + * \p pCopy. See the definition of the ::CUDA_MEMCPY3D_PEER structure + * for documentation of its parameters. + * + * \param pCopy - Parameters for the memory copy + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemcpyDtoD, ::cuMemcpyPeer, ::cuMemcpyDtoDAsync, ::cuMemcpyPeerAsync, + * ::cuMemcpy3DPeerAsync, + * ::cudaMemcpy3DPeerAsync + */ +CUresult CUDAAPI cuMemcpy3DPeerAsync(const CUDA_MEMCPY3D_PEER *pCopy, CUstream hStream); + +/** + * \brief Initializes device memory + * + * Sets the memory range of \p N 8-bit values to the specified value + * \p uc. + * + * \param dstDevice - Destination device pointer + * \param uc - Value to set + * \param N - Number of elements + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset + */ +CUresult CUDAAPI cuMemsetD8(CUdeviceptr dstDevice, unsigned char uc, size_t N); + +/** + * \brief Initializes device memory + * + * Sets the memory range of \p N 16-bit values to the specified value + * \p us. The \p dstDevice pointer must be two byte aligned. + * + * \param dstDevice - Destination device pointer + * \param us - Value to set + * \param N - Number of elements + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset + */ +CUresult CUDAAPI cuMemsetD16(CUdeviceptr dstDevice, unsigned short us, size_t N); + +/** + * \brief Initializes device memory + * + * Sets the memory range of \p N 32-bit values to the specified value + * \p ui. The \p dstDevice pointer must be four byte aligned. + * + * \param dstDevice - Destination device pointer + * \param ui - Value to set + * \param N - Number of elements + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32Async, + * ::cudaMemset + */ +CUresult CUDAAPI cuMemsetD32(CUdeviceptr dstDevice, unsigned int ui, size_t N); + +/** + * \brief Initializes device memory + * + * Sets the 2D memory range of \p Width 8-bit values to the specified value + * \p uc. \p Height specifies the number of rows to set, and \p dstPitch + * specifies the number of bytes between each row. This function performs + * fastest when the pitch is one that has been passed back by + * ::cuMemAllocPitch(). + * + * \param dstDevice - Destination device pointer + * \param dstPitch - Pitch of destination device pointer(Unused if \p Height is 1) + * \param uc - Value to set + * \param Width - Width of row + * \param Height - Number of rows + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset2D + */ +CUresult CUDAAPI cuMemsetD2D8(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height); + +/** + * \brief Initializes device memory + * + * Sets the 2D memory range of \p Width 16-bit values to the specified value + * \p us. \p Height specifies the number of rows to set, and \p dstPitch + * specifies the number of bytes between each row. The \p dstDevice pointer + * and \p dstPitch offset must be two byte aligned. This function performs + * fastest when the pitch is one that has been passed back by + * ::cuMemAllocPitch(). + * + * \param dstDevice - Destination device pointer + * \param dstPitch - Pitch of destination device pointer(Unused if \p Height is 1) + * \param us - Value to set + * \param Width - Width of row + * \param Height - Number of rows + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset2D + */ +CUresult CUDAAPI cuMemsetD2D16(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height); + +/** + * \brief Initializes device memory + * + * Sets the 2D memory range of \p Width 32-bit values to the specified value + * \p ui. \p Height specifies the number of rows to set, and \p dstPitch + * specifies the number of bytes between each row. The \p dstDevice pointer + * and \p dstPitch offset must be four byte aligned. This function performs + * fastest when the pitch is one that has been passed back by + * ::cuMemAllocPitch(). + * + * \param dstDevice - Destination device pointer + * \param dstPitch - Pitch of destination device pointer(Unused if \p Height is 1) + * \param ui - Value to set + * \param Width - Width of row + * \param Height - Number of rows + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset2D + */ +CUresult CUDAAPI cuMemsetD2D32(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height); + +/** + * \brief Sets device memory + * + * Sets the memory range of \p N 8-bit values to the specified value + * \p uc. + * + * \param dstDevice - Destination device pointer + * \param uc - Value to set + * \param N - Number of elements + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemsetAsync + */ +CUresult CUDAAPI cuMemsetD8Async(CUdeviceptr dstDevice, unsigned char uc, size_t N, CUstream hStream); + +/** + * \brief Sets device memory + * + * Sets the memory range of \p N 16-bit values to the specified value + * \p us. The \p dstDevice pointer must be two byte aligned. + * + * \param dstDevice - Destination device pointer + * \param us - Value to set + * \param N - Number of elements + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemsetAsync + */ +CUresult CUDAAPI cuMemsetD16Async(CUdeviceptr dstDevice, unsigned short us, size_t N, CUstream hStream); + +/** + * \brief Sets device memory + * + * Sets the memory range of \p N 32-bit values to the specified value + * \p ui. The \p dstDevice pointer must be four byte aligned. + * + * \param dstDevice - Destination device pointer + * \param ui - Value to set + * \param N - Number of elements + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, ::cuMemsetD32, + * ::cudaMemsetAsync + */ +CUresult CUDAAPI cuMemsetD32Async(CUdeviceptr dstDevice, unsigned int ui, size_t N, CUstream hStream); + +/** + * \brief Sets device memory + * + * Sets the 2D memory range of \p Width 8-bit values to the specified value + * \p uc. \p Height specifies the number of rows to set, and \p dstPitch + * specifies the number of bytes between each row. This function performs + * fastest when the pitch is one that has been passed back by + * ::cuMemAllocPitch(). + * + * \param dstDevice - Destination device pointer + * \param dstPitch - Pitch of destination device pointer(Unused if \p Height is 1) + * \param uc - Value to set + * \param Width - Width of row + * \param Height - Number of rows + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset2DAsync + */ +CUresult CUDAAPI cuMemsetD2D8Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height, CUstream hStream); + +/** + * \brief Sets device memory + * + * Sets the 2D memory range of \p Width 16-bit values to the specified value + * \p us. \p Height specifies the number of rows to set, and \p dstPitch + * specifies the number of bytes between each row. The \p dstDevice pointer + * and \p dstPitch offset must be two byte aligned. This function performs + * fastest when the pitch is one that has been passed back by + * ::cuMemAllocPitch(). + * + * \param dstDevice - Destination device pointer + * \param dstPitch - Pitch of destination device pointer(Unused if \p Height is 1) + * \param us - Value to set + * \param Width - Width of row + * \param Height - Number of rows + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset2DAsync + */ +CUresult CUDAAPI cuMemsetD2D16Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height, CUstream hStream); + +/** + * \brief Sets device memory + * + * Sets the 2D memory range of \p Width 32-bit values to the specified value + * \p ui. \p Height specifies the number of rows to set, and \p dstPitch + * specifies the number of bytes between each row. The \p dstDevice pointer + * and \p dstPitch offset must be four byte aligned. This function performs + * fastest when the pitch is one that has been passed back by + * ::cuMemAllocPitch(). + * + * \param dstDevice - Destination device pointer + * \param dstPitch - Pitch of destination device pointer(Unused if \p Height is 1) + * \param ui - Value to set + * \param Width - Width of row + * \param Height - Number of rows + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset2DAsync + */ +CUresult CUDAAPI cuMemsetD2D32Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height, CUstream hStream); + +/** + * \brief Creates a 1D or 2D CUDA array + * + * Creates a CUDA array according to the ::CUDA_ARRAY_DESCRIPTOR structure + * \p pAllocateArray and returns a handle to the new CUDA array in \p *pHandle. + * The ::CUDA_ARRAY_DESCRIPTOR is defined as: + * + * \code + typedef struct { + unsigned int Width; + unsigned int Height; + CUarray_format Format; + unsigned int NumChannels; + } CUDA_ARRAY_DESCRIPTOR; + * \endcode + * where: + * + * - \p Width, and \p Height are the width, and height of the CUDA array (in + * elements); the CUDA array is one-dimensional if height is 0, two-dimensional + * otherwise; + * - ::Format specifies the format of the elements; ::CUarray_format is + * defined as: + * \code + typedef enum CUarray_format_enum { + CU_AD_FORMAT_UNSIGNED_INT8 = 0x01, + CU_AD_FORMAT_UNSIGNED_INT16 = 0x02, + CU_AD_FORMAT_UNSIGNED_INT32 = 0x03, + CU_AD_FORMAT_SIGNED_INT8 = 0x08, + CU_AD_FORMAT_SIGNED_INT16 = 0x09, + CU_AD_FORMAT_SIGNED_INT32 = 0x0a, + CU_AD_FORMAT_HALF = 0x10, + CU_AD_FORMAT_FLOAT = 0x20 + } CUarray_format; + * \endcode + * - \p NumChannels specifies the number of packed components per CUDA array + * element; it may be 1, 2, or 4; + * + * Here are examples of CUDA array descriptions: + * + * Description for a CUDA array of 2048 floats: + * \code + CUDA_ARRAY_DESCRIPTOR desc; + desc.Format = CU_AD_FORMAT_FLOAT; + desc.NumChannels = 1; + desc.Width = 2048; + desc.Height = 1; + * \endcode + * + * Description for a 64 x 64 CUDA array of floats: + * \code + CUDA_ARRAY_DESCRIPTOR desc; + desc.Format = CU_AD_FORMAT_FLOAT; + desc.NumChannels = 1; + desc.Width = 64; + desc.Height = 64; + * \endcode + * + * Description for a \p width x \p height CUDA array of 64-bit, 4x16-bit + * float16's: + * \code + CUDA_ARRAY_DESCRIPTOR desc; + desc.Format = CU_AD_FORMAT_HALF; + desc.NumChannels = 4; + desc.Width = width; + desc.Height = height; + * \endcode + * + * Description for a \p width x \p height CUDA array of 16-bit elements, each + * of which is two 8-bit unsigned chars: + * \code + CUDA_ARRAY_DESCRIPTOR arrayDesc; + desc.Format = CU_AD_FORMAT_UNSIGNED_INT8; + desc.NumChannels = 2; + desc.Width = width; + desc.Height = height; + * \endcode + * + * \param pHandle - Returned array + * \param pAllocateArray - Array descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMallocArray + */ +CUresult CUDAAPI cuArrayCreate(CUarray *pHandle, const CUDA_ARRAY_DESCRIPTOR *pAllocateArray); + +/** + * \brief Get a 1D or 2D CUDA array descriptor + * + * Returns in \p *pArrayDescriptor a descriptor containing information on the + * format and dimensions of the CUDA array \p hArray. It is useful for + * subroutines that have been passed a CUDA array, but need to know the CUDA + * array parameters for validation or other purposes. + * + * \param pArrayDescriptor - Returned array descriptor + * \param hArray - Array to get descriptor of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaArrayGetInfo + */ +CUresult CUDAAPI cuArrayGetDescriptor(CUDA_ARRAY_DESCRIPTOR *pArrayDescriptor, CUarray hArray); + +/** + * \brief Returns the layout properties of a sparse CUDA array + * + * Returns the layout properties of a sparse CUDA array in \p sparseProperties + * If the CUDA array is not allocated with flag ::CUDA_ARRAY3D_SPARSE + * ::CUDA_ERROR_INVALID_VALUE will be returned. + * + * If the returned value in ::CUDA_ARRAY_SPARSE_PROPERTIES::flags contains ::CU_ARRAY_SPARSE_PROPERTIES_SINGLE_MIPTAIL, + * then ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailSize represents the total size of the array. Otherwise, it will be zero. + * Also, the returned value in ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailFirstLevel is always zero. + * Note that the \p array must have been allocated using ::cuArrayCreate or ::cuArray3DCreate. For CUDA arrays obtained + * using ::cuMipmappedArrayGetLevel, ::CUDA_ERROR_INVALID_VALUE will be returned. Instead, ::cuMipmappedArrayGetSparseProperties + * must be used to obtain the sparse properties of the entire CUDA mipmapped array to which \p array belongs to. + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_INVALID_VALUE + * + * \param[out] sparseProperties - Pointer to ::CUDA_ARRAY_SPARSE_PROPERTIES + * \param[in] array - CUDA array to get the sparse properties of + * \sa ::cuMipmappedArrayGetSparseProperties, ::cuMemMapArrayAsync + */ +CUresult CUDAAPI cuArrayGetSparseProperties(CUDA_ARRAY_SPARSE_PROPERTIES *sparseProperties, CUarray array); + +/** + * \brief Returns the layout properties of a sparse CUDA mipmapped array + * + * Returns the sparse array layout properties in \p sparseProperties + * If the CUDA mipmapped array is not allocated with flag ::CUDA_ARRAY3D_SPARSE + * ::CUDA_ERROR_INVALID_VALUE will be returned. + * + * For non-layered CUDA mipmapped arrays, ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailSize returns the + * size of the mip tail region. The mip tail region includes all mip levels whose width, height or depth + * is less than that of the tile. + * For layered CUDA mipmapped arrays, if ::CUDA_ARRAY_SPARSE_PROPERTIES::flags contains ::CU_ARRAY_SPARSE_PROPERTIES_SINGLE_MIPTAIL, + * then ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailSize specifies the size of the mip tail of all layers combined. + * Otherwise, ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailSize specifies mip tail size per layer. + * The returned value of ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailFirstLevel is valid only if ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailSize is non-zero. + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_INVALID_VALUE + * + * \param[out] sparseProperties - Pointer to ::CUDA_ARRAY_SPARSE_PROPERTIES + * \param[in] mipmap - CUDA mipmapped array to get the sparse properties of + * \sa ::cuArrayGetSparseProperties, ::cuMemMapArrayAsync + */ +CUresult CUDAAPI cuMipmappedArrayGetSparseProperties(CUDA_ARRAY_SPARSE_PROPERTIES *sparseProperties, CUmipmappedArray mipmap); + +/** + * \brief Returns the memory requirements of a CUDA array + * + * Returns the memory requirements of a CUDA array in \p memoryRequirements + * If the CUDA array is not allocated with flag ::CUDA_ARRAY3D_DEFERRED_MAPPING + * ::CUDA_ERROR_INVALID_VALUE will be returned. + * + * The returned value in ::CUDA_ARRAY_MEMORY_REQUIREMENTS::size + * represents the total size of the CUDA array. + * The returned value in ::CUDA_ARRAY_MEMORY_REQUIREMENTS::alignment + * represents the alignment necessary for mapping the CUDA array. + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_INVALID_VALUE + * + * \param[out] memoryRequirements - Pointer to ::CUDA_ARRAY_MEMORY_REQUIREMENTS + * \param[in] array - CUDA array to get the memory requirements of + * \param[in] device - Device to get the memory requirements for + * \sa ::cuMipmappedArrayGetMemoryRequirements, ::cuMemMapArrayAsync + */ +CUresult CUDAAPI cuArrayGetMemoryRequirements(CUDA_ARRAY_MEMORY_REQUIREMENTS *memoryRequirements, CUarray array, CUdevice device); + +/** + * \brief Returns the memory requirements of a CUDA mipmapped array + * + * Returns the memory requirements of a CUDA mipmapped array in \p memoryRequirements + * If the CUDA mipmapped array is not allocated with flag ::CUDA_ARRAY3D_DEFERRED_MAPPING + * ::CUDA_ERROR_INVALID_VALUE will be returned. + * + * The returned value in ::CUDA_ARRAY_MEMORY_REQUIREMENTS::size + * represents the total size of the CUDA mipmapped array. + * The returned value in ::CUDA_ARRAY_MEMORY_REQUIREMENTS::alignment + * represents the alignment necessary for mapping the CUDA mipmapped + * array. + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_INVALID_VALUE + * + * \param[out] memoryRequirements - Pointer to ::CUDA_ARRAY_MEMORY_REQUIREMENTS + * \param[in] mipmap - CUDA mipmapped array to get the memory requirements of + * \param[in] device - Device to get the memory requirements for + * \sa ::cuArrayGetMemoryRequirements, ::cuMemMapArrayAsync + */ +CUresult CUDAAPI cuMipmappedArrayGetMemoryRequirements(CUDA_ARRAY_MEMORY_REQUIREMENTS *memoryRequirements, CUmipmappedArray mipmap, CUdevice device); + +/** + * \brief Gets a CUDA array plane from a CUDA array + * + * Returns in \p pPlaneArray a CUDA array that represents a single format plane + * of the CUDA array \p hArray. + * + * If \p planeIdx is greater than the maximum number of planes in this array or if the array does + * not have a multi-planar format e.g: ::CU_AD_FORMAT_NV12, then ::CUDA_ERROR_INVALID_VALUE is returned. + * + * Note that if the \p hArray has format ::CU_AD_FORMAT_NV12, then passing in 0 for \p planeIdx returns + * a CUDA array of the same size as \p hArray but with one channel and ::CU_AD_FORMAT_UNSIGNED_INT8 as its format. + * If 1 is passed for \p planeIdx, then the returned CUDA array has half the height and width + * of \p hArray with two channels and ::CU_AD_FORMAT_UNSIGNED_INT8 as its format. + * + * \param pPlaneArray - Returned CUDA array referenced by the \p planeIdx + * \param hArray - Multiplanar CUDA array + * \param planeIdx - Plane index + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa + * ::cuArrayCreate, + * ::cudaArrayGetPlane + */ +CUresult CUDAAPI cuArrayGetPlane(CUarray *pPlaneArray, CUarray hArray, unsigned int planeIdx); + +/** + * \brief Destroys a CUDA array + * + * Destroys the CUDA array \p hArray. + * + * \param hArray - Array to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_ARRAY_IS_MAPPED, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaFreeArray + */ +CUresult CUDAAPI cuArrayDestroy(CUarray hArray); + +/** + * \brief Creates a 3D CUDA array + * + * Creates a CUDA array according to the ::CUDA_ARRAY3D_DESCRIPTOR structure + * \p pAllocateArray and returns a handle to the new CUDA array in \p *pHandle. + * The ::CUDA_ARRAY3D_DESCRIPTOR is defined as: + * + * \code + typedef struct { + unsigned int Width; + unsigned int Height; + unsigned int Depth; + CUarray_format Format; + unsigned int NumChannels; + unsigned int Flags; + } CUDA_ARRAY3D_DESCRIPTOR; + * \endcode + * where: + * + * - \p Width, \p Height, and \p Depth are the width, height, and depth of the + * CUDA array (in elements); the following types of CUDA arrays can be allocated: + * - A 1D array is allocated if \p Height and \p Depth extents are both zero. + * - A 2D array is allocated if only \p Depth extent is zero. + * - A 3D array is allocated if all three extents are non-zero. + * - A 1D layered CUDA array is allocated if only \p Height is zero and the + * ::CUDA_ARRAY3D_LAYERED flag is set. Each layer is a 1D array. The number + * of layers is determined by the depth extent. + * - A 2D layered CUDA array is allocated if all three extents are non-zero and + * the ::CUDA_ARRAY3D_LAYERED flag is set. Each layer is a 2D array. The number + * of layers is determined by the depth extent. + * - A cubemap CUDA array is allocated if all three extents are non-zero and the + * ::CUDA_ARRAY3D_CUBEMAP flag is set. \p Width must be equal to \p Height, and + * \p Depth must be six. A cubemap is a special type of 2D layered CUDA array, + * where the six layers represent the six faces of a cube. The order of the six + * layers in memory is the same as that listed in ::CUarray_cubemap_face. + * - A cubemap layered CUDA array is allocated if all three extents are non-zero, + * and both, ::CUDA_ARRAY3D_CUBEMAP and ::CUDA_ARRAY3D_LAYERED flags are set. + * \p Width must be equal to \p Height, and \p Depth must be a multiple of six. + * A cubemap layered CUDA array is a special type of 2D layered CUDA array that + * consists of a collection of cubemaps. The first six layers represent the first + * cubemap, the next six layers form the second cubemap, and so on. + * + * - ::Format specifies the format of the elements; ::CUarray_format is + * defined as: + * \code + typedef enum CUarray_format_enum { + CU_AD_FORMAT_UNSIGNED_INT8 = 0x01, + CU_AD_FORMAT_UNSIGNED_INT16 = 0x02, + CU_AD_FORMAT_UNSIGNED_INT32 = 0x03, + CU_AD_FORMAT_SIGNED_INT8 = 0x08, + CU_AD_FORMAT_SIGNED_INT16 = 0x09, + CU_AD_FORMAT_SIGNED_INT32 = 0x0a, + CU_AD_FORMAT_HALF = 0x10, + CU_AD_FORMAT_FLOAT = 0x20 + } CUarray_format; + * \endcode + * + * - \p NumChannels specifies the number of packed components per CUDA array + * element; it may be 1, 2, or 4; + * + * - ::Flags may be set to + * - ::CUDA_ARRAY3D_LAYERED to enable creation of layered CUDA arrays. If this flag is set, + * \p Depth specifies the number of layers, not the depth of a 3D array. + * - ::CUDA_ARRAY3D_SURFACE_LDST to enable surface references to be bound to the CUDA array. + * If this flag is not set, ::cuSurfRefSetArray will fail when attempting to bind the CUDA array + * to a surface reference. + * - ::CUDA_ARRAY3D_CUBEMAP to enable creation of cubemaps. If this flag is set, \p Width must be + * equal to \p Height, and \p Depth must be six. If the ::CUDA_ARRAY3D_LAYERED flag is also set, + * then \p Depth must be a multiple of six. + * - ::CUDA_ARRAY3D_TEXTURE_GATHER to indicate that the CUDA array will be used for texture gather. + * Texture gather can only be performed on 2D CUDA arrays. + * + * \p Width, \p Height and \p Depth must meet certain size requirements as listed in the following table. + * All values are specified in elements. Note that for brevity's sake, the full name of the device attribute + * is not specified. For ex., TEXTURE1D_WIDTH refers to the device attribute + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_WIDTH. + * + * Note that 2D CUDA arrays have different size requirements if the ::CUDA_ARRAY3D_TEXTURE_GATHER flag + * is set. \p Width and \p Height must not be greater than ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_GATHER_WIDTH + * and ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_GATHER_HEIGHT respectively, in that case. + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + *
CUDA array typeValid extents that must always be met
{(width range in elements), (height range), + * (depth range)}
Valid extents with CUDA_ARRAY3D_SURFACE_LDST set
+ * {(width range in elements), (height range), (depth range)}
1D{ (1,TEXTURE1D_WIDTH), 0, 0 }{ (1,SURFACE1D_WIDTH), 0, 0 }
2D{ (1,TEXTURE2D_WIDTH), (1,TEXTURE2D_HEIGHT), 0 }{ (1,SURFACE2D_WIDTH), (1,SURFACE2D_HEIGHT), 0 }
3D{ (1,TEXTURE3D_WIDTH), (1,TEXTURE3D_HEIGHT), (1,TEXTURE3D_DEPTH) } + *
OR
{ (1,TEXTURE3D_WIDTH_ALTERNATE), (1,TEXTURE3D_HEIGHT_ALTERNATE), + * (1,TEXTURE3D_DEPTH_ALTERNATE) }
{ (1,SURFACE3D_WIDTH), (1,SURFACE3D_HEIGHT), + * (1,SURFACE3D_DEPTH) }
1D Layered{ (1,TEXTURE1D_LAYERED_WIDTH), 0, + * (1,TEXTURE1D_LAYERED_LAYERS) }{ (1,SURFACE1D_LAYERED_WIDTH), 0, + * (1,SURFACE1D_LAYERED_LAYERS) }
2D Layered{ (1,TEXTURE2D_LAYERED_WIDTH), (1,TEXTURE2D_LAYERED_HEIGHT), + * (1,TEXTURE2D_LAYERED_LAYERS) }{ (1,SURFACE2D_LAYERED_WIDTH), (1,SURFACE2D_LAYERED_HEIGHT), + * (1,SURFACE2D_LAYERED_LAYERS) }
Cubemap{ (1,TEXTURECUBEMAP_WIDTH), (1,TEXTURECUBEMAP_WIDTH), 6 }{ (1,SURFACECUBEMAP_WIDTH), + * (1,SURFACECUBEMAP_WIDTH), 6 }
Cubemap Layered{ (1,TEXTURECUBEMAP_LAYERED_WIDTH), (1,TEXTURECUBEMAP_LAYERED_WIDTH), + * (1,TEXTURECUBEMAP_LAYERED_LAYERS) }{ (1,SURFACECUBEMAP_LAYERED_WIDTH), (1,SURFACECUBEMAP_LAYERED_WIDTH), + * (1,SURFACECUBEMAP_LAYERED_LAYERS) }
+ * + * Here are examples of CUDA array descriptions: + * + * Description for a CUDA array of 2048 floats: + * \code + CUDA_ARRAY3D_DESCRIPTOR desc; + desc.Format = CU_AD_FORMAT_FLOAT; + desc.NumChannels = 1; + desc.Width = 2048; + desc.Height = 0; + desc.Depth = 0; + * \endcode + * + * Description for a 64 x 64 CUDA array of floats: + * \code + CUDA_ARRAY3D_DESCRIPTOR desc; + desc.Format = CU_AD_FORMAT_FLOAT; + desc.NumChannels = 1; + desc.Width = 64; + desc.Height = 64; + desc.Depth = 0; + * \endcode + * + * Description for a \p width x \p height x \p depth CUDA array of 64-bit, + * 4x16-bit float16's: + * \code + CUDA_ARRAY3D_DESCRIPTOR desc; + desc.Format = CU_AD_FORMAT_HALF; + desc.NumChannels = 4; + desc.Width = width; + desc.Height = height; + desc.Depth = depth; + * \endcode + * + * \param pHandle - Returned array + * \param pAllocateArray - 3D array descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMalloc3DArray + */ +CUresult CUDAAPI cuArray3DCreate(CUarray *pHandle, const CUDA_ARRAY3D_DESCRIPTOR *pAllocateArray); + +/** + * \brief Get a 3D CUDA array descriptor + * + * Returns in \p *pArrayDescriptor a descriptor containing information on the + * format and dimensions of the CUDA array \p hArray. It is useful for + * subroutines that have been passed a CUDA array, but need to know the CUDA + * array parameters for validation or other purposes. + * + * This function may be called on 1D and 2D arrays, in which case the \p Height + * and/or \p Depth members of the descriptor struct will be set to 0. + * + * \param pArrayDescriptor - Returned 3D array descriptor + * \param hArray - 3D array to get descriptor of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaArrayGetInfo + */ +CUresult CUDAAPI cuArray3DGetDescriptor(CUDA_ARRAY3D_DESCRIPTOR *pArrayDescriptor, CUarray hArray); + +/** + * \brief Creates a CUDA mipmapped array + * + * Creates a CUDA mipmapped array according to the ::CUDA_ARRAY3D_DESCRIPTOR structure + * \p pMipmappedArrayDesc and returns a handle to the new CUDA mipmapped array in \p *pHandle. + * \p numMipmapLevels specifies the number of mipmap levels to be allocated. This value is + * clamped to the range [1, 1 + floor(log2(max(width, height, depth)))]. + * + * The ::CUDA_ARRAY3D_DESCRIPTOR is defined as: + * + * \code + typedef struct { + unsigned int Width; + unsigned int Height; + unsigned int Depth; + CUarray_format Format; + unsigned int NumChannels; + unsigned int Flags; + } CUDA_ARRAY3D_DESCRIPTOR; + * \endcode + * where: + * + * - \p Width, \p Height, and \p Depth are the width, height, and depth of the + * CUDA array (in elements); the following types of CUDA arrays can be allocated: + * - A 1D mipmapped array is allocated if \p Height and \p Depth extents are both zero. + * - A 2D mipmapped array is allocated if only \p Depth extent is zero. + * - A 3D mipmapped array is allocated if all three extents are non-zero. + * - A 1D layered CUDA mipmapped array is allocated if only \p Height is zero and the + * ::CUDA_ARRAY3D_LAYERED flag is set. Each layer is a 1D array. The number + * of layers is determined by the depth extent. + * - A 2D layered CUDA mipmapped array is allocated if all three extents are non-zero and + * the ::CUDA_ARRAY3D_LAYERED flag is set. Each layer is a 2D array. The number + * of layers is determined by the depth extent. + * - A cubemap CUDA mipmapped array is allocated if all three extents are non-zero and the + * ::CUDA_ARRAY3D_CUBEMAP flag is set. \p Width must be equal to \p Height, and + * \p Depth must be six. A cubemap is a special type of 2D layered CUDA array, + * where the six layers represent the six faces of a cube. The order of the six + * layers in memory is the same as that listed in ::CUarray_cubemap_face. + * - A cubemap layered CUDA mipmapped array is allocated if all three extents are non-zero, + * and both, ::CUDA_ARRAY3D_CUBEMAP and ::CUDA_ARRAY3D_LAYERED flags are set. + * \p Width must be equal to \p Height, and \p Depth must be a multiple of six. + * A cubemap layered CUDA array is a special type of 2D layered CUDA array that + * consists of a collection of cubemaps. The first six layers represent the first + * cubemap, the next six layers form the second cubemap, and so on. + * + * - ::Format specifies the format of the elements; ::CUarray_format is + * defined as: + * \code + typedef enum CUarray_format_enum { + CU_AD_FORMAT_UNSIGNED_INT8 = 0x01, + CU_AD_FORMAT_UNSIGNED_INT16 = 0x02, + CU_AD_FORMAT_UNSIGNED_INT32 = 0x03, + CU_AD_FORMAT_SIGNED_INT8 = 0x08, + CU_AD_FORMAT_SIGNED_INT16 = 0x09, + CU_AD_FORMAT_SIGNED_INT32 = 0x0a, + CU_AD_FORMAT_HALF = 0x10, + CU_AD_FORMAT_FLOAT = 0x20 + } CUarray_format; + * \endcode + * + * - \p NumChannels specifies the number of packed components per CUDA array + * element; it may be 1, 2, or 4; + * + * - ::Flags may be set to + * - ::CUDA_ARRAY3D_LAYERED to enable creation of layered CUDA mipmapped arrays. If this flag is set, + * \p Depth specifies the number of layers, not the depth of a 3D array. + * - ::CUDA_ARRAY3D_SURFACE_LDST to enable surface references to be bound to individual mipmap levels of + * the CUDA mipmapped array. If this flag is not set, ::cuSurfRefSetArray will fail when attempting to + * bind a mipmap level of the CUDA mipmapped array to a surface reference. + * - ::CUDA_ARRAY3D_CUBEMAP to enable creation of mipmapped cubemaps. If this flag is set, \p Width must be + * equal to \p Height, and \p Depth must be six. If the ::CUDA_ARRAY3D_LAYERED flag is also set, + * then \p Depth must be a multiple of six. + * - ::CUDA_ARRAY3D_TEXTURE_GATHER to indicate that the CUDA mipmapped array will be used for texture gather. + * Texture gather can only be performed on 2D CUDA mipmapped arrays. + * + * \p Width, \p Height and \p Depth must meet certain size requirements as listed in the following table. + * All values are specified in elements. Note that for brevity's sake, the full name of the device attribute + * is not specified. For ex., TEXTURE1D_MIPMAPPED_WIDTH refers to the device attribute + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_MIPMAPPED_WIDTH. + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + *
CUDA array typeValid extents that must always be met
{(width range in elements), (height range), + * (depth range)}
Valid extents with CUDA_ARRAY3D_SURFACE_LDST set
+ * {(width range in elements), (height range), (depth range)}
1D{ (1,TEXTURE1D_MIPMAPPED_WIDTH), 0, 0 }{ (1,SURFACE1D_WIDTH), 0, 0 }
2D{ (1,TEXTURE2D_MIPMAPPED_WIDTH), (1,TEXTURE2D_MIPMAPPED_HEIGHT), 0 }{ (1,SURFACE2D_WIDTH), (1,SURFACE2D_HEIGHT), 0 }
3D{ (1,TEXTURE3D_WIDTH), (1,TEXTURE3D_HEIGHT), (1,TEXTURE3D_DEPTH) } + *
OR
{ (1,TEXTURE3D_WIDTH_ALTERNATE), (1,TEXTURE3D_HEIGHT_ALTERNATE), + * (1,TEXTURE3D_DEPTH_ALTERNATE) }
{ (1,SURFACE3D_WIDTH), (1,SURFACE3D_HEIGHT), + * (1,SURFACE3D_DEPTH) }
1D Layered{ (1,TEXTURE1D_LAYERED_WIDTH), 0, + * (1,TEXTURE1D_LAYERED_LAYERS) }{ (1,SURFACE1D_LAYERED_WIDTH), 0, + * (1,SURFACE1D_LAYERED_LAYERS) }
2D Layered{ (1,TEXTURE2D_LAYERED_WIDTH), (1,TEXTURE2D_LAYERED_HEIGHT), + * (1,TEXTURE2D_LAYERED_LAYERS) }{ (1,SURFACE2D_LAYERED_WIDTH), (1,SURFACE2D_LAYERED_HEIGHT), + * (1,SURFACE2D_LAYERED_LAYERS) }
Cubemap{ (1,TEXTURECUBEMAP_WIDTH), (1,TEXTURECUBEMAP_WIDTH), 6 }{ (1,SURFACECUBEMAP_WIDTH), + * (1,SURFACECUBEMAP_WIDTH), 6 }
Cubemap Layered{ (1,TEXTURECUBEMAP_LAYERED_WIDTH), (1,TEXTURECUBEMAP_LAYERED_WIDTH), + * (1,TEXTURECUBEMAP_LAYERED_LAYERS) }{ (1,SURFACECUBEMAP_LAYERED_WIDTH), (1,SURFACECUBEMAP_LAYERED_WIDTH), + * (1,SURFACECUBEMAP_LAYERED_LAYERS) }
+ * + * + * \param pHandle - Returned mipmapped array + * \param pMipmappedArrayDesc - mipmapped array descriptor + * \param numMipmapLevels - Number of mipmap levels + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cuMipmappedArrayDestroy, + * ::cuMipmappedArrayGetLevel, + * ::cuArrayCreate, + * ::cudaMallocMipmappedArray + */ +CUresult CUDAAPI cuMipmappedArrayCreate(CUmipmappedArray *pHandle, const CUDA_ARRAY3D_DESCRIPTOR *pMipmappedArrayDesc, unsigned int numMipmapLevels); + +/** + * \brief Gets a mipmap level of a CUDA mipmapped array + * + * Returns in \p *pLevelArray a CUDA array that represents a single mipmap level + * of the CUDA mipmapped array \p hMipmappedArray. + * + * If \p level is greater than the maximum number of levels in this mipmapped array, + * ::CUDA_ERROR_INVALID_VALUE is returned. + * + * \param pLevelArray - Returned mipmap level CUDA array + * \param hMipmappedArray - CUDA mipmapped array + * \param level - Mipmap level + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa + * ::cuMipmappedArrayCreate, + * ::cuMipmappedArrayDestroy, + * ::cuArrayCreate, + * ::cudaGetMipmappedArrayLevel + */ +CUresult CUDAAPI cuMipmappedArrayGetLevel(CUarray *pLevelArray, CUmipmappedArray hMipmappedArray, unsigned int level); + +/** + * \brief Destroys a CUDA mipmapped array + * + * Destroys the CUDA mipmapped array \p hMipmappedArray. + * + * \param hMipmappedArray - Mipmapped array to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_ARRAY_IS_MAPPED, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * \notefnerr + * + * \sa + * ::cuMipmappedArrayCreate, + * ::cuMipmappedArrayGetLevel, + * ::cuArrayCreate, + * ::cudaFreeMipmappedArray + */ +CUresult CUDAAPI cuMipmappedArrayDestroy(CUmipmappedArray hMipmappedArray); + +/** +* \brief Retrieve handle for an address range +* +* Get a handle of the specified type to an address range. The address range +* must have been obtained by a prior call to either ::cuMemAlloc or ::cuMemAddressReserve. +* If the address range was obtained via ::cuMemAddressReserve, it must also be fully mapped via ::cuMemMap. +* The address range must have been obtained by a prior call to either ::cuMemAllocHost or +* ::cuMemHostAlloc on Tegra. +* +* Users must ensure the \p dptr and \p size are aligned to the host page size. +* +* When requesting CUmemRangeHandleType::CU_MEM_RANGE_HANDLE_TYPE_DMA_BUF_FD, +* users are expected to query for dma_buf support for the platform +* by using ::CU_DEVICE_ATTRIBUTE_DMA_BUF_SUPPORTED device attribute before calling +* this API. The \p handle will be interpreted as a pointer to an integer to store the dma_buf file descriptor. +* Users must ensure the entire address range is backed and mapped when +* the address range is allocated by ::cuMemAddressReserve. All the physical +* allocations backing the address range must be resident on the same device and +* have identical allocation properties. Users are also expected to retrieve a +* new handle every time the underlying physical allocation(s) corresponding +* to a previously queried VA range are changed. +* +* \param[out] handle - Pointer to the location where the returned handle will be stored. +* \param[in] dptr - Pointer to a valid CUDA device allocation. Must be aligned to host page size. +* \param[in] size - Length of the address range. Must be aligned to host page size. +* \param[in] handleType - Type of handle requested (defines type and size of the \p handle output parameter) +* \param[in] flags - Reserved, must be zero +* +* \return +* CUDA_SUCCESS +* CUDA_ERROR_INVALID_VALUE +* CUDA_ERROR_NOT_SUPPORTED +*/ +CUresult CUDAAPI cuMemGetHandleForAddressRange(void *handle, CUdeviceptr dptr, size_t size, CUmemRangeHandleType handleType, unsigned long long flags); + +/** @} */ /* END CUDA_MEM */ + +/** + * \defgroup CUDA_VA Virtual Memory Management + * + * ___MANBRIEF___ virtual memory management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the virtual memory management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** +* \brief Allocate an address range reservation. +* +* Reserves a virtual address range based on the given parameters, giving +* the starting address of the range in \p ptr. This API requires a system that +* supports UVA. The size and address parameters must be a multiple of the +* host page size and the alignment must be a power of two or zero for default +* alignment. +* +* \param[out] ptr - Resulting pointer to start of virtual address range allocated +* \param[in] size - Size of the reserved virtual address range requested +* \param[in] alignment - Alignment of the reserved virtual address range requested +* \param[in] addr - Fixed starting address range requested +* \param[in] flags - Currently unused, must be zero +* \return +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_OUT_OF_MEMORY, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemAddressFree +*/ +CUresult CUDAAPI cuMemAddressReserve(CUdeviceptr *ptr, size_t size, size_t alignment, CUdeviceptr addr, unsigned long long flags); + +/** +* \brief Free an address range reservation. +* +* Frees a virtual address range reserved by cuMemAddressReserve. The size +* must match what was given to memAddressReserve and the ptr given must +* match what was returned from memAddressReserve. +* +* \param[in] ptr - Starting address of the virtual address range to free +* \param[in] size - Size of the virtual address region to free +* \return +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemAddressReserve +*/ +CUresult CUDAAPI cuMemAddressFree(CUdeviceptr ptr, size_t size); + +/** +* \brief Create a CUDA memory handle representing a memory allocation of a given size described by the given properties +* +* This creates a memory allocation on the target device specified through the +* \p prop structure. The created allocation will not have any device or host +* mappings. The generic memory \p handle for the allocation can be +* mapped to the address space of calling process via ::cuMemMap. This handle +* cannot be transmitted directly to other processes (see +* ::cuMemExportToShareableHandle). On Windows, the caller must also pass +* an LPSECURITYATTRIBUTE in \p prop to be associated with this handle which +* limits or allows access to this handle for a recipient process (see +* ::CUmemAllocationProp::win32HandleMetaData for more). The \p size of this +* allocation must be a multiple of the the value given via +* ::cuMemGetAllocationGranularity with the ::CU_MEM_ALLOC_GRANULARITY_MINIMUM +* flag. +* To create a CPU allocation targeting a specific host NUMA node, applications must +* set ::CUmemAllocationProp::CUmemLocation::type to ::CU_MEM_LOCATION_TYPE_HOST_NUMA and +* ::CUmemAllocationProp::CUmemLocation::id must specify the NUMA ID of the CPU. +* On systems where NUMA is not available ::CUmemAllocationProp::CUmemLocation::id must be set to 0. +* Specifying ::CU_MEM_LOCATION_TYPE_HOST_NUMA_CURRENT or ::CU_MEM_LOCATION_TYPE_HOST as the +* ::CUmemLocation::type will result in ::CUDA_ERROR_INVALID_VALUE. +* +* Applications can set ::CUmemAllocationProp::requestedHandleTypes to +* ::CU_MEM_HANDLE_TYPE_FABRIC in order to create allocations suitable for sharing +* within an IMEX domain. An IMEX domain is either an OS instance or a group of securely +* connected OS instances using the NVIDIA IMEX daemon. An IMEX channel is a global resource +* within the IMEX domain that represents a logical entity that aims to provide fine grained +* accessibility control for the participating processes. When exporter and importer CUDA processes +* have been granted access to the same IMEX channel, they can securely share memory. +* If the allocating process does not have access setup for an IMEX channel, attempting to create +* a ::CUmemGenericAllocationHandle with ::CU_MEM_HANDLE_TYPE_FABRIC will result in ::CUDA_ERROR_NOT_PERMITTED. +* The nvidia-modprobe CLI provides more information regarding setting up of IMEX channels. +* +* If ::CUmemAllocationProp::allocFlags::usage contains ::CU_MEM_CREATE_USAGE_TILE_POOL flag then +* the memory allocation is intended only to be used as backing tile pool for sparse CUDA arrays +* and sparse CUDA mipmapped arrays. +* (see ::cuMemMapArrayAsync). +* +* \param[out] handle - Value of handle returned. All operations on this allocation are to be performed using this handle. +* \param[in] size - Size of the allocation requested +* \param[in] prop - Properties of the allocation to create. +* \param[in] flags - flags for future use, must be zero now. +* \return +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_OUT_OF_MEMORY, +* ::CUDA_ERROR_INVALID_DEVICE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* \notefnerr +* +* \sa ::cuMemRelease, ::cuMemExportToShareableHandle, ::cuMemImportFromShareableHandle +*/ +CUresult CUDAAPI cuMemCreate(CUmemGenericAllocationHandle *handle, size_t size, const CUmemAllocationProp *prop, unsigned long long flags); + +/** +* \brief Release a memory handle representing a memory allocation which was previously allocated through cuMemCreate. +* +* Frees the memory that was allocated on a device through cuMemCreate. +* +* The memory allocation will be freed when all outstanding mappings to the memory +* are unmapped and when all outstanding references to the handle (including it's +* shareable counterparts) are also released. The generic memory handle can be +* freed when there are still outstanding mappings made with this handle. Each +* time a recipient process imports a shareable handle, it needs to pair it with +* ::cuMemRelease for the handle to be freed. If \p handle is not a valid handle +* the behavior is undefined. +* +* \param[in] handle Value of handle which was returned previously by cuMemCreate. +* \return +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* \notefnerr +* +* \sa ::cuMemCreate +*/ +CUresult CUDAAPI cuMemRelease(CUmemGenericAllocationHandle handle); + +/** +* \brief Maps an allocation handle to a reserved virtual address range. +* +* Maps bytes of memory represented by \p handle starting from byte \p offset to +* \p size to address range [\p addr, \p addr + \p size]. This range must be an +* address reservation previously reserved with ::cuMemAddressReserve, and +* \p offset + \p size must be less than the size of the memory allocation. +* Both \p ptr, \p size, and \p offset must be a multiple of the value given via +* ::cuMemGetAllocationGranularity with the ::CU_MEM_ALLOC_GRANULARITY_MINIMUM flag. +* If \p handle represents a multicast object, \p ptr, \p size and \p offset must +* be aligned to the value returned by ::cuMulticastGetGranularity with the flag +* ::CU_MULTICAST_MINIMUM_GRANULARITY. For best performance however, it is +* recommended that \p ptr, \p size and \p offset be aligned to the value +* returned by ::cuMulticastGetGranularity with the flag +* ::CU_MULTICAST_RECOMMENDED_GRANULARITY. +* +* Please note calling ::cuMemMap does not make the address accessible, +* the caller needs to update accessibility of a contiguous mapped VA +* range by calling ::cuMemSetAccess. +* +* Once a recipient process obtains a shareable memory handle +* from ::cuMemImportFromShareableHandle, the process must +* use ::cuMemMap to map the memory into its address ranges before +* setting accessibility with ::cuMemSetAccess. +* +* ::cuMemMap can only create mappings on VA range reservations +* that are not currently mapped. +* +* \param[in] ptr - Address where memory will be mapped. +* \param[in] size - Size of the memory mapping. +* \param[in] offset - Offset into the memory represented by +* - \p handle from which to start mapping +* - Note: currently must be zero. +* \param[in] handle - Handle to a shareable memory +* \param[in] flags - flags for future use, must be zero now. +* \return +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_INVALID_DEVICE, +* ::CUDA_ERROR_OUT_OF_MEMORY, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* \notefnerr +* +* \sa ::cuMemUnmap, ::cuMemSetAccess, ::cuMemCreate, ::cuMemAddressReserve, ::cuMemImportFromShareableHandle +*/ +CUresult CUDAAPI cuMemMap(CUdeviceptr ptr, size_t size, size_t offset, CUmemGenericAllocationHandle handle, unsigned long long flags); + +/** + * \brief Maps or unmaps subregions of sparse CUDA arrays and sparse CUDA mipmapped arrays + * + * Performs map or unmap operations on subregions of sparse CUDA arrays and sparse CUDA mipmapped arrays. + * Each operation is specified by a ::CUarrayMapInfo entry in the \p mapInfoList array of size \p count. + * The structure ::CUarrayMapInfo is defined as follow: + \code + typedef struct CUarrayMapInfo_st { + CUresourcetype resourceType; + union { + CUmipmappedArray mipmap; + CUarray array; + } resource; + + CUarraySparseSubresourceType subresourceType; + union { + struct { + unsigned int level; + unsigned int layer; + unsigned int offsetX; + unsigned int offsetY; + unsigned int offsetZ; + unsigned int extentWidth; + unsigned int extentHeight; + unsigned int extentDepth; + } sparseLevel; + struct { + unsigned int layer; + unsigned long long offset; + unsigned long long size; + } miptail; + } subresource; + + CUmemOperationType memOperationType; + + CUmemHandleType memHandleType; + union { + CUmemGenericAllocationHandle memHandle; + } memHandle; + + unsigned long long offset; + unsigned int deviceBitMask; + unsigned int flags; + unsigned int reserved[2]; + } CUarrayMapInfo; + \endcode + * + * where ::CUarrayMapInfo::resourceType specifies the type of resource to be operated on. + * If ::CUarrayMapInfo::resourceType is set to ::CUresourcetype::CU_RESOURCE_TYPE_ARRAY then + * ::CUarrayMapInfo::resource::array must be set to a valid sparse CUDA array handle. + * The CUDA array must be either a 2D, 2D layered or 3D CUDA array and must have been allocated using + * ::cuArrayCreate or ::cuArray3DCreate with the flag ::CUDA_ARRAY3D_SPARSE + * or ::CUDA_ARRAY3D_DEFERRED_MAPPING. + * For CUDA arrays obtained using ::cuMipmappedArrayGetLevel, ::CUDA_ERROR_INVALID_VALUE will be returned. + * If ::CUarrayMapInfo::resourceType is set to ::CUresourcetype::CU_RESOURCE_TYPE_MIPMAPPED_ARRAY + * then ::CUarrayMapInfo::resource::mipmap must be set to a valid sparse CUDA mipmapped array handle. + * The CUDA mipmapped array must be either a 2D, 2D layered or 3D CUDA mipmapped array and must have been + * allocated using ::cuMipmappedArrayCreate with the flag ::CUDA_ARRAY3D_SPARSE + * or ::CUDA_ARRAY3D_DEFERRED_MAPPING. + * + * ::CUarrayMapInfo::subresourceType specifies the type of subresource within the resource. + * ::CUarraySparseSubresourceType_enum is defined as: + \code + typedef enum CUarraySparseSubresourceType_enum { + CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_SPARSE_LEVEL = 0, + CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_MIPTAIL = 1 + } CUarraySparseSubresourceType; + \endcode + * + * where ::CUarraySparseSubresourceType::CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_SPARSE_LEVEL indicates a + * sparse-miplevel which spans at least one tile in every dimension. The remaining miplevels which + * are too small to span at least one tile in any dimension constitute the mip tail region as indicated by + * ::CUarraySparseSubresourceType::CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_MIPTAIL subresource type. + * + * If ::CUarrayMapInfo::subresourceType is set to ::CUarraySparseSubresourceType::CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_SPARSE_LEVEL + * then ::CUarrayMapInfo::subresource::sparseLevel struct must contain valid array subregion offsets and extents. + * The ::CUarrayMapInfo::subresource::sparseLevel::offsetX, ::CUarrayMapInfo::subresource::sparseLevel::offsetY + * and ::CUarrayMapInfo::subresource::sparseLevel::offsetZ must specify valid X, Y and Z offsets respectively. + * The ::CUarrayMapInfo::subresource::sparseLevel::extentWidth, ::CUarrayMapInfo::subresource::sparseLevel::extentHeight + * and ::CUarrayMapInfo::subresource::sparseLevel::extentDepth must specify valid width, height and depth extents respectively. + * These offsets and extents must be aligned to the corresponding tile dimension. + * For CUDA mipmapped arrays ::CUarrayMapInfo::subresource::sparseLevel::level must specify a valid mip level index. Otherwise, + * must be zero. + * For layered CUDA arrays and layered CUDA mipmapped arrays ::CUarrayMapInfo::subresource::sparseLevel::layer must specify a valid layer index. Otherwise, + * must be zero. + * ::CUarrayMapInfo::subresource::sparseLevel::offsetZ must be zero and ::CUarrayMapInfo::subresource::sparseLevel::extentDepth + * must be set to 1 for 2D and 2D layered CUDA arrays and CUDA mipmapped arrays. + * Tile extents can be obtained by calling ::cuArrayGetSparseProperties and ::cuMipmappedArrayGetSparseProperties + * + * If ::CUarrayMapInfo::subresourceType is set to ::CUarraySparseSubresourceType::CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_MIPTAIL + * then ::CUarrayMapInfo::subresource::miptail struct must contain valid mip tail offset in + * ::CUarrayMapInfo::subresource::miptail::offset and size in ::CUarrayMapInfo::subresource::miptail::size. + * Both, mip tail offset and mip tail size must be aligned to the tile size. + * For layered CUDA mipmapped arrays which don't have the flag ::CU_ARRAY_SPARSE_PROPERTIES_SINGLE_MIPTAIL set in ::CUDA_ARRAY_SPARSE_PROPERTIES::flags + * as returned by ::cuMipmappedArrayGetSparseProperties, ::CUarrayMapInfo::subresource::miptail::layer must specify a valid layer index. + * Otherwise, must be zero. + * + * If ::CUarrayMapInfo::resource::array or ::CUarrayMapInfo::resource::mipmap was created with ::CUDA_ARRAY3D_DEFERRED_MAPPING + * flag set the ::CUarrayMapInfo::subresourceType and the contents of ::CUarrayMapInfo::subresource will be ignored. + * + * ::CUarrayMapInfo::memOperationType specifies the type of operation. ::CUmemOperationType is defined as: + \code + typedef enum CUmemOperationType_enum { + CU_MEM_OPERATION_TYPE_MAP = 1, + CU_MEM_OPERATION_TYPE_UNMAP = 2 + } CUmemOperationType; + \endcode + * If ::CUarrayMapInfo::memOperationType is set to ::CUmemOperationType::CU_MEM_OPERATION_TYPE_MAP then the subresource + * will be mapped onto the tile pool memory specified by ::CUarrayMapInfo::memHandle at offset ::CUarrayMapInfo::offset. + * The tile pool allocation has to be created by specifying the ::CU_MEM_CREATE_USAGE_TILE_POOL flag when calling ::cuMemCreate. Also, + * ::CUarrayMapInfo::memHandleType must be set to ::CUmemHandleType::CU_MEM_HANDLE_TYPE_GENERIC. + * + * If ::CUarrayMapInfo::memOperationType is set to ::CUmemOperationType::CU_MEM_OPERATION_TYPE_UNMAP then an unmapping operation + * is performed. ::CUarrayMapInfo::memHandle must be NULL. + * + * ::CUarrayMapInfo::deviceBitMask specifies the list of devices that must map or unmap physical memory. + * Currently, this mask must have exactly one bit set, and the corresponding device must match the device associated with the stream. + * If ::CUarrayMapInfo::memOperationType is set to ::CUmemOperationType::CU_MEM_OPERATION_TYPE_MAP, the device must also match + * the device associated with the tile pool memory allocation as specified by ::CUarrayMapInfo::memHandle. + * + * ::CUarrayMapInfo::flags and ::CUarrayMapInfo::reserved[] are unused and must be set to zero. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * + * \param[in] mapInfoList - List of ::CUarrayMapInfo + * \param[in] count - Count of ::CUarrayMapInfo in \p mapInfoList + * \param[in] hStream - Stream identifier for the stream to use for map or unmap operations + * + * \sa ::cuMipmappedArrayCreate, ::cuArrayCreate, ::cuArray3DCreate, ::cuMemCreate, ::cuArrayGetSparseProperties, ::cuMipmappedArrayGetSparseProperties + */ +CUresult CUDAAPI cuMemMapArrayAsync(CUarrayMapInfo *mapInfoList, unsigned int count, CUstream hStream); + +/** +* \brief Unmap the backing memory of a given address range. +* +* The range must be the entire contiguous address range that was mapped to. In +* other words, ::cuMemUnmap cannot unmap a sub-range of an address range mapped +* by ::cuMemCreate / ::cuMemMap. Any backing memory allocations will be freed +* if there are no existing mappings and there are no unreleased memory handles. +* +* When ::cuMemUnmap returns successfully the address range is converted to an +* address reservation and can be used for a future calls to ::cuMemMap. Any new +* mapping to this virtual address will need to have access granted through +* ::cuMemSetAccess, as all mappings start with no accessibility setup. +* +* \param[in] ptr - Starting address for the virtual address range to unmap +* \param[in] size - Size of the virtual address range to unmap +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* \notefnerr +* \note_sync +* +* \sa ::cuMemCreate, ::cuMemAddressReserve +*/ +CUresult CUDAAPI cuMemUnmap(CUdeviceptr ptr, size_t size); + +/** +* \brief Set the access flags for each location specified in \p desc for the given virtual address range +* +* Given the virtual address range via \p ptr and \p size, and the locations +* in the array given by \p desc and \p count, set the access flags for the +* target locations. The range must be a fully mapped address range +* containing all allocations created by ::cuMemMap / ::cuMemCreate. +* Users cannot specify ::CU_MEM_LOCATION_TYPE_HOST_NUMA accessibility for allocations created on with other location types. +* Note: When ::CUmemAccessDesc::CUmemLocation::type is ::CU_MEM_LOCATION_TYPE_HOST_NUMA, ::CUmemAccessDesc::CUmemLocation::id +* is ignored. +* When setting the access flags for a virtual address range mapping a multicast +* object, \p ptr and \p size must be aligned to the value returned by +* ::cuMulticastGetGranularity with the flag ::CU_MULTICAST_MINIMUM_GRANULARITY. +* For best performance however, it is recommended that \p ptr and \p size be +* aligned to the value returned by ::cuMulticastGetGranularity with the flag +* ::CU_MULTICAST_RECOMMENDED_GRANULARITY. +* +* \param[in] ptr - Starting address for the virtual address range +* \param[in] size - Length of the virtual address range +* \param[in] desc - Array of ::CUmemAccessDesc that describe how to change the +* - mapping for each location specified +* \param[in] count - Number of ::CUmemAccessDesc in \p desc +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_INVALID_DEVICE, +* ::CUDA_ERROR_NOT_SUPPORTED +* \notefnerr +* \note_sync +* +* \sa ::cuMemSetAccess, ::cuMemCreate, :cuMemMap +*/ +CUresult CUDAAPI cuMemSetAccess(CUdeviceptr ptr, size_t size, const CUmemAccessDesc *desc, size_t count); + +/** +* \brief Get the access \p flags set for the given \p location and \p ptr +* +* \param[out] flags - Flags set for this location +* \param[in] location - Location in which to check the flags for +* \param[in] ptr - Address in which to check the access flags for +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_INVALID_DEVICE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemSetAccess +*/ +CUresult CUDAAPI cuMemGetAccess(unsigned long long *flags, const CUmemLocation *location, CUdeviceptr ptr); + +/** +* \brief Exports an allocation to a requested shareable handle type +* +* Given a CUDA memory handle, create a shareable memory +* allocation handle that can be used to share the memory with other +* processes. The recipient process can convert the shareable handle back into a +* CUDA memory handle using ::cuMemImportFromShareableHandle and map +* it with ::cuMemMap. The implementation of what this handle is and how it +* can be transferred is defined by the requested handle type in \p handleType +* +* Once all shareable handles are closed and the allocation is released, the allocated +* memory referenced will be released back to the OS and uses of the CUDA handle afterward +* will lead to undefined behavior. +* +* This API can also be used in conjunction with other APIs (e.g. Vulkan, OpenGL) +* that support importing memory from the shareable type +* +* \param[out] shareableHandle - Pointer to the location in which to store the requested handle type +* \param[in] handle - CUDA handle for the memory allocation +* \param[in] handleType - Type of shareable handle requested (defines type and size of the \p shareableHandle output parameter) +* \param[in] flags - Reserved, must be zero +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemImportFromShareableHandle +*/ +CUresult CUDAAPI cuMemExportToShareableHandle(void *shareableHandle, CUmemGenericAllocationHandle handle, CUmemAllocationHandleType handleType, unsigned long long flags); + +/** +* \brief Imports an allocation from a requested shareable handle type. +* +* If the current process cannot support the memory described by this shareable +* handle, this API will error as ::CUDA_ERROR_NOT_SUPPORTED. +* +* If \p shHandleType is ::CU_MEM_HANDLE_TYPE_FABRIC and the importer process has not been +* granted access to the same IMEX channel as the exporter process, this API will error +* as ::CUDA_ERROR_NOT_PERMITTED. +* +* \note Importing shareable handles exported from some graphics APIs(VUlkan, OpenGL, etc) +* created on devices under an SLI group may not be supported, and thus this API will +* return CUDA_ERROR_NOT_SUPPORTED. +* There is no guarantee that the contents of \p handle will be the same CUDA memory handle +* for the same given OS shareable handle, or the same underlying allocation. +* +* \param[out] handle - CUDA Memory handle for the memory allocation. +* \param[in] osHandle - Shareable Handle representing the memory allocation that is to be imported. +* \param[in] shHandleType - handle type of the exported handle ::CUmemAllocationHandleType. +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemExportToShareableHandle, ::cuMemMap, ::cuMemRelease +*/ +CUresult CUDAAPI cuMemImportFromShareableHandle(CUmemGenericAllocationHandle *handle, void *osHandle, CUmemAllocationHandleType shHandleType); + +/** +* \brief Calculates either the minimal or recommended granularity +* +* Calculates either the minimal or recommended granularity +* for a given allocation specification and returns it in granularity. This +* granularity can be used as a multiple for alignment, size, or address mapping. +* +* \param[out] granularity Returned granularity. +* \param[in] prop Property for which to determine the granularity for +* \param[in] option Determines which granularity to return +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemCreate, ::cuMemMap +*/ +CUresult CUDAAPI cuMemGetAllocationGranularity(size_t *granularity, const CUmemAllocationProp *prop, CUmemAllocationGranularity_flags option); + +/** +* \brief Retrieve the contents of the property structure defining properties for this handle +* +* \param[out] prop - Pointer to a properties structure which will hold the information about this handle +* \param[in] handle - Handle which to perform the query on +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemCreate, ::cuMemImportFromShareableHandle +*/ +CUresult CUDAAPI cuMemGetAllocationPropertiesFromHandle(CUmemAllocationProp *prop, CUmemGenericAllocationHandle handle); + +/** +* \brief Given an address \p addr, returns the allocation handle of the backing memory allocation. +* +* The handle is guaranteed to be the same handle value used to map the memory. If the address +* requested is not mapped, the function will fail. The returned handle must be released with +* corresponding number of calls to ::cuMemRelease. +* +* \note The address \p addr, can be any address in a range previously mapped +* by ::cuMemMap, and not necessarily the start address. +* +* \param[out] handle CUDA Memory handle for the backing memory allocation. +* \param[in] addr Memory address to query, that has been mapped previously. +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemCreate, ::cuMemRelease, ::cuMemMap +*/ +CUresult CUDAAPI cuMemRetainAllocationHandle(CUmemGenericAllocationHandle *handle, void *addr); + +/** @} */ /* END CUDA_VA */ + +/** + * \defgroup CUDA_MALLOC_ASYNC Stream Ordered Memory Allocator + * + * ___MANBRIEF___ Functions for performing allocation and free operations in stream order. + * Functions for controlling the behavior of the underlying allocator. + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the stream ordered memory allocator exposed by the + * low-level CUDA driver application programming interface. + * + * @{ + * + * \section CUDA_MALLOC_ASYNC_overview overview + * + * The asynchronous allocator allows the user to allocate and free in stream order. + * All asynchronous accesses of the allocation must happen between + * the stream executions of the allocation and the free. If the memory is accessed + * outside of the promised stream order, a use before allocation / use after free error + * will cause undefined behavior. + * + * The allocator is free to reallocate the memory as long as it can guarantee + * that compliant memory accesses will not overlap temporally. + * The allocator may refer to internal stream ordering as well as inter-stream dependencies + * (such as CUDA events and null stream dependencies) when establishing the temporal guarantee. + * The allocator may also insert inter-stream dependencies to establish the temporal guarantee. + * + * \section CUDA_MALLOC_ASYNC_support Supported Platforms + * + * Whether or not a device supports the integrated stream ordered memory allocator + * may be queried by calling ::cuDeviceGetAttribute() with the device attribute + * ::CU_DEVICE_ATTRIBUTE_MEMORY_POOLS_SUPPORTED + */ + +/** + * \brief Frees memory with stream ordered semantics + * + * Inserts a free operation into \p hStream. + * The allocation must not be accessed after stream execution reaches the free. + * After this API returns, accessing the memory from any subsequent work launched on the GPU + * or querying its pointer attributes results in undefined behavior. + * + * \note During stream capture, this function results in the creation of a free node and + * must therefore be passed the address of a graph allocation. + * + * \param dptr - memory to free + * \param hStream - The stream establishing the stream ordering contract. + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT (default stream specified with no current context), + * ::CUDA_ERROR_NOT_SUPPORTED + */ +CUresult CUDAAPI cuMemFreeAsync(CUdeviceptr dptr, CUstream hStream); + +/** + * \brief Allocates memory with stream ordered semantics + * + * Inserts an allocation operation into \p hStream. + * A pointer to the allocated memory is returned immediately in *dptr. + * The allocation must not be accessed until the the allocation operation completes. + * The allocation comes from the memory pool current to the stream's device. + * + * \note The default memory pool of a device contains device memory from that device. + * \note Basic stream ordering allows future work submitted into the same stream to use the allocation. + * Stream query, stream synchronize, and CUDA events can be used to guarantee that the allocation + * operation completes before work submitted in a separate stream runs. + * \note During stream capture, this function results in the creation of an allocation node. In this case, + * the allocation is owned by the graph instead of the memory pool. The memory pool's properties + * are used to set the node's creation parameters. + * + * \param[out] dptr - Returned device pointer + * \param[in] bytesize - Number of bytes to allocate + * \param[in] hStream - The stream establishing the stream ordering contract and the memory pool to allocate from + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT (default stream specified with no current context), + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuMemAllocFromPoolAsync, ::cuMemFreeAsync, ::cuDeviceSetMemPool, + * ::cuDeviceGetDefaultMemPool, ::cuDeviceGetMemPool, ::cuMemPoolCreate, + * ::cuMemPoolSetAccess, ::cuMemPoolSetAttribute + */ +CUresult CUDAAPI cuMemAllocAsync(CUdeviceptr *dptr, size_t bytesize, CUstream hStream); + +/** + * \brief Tries to release memory back to the OS + * + * Releases memory back to the OS until the pool contains fewer than minBytesToKeep + * reserved bytes, or there is no more memory that the allocator can safely release. + * The allocator cannot release OS allocations that back outstanding asynchronous allocations. + * The OS allocations may happen at different granularity from the user allocations. + * + * \note: Allocations that have not been freed count as outstanding. + * \note: Allocations that have been asynchronously freed but whose completion has + * not been observed on the host (eg. by a synchronize) can count as outstanding. + * + * \param[in] pool - The memory pool to trim + * \param[in] minBytesToKeep - If the pool has less than minBytesToKeep reserved, + * the TrimTo operation is a no-op. Otherwise the pool will be guaranteed to have + * at least minBytesToKeep bytes reserved after the operation. + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuMemAllocAsync, ::cuMemFreeAsync, ::cuDeviceGetDefaultMemPool, + * ::cuDeviceGetMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuMemPoolTrimTo(CUmemoryPool pool, size_t minBytesToKeep); + +/** + * \brief Sets attributes of a memory pool + * + * Supported attributes are: + * - ::CU_MEMPOOL_ATTR_RELEASE_THRESHOLD: (value type = cuuint64_t) + * Amount of reserved memory in bytes to hold onto before trying + * to release memory back to the OS. When more than the release + * threshold bytes of memory are held by the memory pool, the + * allocator will try to release memory back to the OS on the + * next call to stream, event or context synchronize. (default 0) + * - ::CU_MEMPOOL_ATTR_REUSE_FOLLOW_EVENT_DEPENDENCIES: (value type = int) + * Allow ::cuMemAllocAsync to use memory asynchronously freed + * in another stream as long as a stream ordering dependency + * of the allocating stream on the free action exists. + * Cuda events and null stream interactions can create the required + * stream ordered dependencies. (default enabled) + * - ::CU_MEMPOOL_ATTR_REUSE_ALLOW_OPPORTUNISTIC: (value type = int) + * Allow reuse of already completed frees when there is no dependency + * between the free and allocation. (default enabled) + * - ::CU_MEMPOOL_ATTR_REUSE_ALLOW_INTERNAL_DEPENDENCIES: (value type = int) + * Allow ::cuMemAllocAsync to insert new stream dependencies + * in order to establish the stream ordering required to reuse + * a piece of memory released by ::cuMemFreeAsync (default enabled). + * - ::CU_MEMPOOL_ATTR_RESERVED_MEM_HIGH: (value type = cuuint64_t) + * Reset the high watermark that tracks the amount of backing memory that was + * allocated for the memory pool. It is illegal to set this attribute to a non-zero value. + * - ::CU_MEMPOOL_ATTR_USED_MEM_HIGH: (value type = cuuint64_t) + * Reset the high watermark that tracks the amount of used memory that was + * allocated for the memory pool. + * + * \param[in] pool - The memory pool to modify + * \param[in] attr - The attribute to modify + * \param[in] value - Pointer to the value to assign + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuMemAllocAsync, ::cuMemFreeAsync, ::cuDeviceGetDefaultMemPool, + * ::cuDeviceGetMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuMemPoolSetAttribute(CUmemoryPool pool, CUmemPool_attribute attr, void *value); + +/** + * \brief Gets attributes of a memory pool + * + * Supported attributes are: + * - ::CU_MEMPOOL_ATTR_RELEASE_THRESHOLD: (value type = cuuint64_t) + * Amount of reserved memory in bytes to hold onto before trying + * to release memory back to the OS. When more than the release + * threshold bytes of memory are held by the memory pool, the + * allocator will try to release memory back to the OS on the + * next call to stream, event or context synchronize. (default 0) + * - ::CU_MEMPOOL_ATTR_REUSE_FOLLOW_EVENT_DEPENDENCIES: (value type = int) + * Allow ::cuMemAllocAsync to use memory asynchronously freed + * in another stream as long as a stream ordering dependency + * of the allocating stream on the free action exists. + * Cuda events and null stream interactions can create the required + * stream ordered dependencies. (default enabled) + * - ::CU_MEMPOOL_ATTR_REUSE_ALLOW_OPPORTUNISTIC: (value type = int) + * Allow reuse of already completed frees when there is no dependency + * between the free and allocation. (default enabled) + * - ::CU_MEMPOOL_ATTR_REUSE_ALLOW_INTERNAL_DEPENDENCIES: (value type = int) + * Allow ::cuMemAllocAsync to insert new stream dependencies + * in order to establish the stream ordering required to reuse + * a piece of memory released by ::cuMemFreeAsync (default enabled). + * - ::CU_MEMPOOL_ATTR_RESERVED_MEM_CURRENT: (value type = cuuint64_t) + * Amount of backing memory currently allocated for the mempool + * - ::CU_MEMPOOL_ATTR_RESERVED_MEM_HIGH: (value type = cuuint64_t) + * High watermark of backing memory allocated for the mempool since the + * last time it was reset. + * - ::CU_MEMPOOL_ATTR_USED_MEM_CURRENT: (value type = cuuint64_t) + * Amount of memory from the pool that is currently in use by the application. + * - ::CU_MEMPOOL_ATTR_USED_MEM_HIGH: (value type = cuuint64_t) + * High watermark of the amount of memory from the pool that was in use by the application. + * + * \param[in] pool - The memory pool to get attributes of + * \param[in] attr - The attribute to get + * \param[out] value - Retrieved value + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuMemAllocAsync, ::cuMemFreeAsync, ::cuDeviceGetDefaultMemPool, + * ::cuDeviceGetMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuMemPoolGetAttribute(CUmemoryPool pool, CUmemPool_attribute attr, void *value); + +/** + * \brief Controls visibility of pools between devices + * + * \param[in] pool - The pool being modified + * \param[in] map - Array of access descriptors. Each descriptor instructs the access to enable for a single gpu. + * \param[in] count - Number of descriptors in the map array. + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuMemAllocAsync, ::cuMemFreeAsync, ::cuDeviceGetDefaultMemPool, + * ::cuDeviceGetMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuMemPoolSetAccess(CUmemoryPool pool, const CUmemAccessDesc *map, size_t count); + +/** + * \brief Returns the accessibility of a pool from a device + * + * Returns the accessibility of the pool's memory from the specified location. + * + * \param[out] flags - the accessibility of the pool from the specified location + * \param[in] memPool - the pool being queried + * \param[in] location - the location accessing the pool + * + * \sa ::cuMemAllocAsync, ::cuMemFreeAsync, ::cuDeviceGetDefaultMemPool, + * ::cuDeviceGetMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuMemPoolGetAccess(CUmemAccess_flags *flags, CUmemoryPool memPool, CUmemLocation *location); + +/** + * \brief Creates a memory pool + * + * Creates a CUDA memory pool and returns the handle in \p pool. The \p poolProps determines + * the properties of the pool such as the backing device and IPC capabilities. + * + * To create a memory pool targeting a specific host NUMA node, applications must + * set ::CUmemPoolProps::CUmemLocation::type to ::CU_MEM_LOCATION_TYPE_HOST_NUMA and + * ::CUmemPoolProps::CUmemLocation::id must specify the NUMA ID of the host memory node. + * Specifying ::CU_MEM_LOCATION_TYPE_HOST_NUMA_CURRENT or ::CU_MEM_LOCATION_TYPE_HOST as the + * ::CUmemPoolProps::CUmemLocation::type will result in ::CUDA_ERROR_INVALID_VALUE. +* By default, the pool's memory will be accessible from the device it is allocated on. + * In the case of pools created with ::CU_MEM_LOCATION_TYPE_HOST_NUMA, their default accessibility + * will be from the host CPU. + * Applications can control the maximum size of the pool by specifying a non-zero value for ::CUmemPoolProps::maxSize. + * If set to 0, the maximum size of the pool will default to a system dependent value. + * + * Applications can set ::CUmemPoolProps::handleTypes to ::CU_MEM_HANDLE_TYPE_FABRIC + * in order to create ::CUmemoryPool suitable for sharing within an IMEX domain. + * An IMEX domain is either an OS instance or a group of securely connected OS instances + * using the NVIDIA IMEX daemon. An IMEX channel is a global resource within the IMEX domain + * that represents a logical entity that aims to provide fine grained accessibility control + * for the participating processes. When exporter and importer CUDA processes have been + * granted access to the same IMEX channel, they can securely share memory. + * If the allocating process does not have access setup for an IMEX channel, attempting to export + * a ::CUmemoryPool with ::CU_MEM_HANDLE_TYPE_FABRIC will result in ::CUDA_ERROR_NOT_PERMITTED. + * The nvidia-modprobe CLI provides more information regarding setting up of IMEX channels. + * + * \note Specifying CU_MEM_HANDLE_TYPE_NONE creates a memory pool that will not support IPC. + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NOT_PERMITTED + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa ::cuDeviceSetMemPool, ::cuDeviceGetMemPool, ::cuDeviceGetDefaultMemPool, + * ::cuMemAllocFromPoolAsync, ::cuMemPoolExportToShareableHandle + */ +CUresult CUDAAPI cuMemPoolCreate(CUmemoryPool *pool, const CUmemPoolProps *poolProps); + +/** + * \brief Destroys the specified memory pool + * + * If any pointers obtained from this pool haven't been freed or + * the pool has free operations that haven't completed + * when ::cuMemPoolDestroy is invoked, the function will return immediately and the + * resources associated with the pool will be released automatically + * once there are no more outstanding allocations. + * + * Destroying the current mempool of a device sets the default mempool of + * that device as the current mempool for that device. + * + * \note A device's default memory pool cannot be destroyed. + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuMemFreeAsync, ::cuDeviceSetMemPool, ::cuDeviceGetMemPool, + * ::cuDeviceGetDefaultMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuMemPoolDestroy(CUmemoryPool pool); + +/** + * \brief Allocates memory from a specified pool with stream ordered semantics. + * + * Inserts an allocation operation into \p hStream. + * A pointer to the allocated memory is returned immediately in *dptr. + * The allocation must not be accessed until the the allocation operation completes. + * The allocation comes from the specified memory pool. + * + * \note + * - The specified memory pool may be from a device different than that of the specified \p hStream. + * + * - Basic stream ordering allows future work submitted into the same stream to use the allocation. + * Stream query, stream synchronize, and CUDA events can be used to guarantee that the allocation + * operation completes before work submitted in a separate stream runs. + * + * \note During stream capture, this function results in the creation of an allocation node. In this case, + * the allocation is owned by the graph instead of the memory pool. The memory pool's properties + * are used to set the node's creation parameters. + * + * \param[out] dptr - Returned device pointer + * \param[in] bytesize - Number of bytes to allocate + * \param[in] pool - The pool to allocate from + * \param[in] hStream - The stream establishing the stream ordering semantic + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT (default stream specified with no current context), + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuMemAllocAsync, ::cuMemFreeAsync, ::cuDeviceGetDefaultMemPool, + * ::cuDeviceGetMemPool, ::cuMemPoolCreate, ::cuMemPoolSetAccess, + * ::cuMemPoolSetAttribute + */ +CUresult CUDAAPI cuMemAllocFromPoolAsync(CUdeviceptr *dptr, size_t bytesize, CUmemoryPool pool, CUstream hStream); + +/** + * \brief Exports a memory pool to the requested handle type. + * + * Given an IPC capable mempool, create an OS handle to share the pool with another process. + * A recipient process can convert the shareable handle into a mempool with ::cuMemPoolImportFromShareableHandle. + * Individual pointers can then be shared with the ::cuMemPoolExportPointer and ::cuMemPoolImportPointer APIs. + * The implementation of what the shareable handle is and how it can be transferred is defined by the requested + * handle type. + * + * \note: To create an IPC capable mempool, create a mempool with a CUmemAllocationHandleType other than CU_MEM_HANDLE_TYPE_NONE. + * + * \param[out] handle_out - Returned OS handle + * \param[in] pool - pool to export + * \param[in] handleType - the type of handle to create + * \param[in] flags - must be 0 + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuMemPoolImportFromShareableHandle, ::cuMemPoolExportPointer, + * ::cuMemPoolImportPointer, ::cuMemAllocAsync, ::cuMemFreeAsync, + * ::cuDeviceGetDefaultMemPool, ::cuDeviceGetMemPool, ::cuMemPoolCreate, + * ::cuMemPoolSetAccess, ::cuMemPoolSetAttribute + */ +CUresult CUDAAPI cuMemPoolExportToShareableHandle(void *handle_out, CUmemoryPool pool, CUmemAllocationHandleType handleType, unsigned long long flags); + +/** + * \brief imports a memory pool from a shared handle. + * + * Specific allocations can be imported from the imported pool with cuMemPoolImportPointer. + * + * If \p handleType is ::CU_MEM_HANDLE_TYPE_FABRIC and the importer process has not been + * granted access to the same IMEX channel as the exporter process, this API will error + * as ::CUDA_ERROR_NOT_PERMITTED. + * + * + * \note Imported memory pools do not support creating new allocations. + * As such imported memory pools may not be used in cuDeviceSetMemPool + * or ::cuMemAllocFromPoolAsync calls. + * + * \param[out] pool_out - Returned memory pool + * \param[in] handle - OS handle of the pool to open + * \param[in] handleType - The type of handle being imported + * \param[in] flags - must be 0 + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuMemPoolExportToShareableHandle, ::cuMemPoolExportPointer, ::cuMemPoolImportPointer + */ +CUresult CUDAAPI cuMemPoolImportFromShareableHandle( + CUmemoryPool *pool_out, + void *handle, + CUmemAllocationHandleType handleType, + unsigned long long flags); + +/** + * \brief Export data to share a memory pool allocation between processes. + * + * Constructs \p shareData_out for sharing a specific allocation from an already shared memory pool. + * The recipient process can import the allocation with the ::cuMemPoolImportPointer api. + * The data is not a handle and may be shared through any IPC mechanism. + * + * \param[out] shareData_out - Returned export data + * \param[in] ptr - pointer to memory being exported + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuMemPoolExportToShareableHandle, ::cuMemPoolImportFromShareableHandle, ::cuMemPoolImportPointer + */ +CUresult CUDAAPI cuMemPoolExportPointer(CUmemPoolPtrExportData *shareData_out, CUdeviceptr ptr); + +/** + * \brief Import a memory pool allocation from another process. + * + * Returns in \p ptr_out a pointer to the imported memory. + * The imported memory must not be accessed before the allocation operation completes + * in the exporting process. The imported memory must be freed from all importing processes before + * being freed in the exporting process. The pointer may be freed with cuMemFree + * or cuMemFreeAsync. If cuMemFreeAsync is used, the free must be completed + * on the importing process before the free operation on the exporting process. + * + * \note The cuMemFreeAsync api may be used in the exporting process before + * the cuMemFreeAsync operation completes in its stream as long as the + * cuMemFreeAsync in the exporting process specifies a stream with + * a stream dependency on the importing process's cuMemFreeAsync. + * + * \param[out] ptr_out - pointer to imported memory + * \param[in] pool - pool from which to import + * \param[in] shareData - data specifying the memory to import + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuMemPoolExportToShareableHandle, ::cuMemPoolImportFromShareableHandle, ::cuMemPoolExportPointer + */ +CUresult CUDAAPI cuMemPoolImportPointer(CUdeviceptr *ptr_out, CUmemoryPool pool, CUmemPoolPtrExportData *shareData); + +/** @} */ /* END CUDA_MALLOC_ASYNC */ + +/** + * \defgroup CUDA_MULTICAST Multicast Object Management + * + * ___MANBRIEF___ Functions for creating multicast objects, adding devices to them and binding/unbinding memory + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the CUDA multicast object operations exposed by the + * low-level CUDA driver application programming interface. + * + * @{ + * + * \section CUDA_MULTICAST_overview overview + * + * A multicast object created via ::cuMulticastCreate enables certain memory + * operations to be broadcast to a team of devices. Devices can be added to a + * multicast object via ::cuMulticastAddDevice. Memory can be bound on each + * participating device via either ::cuMulticastBindMem or ::cuMulticastBindAddr. + * Multicast objects can be mapped into a device's virtual address space using + * the virtual memmory management APIs (see ::cuMemMap and ::cuMemSetAccess). + * + * \section CUDA_MULTICAST_support Supported Platforms + * + * Support for multicast on a specific device can be queried using the device + * attribute ::CU_DEVICE_ATTRIBUTE_MULTICAST_SUPPORTED + */ + +/** + * \brief Create a generic allocation handle representing a multicast object described by the given properties. + * + * This creates a multicast object as described by \p prop. The number of + * participating devices is specified by ::CUmulticastObjectProp::numDevices. + * Devices can be added to the multicast object via ::cuMulticastAddDevice. + * All participating devices must be added to the multicast object before memory + * can be bound to it. Memory is bound to the multicast object via either + * ::cuMulticastBindMem or ::cuMulticastBindAddr, and can be unbound via + * ::cuMulticastUnbind. The total amount of memory that can be bound per device + * is specified by :CUmulticastObjectProp::size. This size must be a multiple of + * the value returned by ::cuMulticastGetGranularity with the flag + * ::CU_MULTICAST_GRANULARITY_MINIMUM. For best performance however, the size + * should be aligned to the value returned by ::cuMulticastGetGranularity with + * the flag ::CU_MULTICAST_GRANULARITY_RECOMMENDED. + * + * After all participating devices have been added, multicast objects can also + * be mapped to a device's virtual address space using the virtual memory + * management APIs (see ::cuMemMap and ::cuMemSetAccess). Multicast objects can + * also be shared with other processes by requesting a shareable handle via + * ::cuMemExportToShareableHandle. Note that the desired types of shareable + * handles must be specified in the bitmask ::CUmulticastObjectProp::handleTypes. + * Multicast objects can be released using the virtual memory management API + * ::cuMemRelease. + * + * \param[out] mcHandle Value of handle returned. + * \param[in] prop Properties of the multicast object to create. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa ::cuMulticastAddDevice, ::cuMulticastBindMem, ::cuMulticastBindAddr, ::cuMulticastUnbind + * \sa ::cuMemCreate, ::cuMemRelease, ::cuMemExportToShareableHandle, ::cuMemImportFromShareableHandle + */ +CUresult CUDAAPI cuMulticastCreate(CUmemGenericAllocationHandle *mcHandle, const CUmulticastObjectProp *prop); + +/** + * \brief Associate a device to a multicast object. + * + * Associates a device to a multicast object. The added device will be a part of + * the multicast team of size specified by CUmulticastObjectProp::numDevices + * during ::cuMulticastCreate. + * The association of the device to the multicast object is permanent during + * the life time of the multicast object. + * All devices must be added to the multicast team before any memory can be + * bound to any device in the team. Any calls to ::cuMulticastBindMem or + * ::cuMulticastBindAddr will block until all devices have been added. + * Similarly all devices must be added to the multicast team before a virtual + * address range can be mapped to the multicast object. A call to ::cuMemMap + * will block until all devices have been added. + * + * \param[in] mcHandle Handle representing a multicast object. + * \param[in] dev Device that will be associated to the multicast + * object. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa ::cuMulticastCreate, ::cuMulticastBindMem, ::cuMulticastBindAddr + */ +CUresult CUDAAPI cuMulticastAddDevice(CUmemGenericAllocationHandle mcHandle, CUdevice dev); + +/** + * \brief Bind a memory allocation represented by a handle to a multicast object. + * + * Binds a memory allocation specified by \p memHandle and created via + * ::cuMemCreate to a multicast object represented by \p mcHandle and created + * via ::cuMulticastCreate. The intended \p size of the bind, the offset in the + * multicast range \p mcOffset as well as the offset in the memory \p memOffset + * must be a multiple of the value returned by ::cuMulticastGetGranularity with + * the flag ::CU_MULTICAST_GRANULARITY_MINIMUM. For best performance however, + * \p size, \p mcOffset and \p memOffset should be aligned to the granularity of + * the memory allocation(see ::cuMemGetAllocationGranularity) or to the value + * returned by ::cuMulticastGetGranularity with the flag + * ::CU_MULTICAST_GRANULARITY_RECOMMENDED. + * + * The \p size + \p memOffset cannot be larger than the size of the allocated + * memory. Similarly the \p size + \p mcOffset cannot be larger than the size + * of the multicast object. + * The memory allocation must have beeen created on one of the devices + * that was added to the multicast team via ::cuMulticastAddDevice. + * Externally shareable as well as imported multicast objects can be bound only + * to externally shareable memory. + * Note that this call will return CUDA_ERROR_OUT_OF_MEMORY if there are + * insufficient resources required to perform the bind. This call may also + * return CUDA_ERROR_SYSTEM_NOT_READY if the necessary system software is not + * initialized or running. + * + * \param[in] mcHandle Handle representing a multicast object. + * \param[in] mcOffset Offset into the multicast object for attachment. + * \param[in] memHandle Handle representing a memory allocation. + * \param[in] memOffset Offset into the memory for attachment. + * \param[in] size Size of the memory that will be bound to the + * multicast object. + * \param[in] flags Flags for future use, must be zero for now. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_SYSTEM_NOT_READY + * + * \sa ::cuMulticastCreate, ::cuMulticastAddDevice, ::cuMemCreate + */ +CUresult CUDAAPI cuMulticastBindMem(CUmemGenericAllocationHandle mcHandle, size_t mcOffset, CUmemGenericAllocationHandle memHandle, size_t memOffset, size_t size, unsigned long long flags); + +/** + * \brief Bind a memory allocation represented by a virtual address to a multicast object. + * + * Binds a memory allocation specified by its mapped address \p memptr to a + * multicast object represented by \p mcHandle. + * The memory must have been allocated via ::cuMemCreate or ::cudaMallocAsync. + * The intended \p size of the bind, the offset in the multicast range + * \p mcOffset and \p memptr must be a multiple of the value returned by + * ::cuMulticastGetGranularity with the flag ::CU_MULTICAST_GRANULARITY_MINIMUM. + * For best performance however, \p size, \p mcOffset and \p memptr should be + * aligned to the value returned by ::cuMulticastGetGranularity with the flag + * ::CU_MULTICAST_GRANULARITY_RECOMMENDED. + * + * The \p size cannot be larger than the size of the allocated memory. + * Similarly the \p size + \p mcOffset cannot be larger than the total size + * of the multicast object. + * The memory allocation must have beeen created on one of the devices + * that was added to the multicast team via ::cuMulticastAddDevice. + * Externally shareable as well as imported multicast objects can be bound only + * to externally shareable memory. + * Note that this call will return CUDA_ERROR_OUT_OF_MEMORY if there are + * insufficient resources required to perform the bind. This call may also + * return CUDA_ERROR_SYSTEM_NOT_READY if the necessary system software is not + * initialized or running. + * + * \param[in] mcHandle Handle representing a multicast object. + * \param[in] mcOffset Offset into multicast va range for attachment. + * \param[in] memptr Virtual address of the memory allocation. + * \param[in] size Size of memory that will be bound to the + * multicast object. + * \param[in] flags Flags for future use, must be zero now. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_SYSTEM_NOT_READY + * + * \sa ::cuMulticastCreate, ::cuMulticastAddDevice, ::cuMemCreate + */ +CUresult CUDAAPI cuMulticastBindAddr(CUmemGenericAllocationHandle mcHandle, size_t mcOffset, CUdeviceptr memptr, size_t size, unsigned long long flags); + +/** + * \brief Unbind any memory allocations bound to a multicast object at a given offset and upto a given size. + * + * Unbinds any memory allocations hosted on \p dev and bound to a multicast + * object at \p mcOffset and upto a given \p size. + * The intended \p size of the unbind and the offset in the multicast range + * ( \p mcOffset ) must be a multiple of the value returned by + * ::cuMulticastGetGranularity flag ::CU_MULTICAST_GRANULARITY_MINIMUM. + * The \p size + \p mcOffset cannot be larger than the total size of the + * multicast object. + * + * \note + * Warning: + * The \p mcOffset and the \p size must match the corresponding values specified + * during the bind call. Any other values may result in undefined behavior. + * + * \param[in] mcHandle Handle representing a multicast object. + * \param[in] dev Device that hosts the memory allocation. + * \param[in] mcOffset Offset into the multicast object. + * \param[in] size Desired size to unbind. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa ::cuMulticastBindMem, ::cuMulticastBindAddr + */ +CUresult CUDAAPI cuMulticastUnbind(CUmemGenericAllocationHandle mcHandle, CUdevice dev, size_t mcOffset, size_t size); + +/** +* \brief Calculates either the minimal or recommended granularity for multicast object +* +* Calculates either the minimal or recommended granularity for a given set of +* multicast object properties and returns it in granularity. This granularity +* can be used as a multiple for size, bind offsets and address mappings of the +* multicast object. +* +* \param[out] granularity Returned granularity. +* \param[in] prop Properties of the multicast object. +* \param[in] option Determines which granularity to return. +* +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMulticastCreate, ::cuMulticastBindMem, ::cuMulticastBindAddr, ::cuMulticastUnbind +*/ +CUresult CUDAAPI cuMulticastGetGranularity(size_t *granularity, const CUmulticastObjectProp *prop, CUmulticastGranularity_flags option); + +/** @} */ /* END CUDA_MULTICAST */ + +/** + * \defgroup CUDA_UNIFIED Unified Addressing + * + * ___MANBRIEF___ unified addressing functions of the low-level CUDA driver + * API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the unified addressing functions of the + * low-level CUDA driver application programming interface. + * + * @{ + * + * \section CUDA_UNIFIED_overview Overview + * + * CUDA devices can share a unified address space with the host. + * For these devices there is no distinction between a device + * pointer and a host pointer -- the same pointer value may be + * used to access memory from the host program and from a kernel + * running on the device (with exceptions enumerated below). + * + * \section CUDA_UNIFIED_support Supported Platforms + * + * Whether or not a device supports unified addressing may be + * queried by calling ::cuDeviceGetAttribute() with the device + * attribute ::CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING. + * + * Unified addressing is automatically enabled in 64-bit processes + * + * \section CUDA_UNIFIED_lookup Looking Up Information from Pointer Values + * + * It is possible to look up information about the memory which backs a + * pointer value. For instance, one may want to know if a pointer points + * to host or device memory. As another example, in the case of device + * memory, one may want to know on which CUDA device the memory + * resides. These properties may be queried using the function + * ::cuPointerGetAttribute() + * + * Since pointers are unique, it is not necessary to specify information + * about the pointers specified to the various copy functions in the + * CUDA API. The function ::cuMemcpy() may be used to perform a copy + * between two pointers, ignoring whether they point to host or device + * memory (making ::cuMemcpyHtoD(), ::cuMemcpyDtoD(), and ::cuMemcpyDtoH() + * unnecessary for devices supporting unified addressing). For + * multidimensional copies, the memory type ::CU_MEMORYTYPE_UNIFIED may be + * used to specify that the CUDA driver should infer the location of the + * pointer from its value. + * + * \section CUDA_UNIFIED_automaphost Automatic Mapping of Host Allocated Host Memory + * + * All host memory allocated in all contexts using ::cuMemAllocHost() and + * ::cuMemHostAlloc() is always directly accessible from all contexts on + * all devices that support unified addressing. This is the case regardless + * of whether or not the flags ::CU_MEMHOSTALLOC_PORTABLE and + * ::CU_MEMHOSTALLOC_DEVICEMAP are specified. + * + * The pointer value through which allocated host memory may be accessed + * in kernels on all devices that support unified addressing is the same + * as the pointer value through which that memory is accessed on the host, + * so it is not necessary to call ::cuMemHostGetDevicePointer() to get the device + * pointer for these allocations. + * + * Note that this is not the case for memory allocated using the flag + * ::CU_MEMHOSTALLOC_WRITECOMBINED, as discussed below. + * + * \section CUDA_UNIFIED_autopeerregister Automatic Registration of Peer Memory + * + * Upon enabling direct access from a context that supports unified addressing + * to another peer context that supports unified addressing using + * ::cuCtxEnablePeerAccess() all memory allocated in the peer context using + * ::cuMemAlloc() and ::cuMemAllocPitch() will immediately be accessible + * by the current context. The device pointer value through + * which any peer memory may be accessed in the current context + * is the same pointer value through which that memory may be + * accessed in the peer context. + * + * \section CUDA_UNIFIED_exceptions Exceptions, Disjoint Addressing + * + * Not all memory may be accessed on devices through the same pointer + * value through which they are accessed on the host. These exceptions + * are host memory registered using ::cuMemHostRegister() and host memory + * allocated using the flag ::CU_MEMHOSTALLOC_WRITECOMBINED. For these + * exceptions, there exists a distinct host and device address for the + * memory. The device address is guaranteed to not overlap any valid host + * pointer range and is guaranteed to have the same value across all + * contexts that support unified addressing. + * + * This device address may be queried using ::cuMemHostGetDevicePointer() + * when a context using unified addressing is current. Either the host + * or the unified device pointer value may be used to refer to this memory + * through ::cuMemcpy() and similar functions using the + * ::CU_MEMORYTYPE_UNIFIED memory type. + * + */ + +/** + * \brief Returns information about a pointer + * + * The supported attributes are: + * + * - ::CU_POINTER_ATTRIBUTE_CONTEXT: + * + * Returns in \p *data the ::CUcontext in which \p ptr was allocated or + * registered. + * The type of \p data must be ::CUcontext *. + * + * If \p ptr was not allocated by, mapped by, or registered with + * a ::CUcontext which uses unified virtual addressing then + * ::CUDA_ERROR_INVALID_VALUE is returned. + * + * - ::CU_POINTER_ATTRIBUTE_MEMORY_TYPE: + * + * Returns in \p *data the physical memory type of the memory that + * \p ptr addresses as a ::CUmemorytype enumerated value. + * The type of \p data must be unsigned int. + * + * If \p ptr addresses device memory then \p *data is set to + * ::CU_MEMORYTYPE_DEVICE. The particular ::CUdevice on which the + * memory resides is the ::CUdevice of the ::CUcontext returned by the + * ::CU_POINTER_ATTRIBUTE_CONTEXT attribute of \p ptr. + * + * If \p ptr addresses host memory then \p *data is set to + * ::CU_MEMORYTYPE_HOST. + * + * If \p ptr was not allocated by, mapped by, or registered with + * a ::CUcontext which uses unified virtual addressing then + * ::CUDA_ERROR_INVALID_VALUE is returned. + * + * If the current ::CUcontext does not support unified virtual + * addressing then ::CUDA_ERROR_INVALID_CONTEXT is returned. + * + * - ::CU_POINTER_ATTRIBUTE_DEVICE_POINTER: + * + * Returns in \p *data the device pointer value through which + * \p ptr may be accessed by kernels running in the current + * ::CUcontext. + * The type of \p data must be CUdeviceptr *. + * + * If there exists no device pointer value through which + * kernels running in the current ::CUcontext may access + * \p ptr then ::CUDA_ERROR_INVALID_VALUE is returned. + * + * If there is no current ::CUcontext then + * ::CUDA_ERROR_INVALID_CONTEXT is returned. + * + * Except in the exceptional disjoint addressing cases discussed + * below, the value returned in \p *data will equal the input + * value \p ptr. + * + * - ::CU_POINTER_ATTRIBUTE_HOST_POINTER: + * + * Returns in \p *data the host pointer value through which + * \p ptr may be accessed by by the host program. + * The type of \p data must be void **. + * If there exists no host pointer value through which + * the host program may directly access \p ptr then + * ::CUDA_ERROR_INVALID_VALUE is returned. + * + * Except in the exceptional disjoint addressing cases discussed + * below, the value returned in \p *data will equal the input + * value \p ptr. + * + * - ::CU_POINTER_ATTRIBUTE_P2P_TOKENS: + * + * Returns in \p *data two tokens for use with the nv-p2p.h Linux + * kernel interface. \p data must be a struct of type + * CUDA_POINTER_ATTRIBUTE_P2P_TOKENS. + * + * \p ptr must be a pointer to memory obtained from :cuMemAlloc(). + * Note that p2pToken and vaSpaceToken are only valid for the + * lifetime of the source allocation. A subsequent allocation at + * the same address may return completely different tokens. + * Querying this attribute has a side effect of setting the attribute + * ::CU_POINTER_ATTRIBUTE_SYNC_MEMOPS for the region of memory that + * \p ptr points to. + * + * - ::CU_POINTER_ATTRIBUTE_SYNC_MEMOPS: + * + * A boolean attribute which when set, ensures that synchronous memory operations + * initiated on the region of memory that \p ptr points to will always synchronize. + * See further documentation in the section titled "API synchronization behavior" + * to learn more about cases when synchronous memory operations can + * exhibit asynchronous behavior. + * + * - ::CU_POINTER_ATTRIBUTE_BUFFER_ID: + * + * Returns in \p *data a buffer ID which is guaranteed to be unique within the process. + * \p data must point to an unsigned long long. + * + * \p ptr must be a pointer to memory obtained from a CUDA memory allocation API. + * Every memory allocation from any of the CUDA memory allocation APIs will + * have a unique ID over a process lifetime. Subsequent allocations do not reuse IDs + * from previous freed allocations. IDs are only unique within a single process. + * + * + * - ::CU_POINTER_ATTRIBUTE_IS_MANAGED: + * + * Returns in \p *data a boolean that indicates whether the pointer points to + * managed memory or not. + * + * If \p ptr is not a valid CUDA pointer then ::CUDA_ERROR_INVALID_VALUE is returned. + * + * - ::CU_POINTER_ATTRIBUTE_DEVICE_ORDINAL: + * + * Returns in \p *data an integer representing a device ordinal of a device against + * which the memory was allocated or registered. + * + * - ::CU_POINTER_ATTRIBUTE_IS_LEGACY_CUDA_IPC_CAPABLE: + * + * Returns in \p *data a boolean that indicates if this pointer maps to + * an allocation that is suitable for ::cudaIpcGetMemHandle. + * + * - ::CU_POINTER_ATTRIBUTE_RANGE_START_ADDR: + * + * Returns in \p *data the starting address for the allocation referenced + * by the device pointer \p ptr. Note that this is not necessarily the + * address of the mapped region, but the address of the mappable address + * range \p ptr references (e.g. from ::cuMemAddressReserve). + * + * - ::CU_POINTER_ATTRIBUTE_RANGE_SIZE: + * + * Returns in \p *data the size for the allocation referenced by the device + * pointer \p ptr. Note that this is not necessarily the size of the mapped + * region, but the size of the mappable address range \p ptr references + * (e.g. from ::cuMemAddressReserve). To retrieve the size of the mapped + * region, see ::cuMemGetAddressRange + * + * - ::CU_POINTER_ATTRIBUTE_MAPPED: + * + * Returns in \p *data a boolean that indicates if this pointer is in a + * valid address range that is mapped to a backing allocation. + * + * - ::CU_POINTER_ATTRIBUTE_ALLOWED_HANDLE_TYPES: + * + * Returns a bitmask of the allowed handle types for an allocation that may + * be passed to ::cuMemExportToShareableHandle. + * + * - ::CU_POINTER_ATTRIBUTE_MEMPOOL_HANDLE: + * + * Returns in \p *data the handle to the mempool that the allocation was obtained from. + * + * + * \par + * + * Note that for most allocations in the unified virtual address space + * the host and device pointer for accessing the allocation will be the + * same. The exceptions to this are + * - user memory registered using ::cuMemHostRegister + * - host memory allocated using ::cuMemHostAlloc with the + * ::CU_MEMHOSTALLOC_WRITECOMBINED flag + * For these types of allocation there will exist separate, disjoint host + * and device addresses for accessing the allocation. In particular + * - The host address will correspond to an invalid unmapped device address + * (which will result in an exception if accessed from the device) + * - The device address will correspond to an invalid unmapped host address + * (which will result in an exception if accessed from the host). + * For these types of allocations, querying ::CU_POINTER_ATTRIBUTE_HOST_POINTER + * and ::CU_POINTER_ATTRIBUTE_DEVICE_POINTER may be used to retrieve the host + * and device addresses from either address. + * + * \param data - Returned pointer attribute value + * \param attribute - Pointer attribute to query + * \param ptr - Pointer + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuPointerSetAttribute, + * ::cuMemAlloc, + * ::cuMemFree, + * ::cuMemAllocHost, + * ::cuMemFreeHost, + * ::cuMemHostAlloc, + * ::cuMemHostRegister, + * ::cuMemHostUnregister, + * ::cudaPointerGetAttributes + */ +CUresult CUDAAPI cuPointerGetAttribute(void *data, CUpointer_attribute attribute, CUdeviceptr ptr); + +/** + * \brief Prefetches memory to the specified destination device + * + * Note there is a later version of this API, ::cuMemPrefetchAsync_v2. It will + * supplant this version in 13.0, which is retained for minor version compatibility. + * + * Prefetches memory to the specified destination device. \p devPtr is the + * base device pointer of the memory to be prefetched and \p dstDevice is the + * destination device. \p count specifies the number of bytes to copy. \p hStream + * is the stream in which the operation is enqueued. The memory range must refer + * to managed memory allocated via ::cuMemAllocManaged or declared via __managed__ variables + * or it may also refer to system-allocated memory on systems with non-zero + * CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. + * + * Passing in CU_DEVICE_CPU for \p dstDevice will prefetch the data to host memory. If + * \p dstDevice is a GPU, then the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS + * must be non-zero. Additionally, \p hStream must be associated with a device that has a + * non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * + * The start address and end address of the memory range will be rounded down and rounded up + * respectively to be aligned to CPU page size before the prefetch operation is enqueued + * in the stream. + * + * If no physical memory has been allocated for this region, then this memory region + * will be populated and mapped on the destination device. If there's insufficient + * memory to prefetch the desired region, the Unified Memory driver may evict pages from other + * ::cuMemAllocManaged allocations to host memory in order to make room. Device memory + * allocated using ::cuMemAlloc or ::cuArrayCreate will not be evicted. + * + * By default, any mappings to the previous location of the migrated pages are removed and + * mappings for the new location are only setup on \p dstDevice. The exact behavior however + * also depends on the settings applied to this memory range via ::cuMemAdvise as described + * below: + * + * If ::CU_MEM_ADVISE_SET_READ_MOSTLY was set on any subset of this memory range, + * then that subset will create a read-only copy of the pages on \p dstDevice. + * + * If ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION was called on any subset of this memory + * range, then the pages will be migrated to \p dstDevice even if \p dstDevice is not the + * preferred location of any pages in the memory range. + * + * If ::CU_MEM_ADVISE_SET_ACCESSED_BY was called on any subset of this memory range, + * then mappings to those pages from all the appropriate processors are updated to + * refer to the new location if establishing such a mapping is possible. Otherwise, + * those mappings are cleared. + * + * Note that this API is not required for functionality and only serves to improve performance + * by allowing the application to migrate data to a suitable location before it is accessed. + * Memory accesses to this range are always coherent and are allowed even when the data is + * actively being migrated. + * + * Note that this function is asynchronous with respect to the host and all work + * on other devices. + * + * \param devPtr - Pointer to be prefetched + * \param count - Size in bytes + * \param dstDevice - Destination device to prefetch to + * \param hStream - Stream to enqueue prefetch operation + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemcpy, ::cuMemcpyPeer, ::cuMemcpyAsync, + * ::cuMemcpy3DPeerAsync, ::cuMemAdvise, ::cuMemPrefetchAsync + * ::cudaMemPrefetchAsync_v2 + */ +CUresult CUDAAPI cuMemPrefetchAsync(CUdeviceptr devPtr, size_t count, CUdevice dstDevice, CUstream hStream); + +/** + * \brief Prefetches memory to the specified destination location + * + * Prefetches memory to the specified destination location. \p devPtr is the + * base device pointer of the memory to be prefetched and \p location specifies the + * destination location. \p count specifies the number of bytes to copy. \p hStream + * is the stream in which the operation is enqueued. The memory range must refer + * to managed memory allocated via ::cuMemAllocManaged or declared via __managed__ variables. + * + * Specifying ::CU_MEM_LOCATION_TYPE_DEVICE for ::CUmemLocation::type will prefetch memory to GPU + * specified by device ordinal ::CUmemLocation::id which must have non-zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. Additionally, \p hStream must be associated with a device + * that has a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * Specifying ::CU_MEM_LOCATION_TYPE_HOST as ::CUmemLocation::type will prefetch data to host memory. + * Applications can request prefetching memory to a specific host NUMA node by specifying + * ::CU_MEM_LOCATION_TYPE_HOST_NUMA for ::CUmemLocation::type and a valid host NUMA node id in ::CUmemLocation::id + * Users can also request prefetching memory to the host NUMA node closest to the current thread's CPU by specifying + * ::CU_MEM_LOCATION_TYPE_HOST_NUMA_CURRENT for ::CUmemLocation::type. Note when ::CUmemLocation::type is etiher + * ::CU_MEM_LOCATION_TYPE_HOST OR ::CU_MEM_LOCATION_TYPE_HOST_NUMA_CURRENT, ::CUmemLocation::id will be ignored. + * + * The start address and end address of the memory range will be rounded down and rounded up + * respectively to be aligned to CPU page size before the prefetch operation is enqueued + * in the stream. + * + * If no physical memory has been allocated for this region, then this memory region + * will be populated and mapped on the destination device. If there's insufficient + * memory to prefetch the desired region, the Unified Memory driver may evict pages from other + * ::cuMemAllocManaged allocations to host memory in order to make room. Device memory + * allocated using ::cuMemAlloc or ::cuArrayCreate will not be evicted. + * + * By default, any mappings to the previous location of the migrated pages are removed and + * mappings for the new location are only setup on the destination location. The exact behavior however + * also depends on the settings applied to this memory range via ::cuMemAdvise as described + * below: + * + * If ::CU_MEM_ADVISE_SET_READ_MOSTLY was set on any subset of this memory range, + * then that subset will create a read-only copy of the pages on destination location. + * If however the destination location is a host NUMA node, then any pages of that subset + * that are already in another host NUMA node will be transferred to the destination. + * + * If ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION was called on any subset of this memory + * range, then the pages will be migrated to \p location even if \p location is not the + * preferred location of any pages in the memory range. + * + * If ::CU_MEM_ADVISE_SET_ACCESSED_BY was called on any subset of this memory range, + * then mappings to those pages from all the appropriate processors are updated to + * refer to the new location if establishing such a mapping is possible. Otherwise, + * those mappings are cleared. + * + * Note that this API is not required for functionality and only serves to improve performance + * by allowing the application to migrate data to a suitable location before it is accessed. + * Memory accesses to this range are always coherent and are allowed even when the data is + * actively being migrated. + * + * Note that this function is asynchronous with respect to the host and all work + * on other devices. + * + * \param devPtr - Pointer to be prefetched + * \param count - Size in bytes + * \param dstDevice - Destination device to prefetch to + * \param flags - flags for future use, must be zero now. + * \param hStream - Stream to enqueue prefetch operation + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemcpy, ::cuMemcpyPeer, ::cuMemcpyAsync, + * ::cuMemcpy3DPeerAsync, ::cuMemAdvise, ::cuMemPrefetchAsync + * ::cudaMemPrefetchAsync_v2 + */ +CUresult CUDAAPI cuMemPrefetchAsync_v2(CUdeviceptr devPtr, size_t count, CUmemLocation location, unsigned int flags, CUstream hStream); + +/** + * \brief Advise about the usage of a given memory range + * + * Note there is a later version of this API, ::cuMemAdvise_v2. It will + * supplant this version in 13.0, which is retained for minor version compatibility. + * + * Advise the Unified Memory subsystem about the usage pattern for the memory range + * starting at \p devPtr with a size of \p count bytes. The start address and end address of the memory + * range will be rounded down and rounded up respectively to be aligned to CPU page size before the + * advice is applied. The memory range must refer to managed memory allocated via ::cuMemAllocManaged + * or declared via __managed__ variables. The memory range could also refer to system-allocated pageable + * memory provided it represents a valid, host-accessible region of memory and all additional constraints + * imposed by \p advice as outlined below are also satisfied. Specifying an invalid system-allocated pageable + * memory range results in an error being returned. + * + * The \p advice parameter can take the following values: + * - ::CU_MEM_ADVISE_SET_READ_MOSTLY: This implies that the data is mostly going to be read + * from and only occasionally written to. Any read accesses from any processor to this region will create a + * read-only copy of at least the accessed pages in that processor's memory. Additionally, if ::cuMemPrefetchAsync + * is called on this region, it will create a read-only copy of the data on the destination processor. + * If any processor writes to this region, all copies of the corresponding page will be invalidated + * except for the one where the write occurred. The \p device argument is ignored for this advice. + * Note that for a page to be read-duplicated, the accessing processor must either be the CPU or a GPU + * that has a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * Also, if a context is created on a device that does not have the device attribute + * ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS set, then read-duplication will not occur until + * all such contexts are destroyed. + * If the memory region refers to valid system-allocated pageable memory, then the accessing device must + * have a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS for a read-only + * copy to be created on that device. Note however that if the accessing device also has a non-zero value for the + * device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, then setting this advice + * will not create a read-only copy when that device accesses this memory region. + * + * - ::CU_MEM_ADVISE_UNSET_READ_MOSTLY: Undoes the effect of ::CU_MEM_ADVISE_SET_READ_MOSTLY and also prevents the + * Unified Memory driver from attempting heuristic read-duplication on the memory range. Any read-duplicated + * copies of the data will be collapsed into a single copy. The location for the collapsed + * copy will be the preferred location if the page has a preferred location and one of the read-duplicated + * copies was resident at that location. Otherwise, the location chosen is arbitrary. + * + * - ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION: This advice sets the preferred location for the + * data to be the memory belonging to \p device. Passing in CU_DEVICE_CPU for \p device sets the + * preferred location as host memory. If \p device is a GPU, then it must have a non-zero value for the + * device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. Setting the preferred location + * does not cause data to migrate to that location immediately. Instead, it guides the migration policy + * when a fault occurs on that memory region. If the data is already in its preferred location and the + * faulting processor can establish a mapping without requiring the data to be migrated, then + * data migration will be avoided. On the other hand, if the data is not in its preferred location + * or if a direct mapping cannot be established, then it will be migrated to the processor accessing + * it. It is important to note that setting the preferred location does not prevent data prefetching + * done using ::cuMemPrefetchAsync. + * Having a preferred location can override the page thrash detection and resolution logic in the Unified + * Memory driver. Normally, if a page is detected to be constantly thrashing between for example host and device + * memory, the page may eventually be pinned to host memory by the Unified Memory driver. But + * if the preferred location is set as device memory, then the page will continue to thrash indefinitely. + * If ::CU_MEM_ADVISE_SET_READ_MOSTLY is also set on this memory region or any subset of it, then the + * policies associated with that advice will override the policies of this advice, unless read accesses from + * \p device will not result in a read-only copy being created on that device as outlined in description for + * the advice ::CU_MEM_ADVISE_SET_READ_MOSTLY. + * If the memory region refers to valid system-allocated pageable memory, then \p device must have a non-zero + * value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. + * + * - ::CU_MEM_ADVISE_UNSET_PREFERRED_LOCATION: Undoes the effect of ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION + * and changes the preferred location to none. + * + * - ::CU_MEM_ADVISE_SET_ACCESSED_BY: This advice implies that the data will be accessed by \p device. + * Passing in ::CU_DEVICE_CPU for \p device will set the advice for the CPU. If \p device is a GPU, then + * the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS must be non-zero. + * This advice does not cause data migration and has no impact on the location of the data per se. Instead, + * it causes the data to always be mapped in the specified processor's page tables, as long as the + * location of the data permits a mapping to be established. If the data gets migrated for any reason, + * the mappings are updated accordingly. + * This advice is recommended in scenarios where data locality is not important, but avoiding faults is. + * Consider for example a system containing multiple GPUs with peer-to-peer access enabled, where the + * data located on one GPU is occasionally accessed by peer GPUs. In such scenarios, migrating data + * over to the other GPUs is not as important because the accesses are infrequent and the overhead of + * migration may be too high. But preventing faults can still help improve performance, and so having + * a mapping set up in advance is useful. Note that on CPU access of this data, the data may be migrated + * to host memory because the CPU typically cannot access device memory directly. Any GPU that had the + * ::CU_MEM_ADVISE_SET_ACCESSED_BY flag set for this data will now have its mapping updated to point to the + * page in host memory. + * If ::CU_MEM_ADVISE_SET_READ_MOSTLY is also set on this memory region or any subset of it, then the + * policies associated with that advice will override the policies of this advice. Additionally, if the + * preferred location of this memory region or any subset of it is also \p device, then the policies + * associated with ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION will override the policies of this advice. + * If the memory region refers to valid system-allocated pageable memory, then \p device must have a non-zero + * value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. Additionally, if \p device has + * a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, + * then this call has no effect. + * + * - ::CU_MEM_ADVISE_UNSET_ACCESSED_BY: Undoes the effect of ::CU_MEM_ADVISE_SET_ACCESSED_BY. Any mappings to + * the data from \p device may be removed at any time causing accesses to result in non-fatal page faults. + * If the memory region refers to valid system-allocated pageable memory, then \p device must have a non-zero + * value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. Additionally, if \p device has + * a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, + * then this call has no effect. + * + * \param devPtr - Pointer to memory to set the advice for + * \param count - Size in bytes of the memory range + * \param advice - Advice to be applied for the specified memory range + * \param device - Device to apply the advice for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemcpy, ::cuMemcpyPeer, ::cuMemcpyAsync, + * ::cuMemcpy3DPeerAsync, ::cuMemPrefetchAsync, ::cuMemAdvise_v2 + * ::cudaMemAdvise + */ +CUresult CUDAAPI cuMemAdvise(CUdeviceptr devPtr, size_t count, CUmem_advise advice, CUdevice device); + +/** + * \brief Advise about the usage of a given memory range + * + * Advise the Unified Memory subsystem about the usage pattern for the memory range + * starting at \p devPtr with a size of \p count bytes. The start address and end address of the memory + * range will be rounded down and rounded up respectively to be aligned to CPU page size before the + * advice is applied. The memory range must refer to managed memory allocated via ::cuMemAllocManaged + * or declared via __managed__ variables. The memory range could also refer to system-allocated pageable + * memory provided it represents a valid, host-accessible region of memory and all additional constraints + * imposed by \p advice as outlined below are also satisfied. Specifying an invalid system-allocated pageable + * memory range results in an error being returned. + * + * The \p advice parameter can take the following values: + * - ::CU_MEM_ADVISE_SET_READ_MOSTLY: This implies that the data is mostly going to be read + * from and only occasionally written to. Any read accesses from any processor to this region will create a + * read-only copy of at least the accessed pages in that processor's memory. Additionally, if ::cuMemPrefetchAsync + * or ::cuMemPrefetchAsync_v2 is called on this region, it will create a read-only copy of the data on the destination processor. + * If the target location for ::cuMemPrefetchAsync_v2 is a host NUMA node and a read-only copy already exists on + * another host NUMA node, that copy will be migrated to the targeted host NUMA node. + * If any processor writes to this region, all copies of the corresponding page will be invalidated + * except for the one where the write occurred. If the writing processor is the CPU and the preferred location of + * the page is a host NUMA node, then the page will also be migrated to that host NUMA node. The \p location argument is ignored for this advice. + * Note that for a page to be read-duplicated, the accessing processor must either be the CPU or a GPU + * that has a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * Also, if a context is created on a device that does not have the device attribute + * ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS set, then read-duplication will not occur until + * all such contexts are destroyed. + * If the memory region refers to valid system-allocated pageable memory, then the accessing device must + * have a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS for a read-only + * copy to be created on that device. Note however that if the accessing device also has a non-zero value for the + * device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, then setting this advice + * will not create a read-only copy when that device accesses this memory region. + * + * - ::CU_MEM_ADVISE_UNSET_READ_MOSTLY: Undoes the effect of ::CU_MEM_ADVISE_SET_READ_MOSTLY and also prevents the + * Unified Memory driver from attempting heuristic read-duplication on the memory range. Any read-duplicated + * copies of the data will be collapsed into a single copy. The location for the collapsed + * copy will be the preferred location if the page has a preferred location and one of the read-duplicated + * copies was resident at that location. Otherwise, the location chosen is arbitrary. + * Note: The \p location argument is ignored for this advice. + * + * - ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION: This advice sets the preferred location for the + * data to be the memory belonging to \p location. When ::CUmemLocation::type is ::CU_MEM_LOCATION_TYPE_HOST, + * ::CUmemLocation::id is ignored and the preferred location is set to be host memory. To set the preferred location + * to a specific host NUMA node, applications must set ::CUmemLocation::type to ::CU_MEM_LOCATION_TYPE_HOST_NUMA and + * ::CUmemLocation::id must specify the NUMA ID of the host NUMA node. If ::CUmemLocation::type is set to ::CU_MEM_LOCATION_TYPE_HOST_NUMA_CURRENT, + * ::CUmemLocation::id will be ignored and the the host NUMA node closest to the calling thread's CPU will be used as the preferred location. + * If ::CUmemLocation::type is a ::CU_MEM_LOCATION_TYPE_DEVICE, then ::CUmemLocation::id must be a valid device ordinal + * and the device must have a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * Setting the preferred location does not cause data to migrate to that location immediately. Instead, it guides the migration policy + * when a fault occurs on that memory region. If the data is already in its preferred location and the + * faulting processor can establish a mapping without requiring the data to be migrated, then + * data migration will be avoided. On the other hand, if the data is not in its preferred location + * or if a direct mapping cannot be established, then it will be migrated to the processor accessing + * it. It is important to note that setting the preferred location does not prevent data prefetching + * done using ::cuMemPrefetchAsync. + * Having a preferred location can override the page thrash detection and resolution logic in the Unified + * Memory driver. Normally, if a page is detected to be constantly thrashing between for example host and device + * memory, the page may eventually be pinned to host memory by the Unified Memory driver. But + * if the preferred location is set as device memory, then the page will continue to thrash indefinitely. + * If ::CU_MEM_ADVISE_SET_READ_MOSTLY is also set on this memory region or any subset of it, then the + * policies associated with that advice will override the policies of this advice, unless read accesses from + * \p location will not result in a read-only copy being created on that procesor as outlined in description for + * the advice ::CU_MEM_ADVISE_SET_READ_MOSTLY. + * If the memory region refers to valid system-allocated pageable memory, and ::CUmemLocation::type is CU_MEM_LOCATION_TYPE_DEVICE + * then ::CUmemLocation::id must be a valid device that has a non-zero alue for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. + * + * - ::CU_MEM_ADVISE_UNSET_PREFERRED_LOCATION: Undoes the effect of ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION + * and changes the preferred location to none. The \p location argument is ignored for this advice. + * + * - ::CU_MEM_ADVISE_SET_ACCESSED_BY: This advice implies that the data will be accessed by processor \p location. + * The ::CUmemLocation::type must be either ::CU_MEM_LOCATION_TYPE_DEVICE with ::CUmemLocation::id representing a valid device + * ordinal or ::CU_MEM_LOCATION_TYPE_HOST and ::CUmemLocation::id will be ignored. All other location types are invalid. + * If ::CUmemLocation::id is a GPU, then the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS must be non-zero. + * This advice does not cause data migration and has no impact on the location of the data per se. Instead, + * it causes the data to always be mapped in the specified processor's page tables, as long as the + * location of the data permits a mapping to be established. If the data gets migrated for any reason, + * the mappings are updated accordingly. + * This advice is recommended in scenarios where data locality is not important, but avoiding faults is. + * Consider for example a system containing multiple GPUs with peer-to-peer access enabled, where the + * data located on one GPU is occasionally accessed by peer GPUs. In such scenarios, migrating data + * over to the other GPUs is not as important because the accesses are infrequent and the overhead of + * migration may be too high. But preventing faults can still help improve performance, and so having + * a mapping set up in advance is useful. Note that on CPU access of this data, the data may be migrated + * to host memory because the CPU typically cannot access device memory directly. Any GPU that had the + * ::CU_MEM_ADVISE_SET_ACCESSED_BY flag set for this data will now have its mapping updated to point to the + * page in host memory. + * If ::CU_MEM_ADVISE_SET_READ_MOSTLY is also set on this memory region or any subset of it, then the + * policies associated with that advice will override the policies of this advice. Additionally, if the + * preferred location of this memory region or any subset of it is also \p location, then the policies + * associated with ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION will override the policies of this advice. + * If the memory region refers to valid system-allocated pageable memory, and ::CUmemLocation::type is ::CU_MEM_LOCATION_TYPE_DEVICE + * then device in ::CUmemLocation::id must have a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. + * Additionally, if ::CUmemLocation::id has a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, + * then this call has no effect. + * + * - ::CU_MEM_ADVISE_UNSET_ACCESSED_BY: Undoes the effect of ::CU_MEM_ADVISE_SET_ACCESSED_BY. Any mappings to + * the data from \p location may be removed at any time causing accesses to result in non-fatal page faults. + * If the memory region refers to valid system-allocated pageable memory, and ::CUmemLocation::type is ::CU_MEM_LOCATION_TYPE_DEVICE + * then device in ::CUmemLocation::id must have a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. + * Additionally, if ::CUmemLocation::id has a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, + * then this call has no effect. + * + * \param devPtr - Pointer to memory to set the advice for + * \param count - Size in bytes of the memory range + * \param advice - Advice to be applied for the specified memory range + * \param location - location to apply the advice for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemcpy, ::cuMemcpyPeer, ::cuMemcpyAsync, + * ::cuMemcpy3DPeerAsync, ::cuMemPrefetchAsync, ::cuMemAdvise + * ::cudaMemAdvise + */ +CUresult CUDAAPI cuMemAdvise_v2(CUdeviceptr devPtr, size_t count, CUmem_advise advice, CUmemLocation location); + +/** + * \brief Query an attribute of a given memory range + * + * Query an attribute about the memory range starting at \p devPtr with a size of \p count bytes. The + * memory range must refer to managed memory allocated via ::cuMemAllocManaged or declared via + * __managed__ variables. + * + * The \p attribute parameter can take the following values: + * - ::CU_MEM_RANGE_ATTRIBUTE_READ_MOSTLY: If this attribute is specified, \p data will be interpreted + * as a 32-bit integer, and \p dataSize must be 4. The result returned will be 1 if all pages in the given + * memory range have read-duplication enabled, or 0 otherwise. + * - ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION: If this attribute is specified, \p data will be + * interpreted as a 32-bit integer, and \p dataSize must be 4. The result returned will be a GPU device + * id if all pages in the memory range have that GPU as their preferred location, or it will be CU_DEVICE_CPU + * if all pages in the memory range have the CPU as their preferred location, or it will be CU_DEVICE_INVALID + * if either all the pages don't have the same preferred location or some of the pages don't have a + * preferred location at all. Note that the actual location of the pages in the memory range at the time of + * the query may be different from the preferred location. + * - ::CU_MEM_RANGE_ATTRIBUTE_ACCESSED_BY: If this attribute is specified, \p data will be interpreted + * as an array of 32-bit integers, and \p dataSize must be a non-zero multiple of 4. The result returned + * will be a list of device ids that had ::CU_MEM_ADVISE_SET_ACCESSED_BY set for that entire memory range. + * If any device does not have that advice set for the entire memory range, that device will not be included. + * If \p data is larger than the number of devices that have that advice set for that memory range, + * CU_DEVICE_INVALID will be returned in all the extra space provided. For ex., if \p dataSize is 12 + * (i.e. \p data has 3 elements) and only device 0 has the advice set, then the result returned will be + * { 0, CU_DEVICE_INVALID, CU_DEVICE_INVALID }. If \p data is smaller than the number of devices that have + * that advice set, then only as many devices will be returned as can fit in the array. There is no + * guarantee on which specific devices will be returned, however. + * - ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION: If this attribute is specified, \p data will be + * interpreted as a 32-bit integer, and \p dataSize must be 4. The result returned will be the last location + * to which all pages in the memory range were prefetched explicitly via ::cuMemPrefetchAsync. This will either be + * a GPU id or CU_DEVICE_CPU depending on whether the last location for prefetch was a GPU or the CPU + * respectively. If any page in the memory range was never explicitly prefetched or if all pages were not + * prefetched to the same location, CU_DEVICE_INVALID will be returned. Note that this simply returns the + * last location that the application requested to prefetch the memory range to. It gives no indication as to + * whether the prefetch operation to that location has completed or even begun. + * - ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_TYPE: If this attribute is specified, \p data will be + * interpreted as a ::CUmemLocationType, and \p dataSize must be sizeof(CUmemLocationType). The ::CUmemLocationType returned will be + * ::CU_MEM_LOCATION_TYPE_DEVICE if all pages in the memory range have the same GPU as their preferred location, or ::CUmemLocationType + * will be ::CU_MEM_LOCATION_TYPE_HOST if all pages in the memory range have the CPU as their preferred location, or it will be ::CU_MEM_LOCATION_TYPE_HOST_NUMA + * if all the pages in the memory range have the same host NUMA node ID as their preferred location or it will be ::CU_MEM_LOCATION_TYPE_INVALID + * if either all the pages don't have the same preferred location or some of the pages don't have a preferred location at all. + * Note that the actual location type of the pages in the memory range at the time of the query may be different from the preferred location type. + * - ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_ID: If this attribute is specified, \p data will be + * interpreted as a 32-bit integer, and \p dataSize must be 4. If the ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_TYPE query for the same address range + * returns ::CU_MEM_LOCATION_TYPE_DEVICE, it will be a valid device ordinal or if it returns ::CU_MEM_LOCATION_TYPE_HOST_NUMA, it will be a valid host NUMA node ID + * or if it returns any other location type, the id should be ignored. + * - ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_TYPE: If this attribute is specified, \p data will be + * interpreted as a ::CUmemLocationType, and \p dataSize must be sizeof(CUmemLocationType). The result returned will be the last location + * to which all pages in the memory range were prefetched explicitly via ::cuMemPrefetchAsync. The ::CUmemLocationType returned + * will be ::CU_MEM_LOCATION_TYPE_DEVICE if the last prefetch location was a GPU or ::CU_MEM_LOCATION_TYPE_HOST if it was the CPU or ::CU_MEM_LOCATION_TYPE_HOST_NUMA if + * the last prefetch location was a specific host NUMA node. If any page in the memory range was never explicitly prefetched or if all pages were not + * prefetched to the same location, ::CUmemLocationType will be ::CU_MEM_LOCATION_TYPE_INVALID. + * Note that this simply returns the last location type that the application requested to prefetch the memory range to. It gives no indication as to + * whether the prefetch operation to that location has completed or even begun. + * - ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_ID: If this attribute is specified, \p data will be + * interpreted as a 32-bit integer, and \p dataSize must be 4. If the ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_TYPE query for the same address range + * returns ::CU_MEM_LOCATION_TYPE_DEVICE, it will be a valid device ordinal or if it returns ::CU_MEM_LOCATION_TYPE_HOST_NUMA, it will be a valid host NUMA node ID + * or if it returns any other location type, the id should be ignored. + * + * \param data - A pointers to a memory location where the result + * of each attribute query will be written to. + * \param dataSize - Array containing the size of data + * \param attribute - The attribute to query + * \param devPtr - Start of the range to query + * \param count - Size of the range to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemRangeGetAttributes, ::cuMemPrefetchAsync, + * ::cuMemAdvise, + * ::cudaMemRangeGetAttribute + */ +CUresult CUDAAPI cuMemRangeGetAttribute(void *data, size_t dataSize, CUmem_range_attribute attribute, CUdeviceptr devPtr, size_t count); + +/** + * \brief Query attributes of a given memory range. + * + * Query attributes of the memory range starting at \p devPtr with a size of \p count bytes. The + * memory range must refer to managed memory allocated via ::cuMemAllocManaged or declared via + * __managed__ variables. The \p attributes array will be interpreted to have \p numAttributes + * entries. The \p dataSizes array will also be interpreted to have \p numAttributes entries. + * The results of the query will be stored in \p data. + * + * The list of supported attributes are given below. Please refer to ::cuMemRangeGetAttribute for + * attribute descriptions and restrictions. + * + * - ::CU_MEM_RANGE_ATTRIBUTE_READ_MOSTLY + * - ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION + * - ::CU_MEM_RANGE_ATTRIBUTE_ACCESSED_BY + * - ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION + * - ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_TYPE + * - ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_ID + * - ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_TYPE + * - ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_ID + * + * \param data - A two-dimensional array containing pointers to memory + * locations where the result of each attribute query will be written to. + * \param dataSizes - Array containing the sizes of each result + * \param attributes - An array of attributes to query + * (numAttributes and the number of attributes in this array should match) + * \param numAttributes - Number of attributes to query + * \param devPtr - Start of the range to query + * \param count - Size of the range to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa ::cuMemRangeGetAttribute, ::cuMemAdvise, + * ::cuMemPrefetchAsync, + * ::cudaMemRangeGetAttributes + */ +CUresult CUDAAPI cuMemRangeGetAttributes(void **data, size_t *dataSizes, CUmem_range_attribute *attributes, size_t numAttributes, CUdeviceptr devPtr, size_t count); + +/** + * \brief Set attributes on a previously allocated memory region + * + * The supported attributes are: + * + * - ::CU_POINTER_ATTRIBUTE_SYNC_MEMOPS: + * + * A boolean attribute that can either be set (1) or unset (0). When set, + * the region of memory that \p ptr points to is guaranteed to always synchronize + * memory operations that are synchronous. If there are some previously initiated + * synchronous memory operations that are pending when this attribute is set, the + * function does not return until those memory operations are complete. + * See further documentation in the section titled "API synchronization behavior" + * to learn more about cases when synchronous memory operations can + * exhibit asynchronous behavior. + * \p value will be considered as a pointer to an unsigned integer to which this attribute is to be set. + * + * \param value - Pointer to memory containing the value to be set + * \param attribute - Pointer attribute to set + * \param ptr - Pointer to a memory region allocated using CUDA memory allocation APIs + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa ::cuPointerGetAttribute, + * ::cuPointerGetAttributes, + * ::cuMemAlloc, + * ::cuMemFree, + * ::cuMemAllocHost, + * ::cuMemFreeHost, + * ::cuMemHostAlloc, + * ::cuMemHostRegister, + * ::cuMemHostUnregister + */ +CUresult CUDAAPI cuPointerSetAttribute(const void *value, CUpointer_attribute attribute, CUdeviceptr ptr); + +/** + * \brief Returns information about a pointer. + * + * The supported attributes are (refer to ::cuPointerGetAttribute for attribute descriptions and restrictions): + * + * - ::CU_POINTER_ATTRIBUTE_CONTEXT + * - ::CU_POINTER_ATTRIBUTE_MEMORY_TYPE + * - ::CU_POINTER_ATTRIBUTE_DEVICE_POINTER + * - ::CU_POINTER_ATTRIBUTE_HOST_POINTER + * - ::CU_POINTER_ATTRIBUTE_SYNC_MEMOPS + * - ::CU_POINTER_ATTRIBUTE_BUFFER_ID + * - ::CU_POINTER_ATTRIBUTE_IS_MANAGED + * - ::CU_POINTER_ATTRIBUTE_DEVICE_ORDINAL + * - ::CU_POINTER_ATTRIBUTE_RANGE_START_ADDR + * - ::CU_POINTER_ATTRIBUTE_RANGE_SIZE + * - ::CU_POINTER_ATTRIBUTE_MAPPED + * - ::CU_POINTER_ATTRIBUTE_IS_LEGACY_CUDA_IPC_CAPABLE + * - ::CU_POINTER_ATTRIBUTE_ALLOWED_HANDLE_TYPES + * - ::CU_POINTER_ATTRIBUTE_MEMPOOL_HANDLE + * + * \param numAttributes - Number of attributes to query + * \param attributes - An array of attributes to query + * (numAttributes and the number of attributes in this array should match) + * \param data - A two-dimensional array containing pointers to memory + * locations where the result of each attribute query will be written to. + * \param ptr - Pointer to query + * + * Unlike ::cuPointerGetAttribute, this function will not return an error when the \p ptr + * encountered is not a valid CUDA pointer. Instead, the attributes are assigned default NULL values + * and CUDA_SUCCESS is returned. + * + * If \p ptr was not allocated by, mapped by, or registered with a ::CUcontext which uses UVA + * (Unified Virtual Addressing), ::CUDA_ERROR_INVALID_CONTEXT is returned. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuPointerGetAttribute, + * ::cuPointerSetAttribute, + * ::cudaPointerGetAttributes + */ +CUresult CUDAAPI cuPointerGetAttributes(unsigned int numAttributes, CUpointer_attribute *attributes, void **data, CUdeviceptr ptr); + +/** @} */ /* END CUDA_UNIFIED */ + +/** + * \defgroup CUDA_STREAM Stream Management + * + * ___MANBRIEF___ stream management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the stream management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Create a stream + * + * Creates a stream and returns a handle in \p phStream. The \p Flags argument + * determines behaviors of the stream. + * + * Valid values for \p Flags are: + * - ::CU_STREAM_DEFAULT: Default stream creation flag. + * - ::CU_STREAM_NON_BLOCKING: Specifies that work running in the created + * stream may run concurrently with work in stream 0 (the NULL stream), and that + * the created stream should perform no implicit synchronization with stream 0. + * + * \param phStream - Returned newly created stream + * \param Flags - Parameters for stream creation + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreateWithPriority, + * ::cuGreenCtxStreamCreate, + * ::cuStreamGetPriority, + * ::cuStreamGetFlags, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamCreate, + * ::cudaStreamCreateWithFlags + */ +CUresult CUDAAPI cuStreamCreate(CUstream *phStream, unsigned int Flags); + +/** + * \brief Create a stream with the given priority + * + * Creates a stream with the specified priority and returns a handle in \p phStream. + * This affects the scheduling priority of work in the stream. Priorities provide a + * hint to preferentially run work with higher priority when possible, but do + * not preempt already-running work or provide any other functional guarantee on + * execution order. + * + * \p priority follows a convention where lower numbers represent higher priorities. + * '0' represents default priority. The range of meaningful numerical priorities can + * be queried using ::cuCtxGetStreamPriorityRange. If the specified priority is + * outside the numerical range returned by ::cuCtxGetStreamPriorityRange, + * it will automatically be clamped to the lowest or the highest number in the range. + * + * \param phStream - Returned newly created stream + * \param flags - Flags for stream creation. See ::cuStreamCreate for a list of + * valid flags + * \param priority - Stream priority. Lower numbers represent higher priorities. + * See ::cuCtxGetStreamPriorityRange for more information about + * meaningful stream priorities that can be passed. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \note Stream priorities are supported only on GPUs + * with compute capability 3.5 or higher. + * + * \note In the current implementation, only compute kernels launched in + * priority streams are affected by the stream's priority. Stream priorities have + * no effect on host-to-device and device-to-host memory operations. + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreate, + * ::cuGreenCtxStreamCreate, + * ::cuStreamGetPriority, + * ::cuCtxGetStreamPriorityRange, + * ::cuStreamGetFlags, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamCreateWithPriority + */ +CUresult CUDAAPI cuStreamCreateWithPriority(CUstream *phStream, unsigned int flags, int priority); + + +/** + * \brief Query the priority of a given stream + * + * Query the priority of a stream created using ::cuStreamCreate, ::cuStreamCreateWithPriority or ::cuGreenCtxStreamCreate + * and return the priority in \p priority. Note that if the stream was created with a + * priority outside the numerical range returned by ::cuCtxGetStreamPriorityRange, + * this function returns the clamped priority. + * See ::cuStreamCreateWithPriority for details about priority clamping. + * + * \param hStream - Handle to the stream to be queried + * \param priority - Pointer to a signed integer in which the stream's priority is returned + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreate, + * ::cuStreamCreateWithPriority, + * ::cuGreenCtxStreamCreate, + * ::cuCtxGetStreamPriorityRange, + * ::cuStreamGetFlags, + * ::cudaStreamGetPriority + */ +CUresult CUDAAPI cuStreamGetPriority(CUstream hStream, int *priority); + +/** + * \brief Query the flags of a given stream + * + * Query the flags of a stream created using ::cuStreamCreate, ::cuStreamCreateWithPriority or ::cuGreenCtxStreamCreate + * and return the flags in \p flags. + * + * \param hStream - Handle to the stream to be queried + * \param flags - Pointer to an unsigned integer in which the stream's flags are returned + * The value returned in \p flags is a logical 'OR' of all flags that + * were used while creating this stream. See ::cuStreamCreate for the list + * of valid flags + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreate, + * ::cuGreenCtxStreamCreate, + * ::cuStreamGetPriority, + * ::cudaStreamGetFlags + */ +CUresult CUDAAPI cuStreamGetFlags(CUstream hStream, unsigned int *flags); + +/** + * \brief Returns the unique Id associated with the stream handle supplied + * + * Returns in \p streamId the unique Id which is associated with the given stream handle. + * The Id is unique for the life of the program. + * + * The stream handle \p hStream can refer to any of the following: + *
    + *
  • a stream created via any of the CUDA driver APIs such as ::cuStreamCreate + * and ::cuStreamCreateWithPriority, or their runtime API equivalents such as + * ::cudaStreamCreate, ::cudaStreamCreateWithFlags and ::cudaStreamCreateWithPriority. + * Passing an invalid handle will result in undefined behavior.
  • + *
  • any of the special streams such as the NULL stream, ::CU_STREAM_LEGACY and + * ::CU_STREAM_PER_THREAD. The runtime API equivalents of these are also accepted, + * which are NULL, ::cudaStreamLegacy and ::cudaStreamPerThread respectively.
  • + *
+ * + * \param hStream - Handle to the stream to be queried + * \param streamId - Pointer to store the Id of the stream + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreate, + * ::cuStreamGetPriority, + * ::cudaStreamGetId + */ +CUresult CUDAAPI cuStreamGetId(CUstream hStream, unsigned long long *streamId); + +/** + * \brief Query the context associated with a stream + * + * Returns the CUDA context that the stream is associated with. + * + * Note there is a later version of this API, ::cuStreamGetCtx_v2. It will + * supplant this version in CUDA 13.0. It is recommended to use ::cuStreamGetCtx_v2 + * till then as this version will return ::CUDA_ERROR_NOT_SUPPORTED for streams created via the API ::cuGreenCtxStreamCreate. + * + * The stream handle \p hStream can refer to any of the following: + *
    + *
  • a stream created via any of the CUDA driver APIs such as ::cuStreamCreate + * and ::cuStreamCreateWithPriority, or their runtime API equivalents such as + * ::cudaStreamCreate, ::cudaStreamCreateWithFlags and ::cudaStreamCreateWithPriority. + * The returned context is the context that was active in the calling thread when the + * stream was created. Passing an invalid handle will result in undefined behavior.
  • + *
  • any of the special streams such as the NULL stream, ::CU_STREAM_LEGACY and + * ::CU_STREAM_PER_THREAD. The runtime API equivalents of these are also accepted, + * which are NULL, ::cudaStreamLegacy and ::cudaStreamPerThread respectively. + * Specifying any of the special handles will return the context current to the + * calling thread. If no context is current to the calling thread, + * ::CUDA_ERROR_INVALID_CONTEXT is returned.
  • + *
+ * + * \param hStream - Handle to the stream to be queried + * \param pctx - Returned context associated with the stream + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreateWithPriority, + * ::cuStreamGetPriority, + * ::cuStreamGetFlags, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamCreate, + * ::cuStreamGetCtx_v2, + * ::cudaStreamCreateWithFlags + */ +CUresult CUDAAPI cuStreamGetCtx(CUstream hStream, CUcontext *pctx); + +/** + * \brief Query the contexts associated with a stream + * + * Returns the contexts that the stream is associated with. + * + * If the stream is associated with a green context, the API returns the green context in \p pGreenCtx + * and the primary context of the associated device in \p pCtx. + * + * If the stream is associated with a regular context, the API returns the regular context in \p pCtx + * and NULL in \p pGreenCtx. + * + * The stream handle \p hStream can refer to any of the following: + *
    + *
  • a stream created via any of the CUDA driver APIs such as ::cuStreamCreate, + * ::cuStreamCreateWithPriority and ::cuGreenCtxStreamCreate, or their runtime API equivalents such as + * ::cudaStreamCreate, ::cudaStreamCreateWithFlags and ::cudaStreamCreateWithPriority. + * Passing an invalid handle will result in undefined behavior.
  • + *
  • any of the special streams such as the NULL stream, ::CU_STREAM_LEGACY and + * ::CU_STREAM_PER_THREAD. The runtime API equivalents of these are also accepted, + * which are NULL, ::cudaStreamLegacy and ::cudaStreamPerThread respectively. + * If any of the special handles are specified, the API will operate on the context current to the + * calling thread. If a green context (that was converted via ::cuCtxFromGreenCtx() before setting it current) + * is current to the calling thread, the API will return the green context in \p pGreenCtx + * and the primary context of the associated device in \p pCtx. If a regular context is current, + * the API returns the regular context in \p pCtx and NULL in \p pGreenCtx. + * Note that specifying ::CU_STREAM_PER_THREAD or ::cudaStreamPerThread will return ::CUDA_ERROR_INVALID_HANDLE + * if a green context is current to the calling thread. + * If no context is current to the calling thread, ::CUDA_ERROR_INVALID_CONTEXT is returned.
  • + *
+ * + * \param hStream - Handle to the stream to be queried + * \param pCtx - Returned regular context associated with the stream + * \param pGreenCtx - Returned green context if the stream is associated with a green context or NULL if not + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreate + * ::cuStreamCreateWithPriority, + * ::cuGreenCtxStreamCreate, + * ::cuStreamGetPriority, + * ::cuStreamGetFlags, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamCreate, + * ::cudaStreamCreateWithFlags, + */ +CUresult CUDAAPI cuStreamGetCtx_v2(CUstream hStream, CUcontext *pCtx, CUgreenCtx *pGreenCtx); + +/** + * \brief Make a compute stream wait on an event + * + * Makes all future work submitted to \p hStream wait for all work captured in + * \p hEvent. See ::cuEventRecord() for details on what is captured by an event. + * The synchronization will be performed efficiently on the device when applicable. + * \p hEvent may be from a different context or device than \p hStream. + * + * flags include: + * - ::CU_EVENT_WAIT_DEFAULT: Default event creation flag. + * - ::CU_EVENT_WAIT_EXTERNAL: Event is captured in the graph as an external + * event node when performing stream capture. This flag is invalid outside + * of stream capture. + * + * \param hStream - Stream to wait + * \param hEvent - Event to wait on (may not be NULL) + * \param Flags - See ::CUevent_capture_flags + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * \note_null_stream + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuEventRecord, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cuStreamDestroy, + * ::cudaStreamWaitEvent + */ +CUresult CUDAAPI cuStreamWaitEvent(CUstream hStream, CUevent hEvent, unsigned int Flags); + +/** + * \brief Add a callback to a compute stream + * + * \note This function is slated for eventual deprecation and removal. If + * you do not require the callback to execute in case of a device error, + * consider using ::cuLaunchHostFunc. Additionally, this function is not + * supported with ::cuStreamBeginCapture and ::cuStreamEndCapture, unlike + * ::cuLaunchHostFunc. + * + * Adds a callback to be called on the host after all currently enqueued + * items in the stream have completed. For each + * cuStreamAddCallback call, the callback will be executed exactly once. + * The callback will block later work in the stream until it is finished. + * + * The callback may be passed ::CUDA_SUCCESS or an error code. In the event + * of a device error, all subsequently executed callbacks will receive an + * appropriate ::CUresult. + * + * Callbacks must not make any CUDA API calls. Attempting to use a CUDA API + * will result in ::CUDA_ERROR_NOT_PERMITTED. Callbacks must not perform any + * synchronization that may depend on outstanding device work or other callbacks + * that are not mandated to run earlier. Callbacks without a mandated order + * (in independent streams) execute in undefined order and may be serialized. + * + * For the purposes of Unified Memory, callback execution makes a number of + * guarantees: + *
    + *
  • The callback stream is considered idle for the duration of the + * callback. Thus, for example, a callback may always use memory attached + * to the callback stream.
  • + *
  • The start of execution of a callback has the same effect as + * synchronizing an event recorded in the same stream immediately prior to + * the callback. It thus synchronizes streams which have been "joined" + * prior to the callback.
  • + *
  • Adding device work to any stream does not have the effect of making + * the stream active until all preceding host functions and stream callbacks + * have executed. Thus, for + * example, a callback might use global attached memory even if work has + * been added to another stream, if the work has been ordered behind the + * callback with an event.
  • + *
  • Completion of a callback does not cause a stream to become + * active except as described above. The callback stream will remain idle + * if no device work follows the callback, and will remain idle across + * consecutive callbacks without device work in between. Thus, for example, + * stream synchronization can be done by signaling from a callback at the + * end of the stream.
  • + *
+ * + * \param hStream - Stream to add callback to + * \param callback - The function to call once preceding stream operations are complete + * \param userData - User specified data to be passed to the callback function + * \param flags - Reserved for future use, must be 0 + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_null_stream + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamWaitEvent, + * ::cuStreamDestroy, + * ::cuMemAllocManaged, + * ::cuStreamAttachMemAsync, + * ::cuLaunchHostFunc, + * ::cudaStreamAddCallback + */ +CUresult CUDAAPI cuStreamAddCallback(CUstream hStream, CUstreamCallback callback, void *userData, unsigned int flags); + +/** + * \brief Begins graph capture on a stream + * + * Begin graph capture on \p hStream. When a stream is in capture mode, all operations + * pushed into the stream will not be executed, but will instead be captured into + * a graph, which will be returned via ::cuStreamEndCapture. Capture may not be initiated + * if \p stream is CU_STREAM_LEGACY. Capture must be ended on the same stream in which + * it was initiated, and it may only be initiated if the stream is not already in capture + * mode. The capture mode may be queried via ::cuStreamIsCapturing. A unique id + * representing the capture sequence may be queried via ::cuStreamGetCaptureInfo. + * + * If \p mode is not ::CU_STREAM_CAPTURE_MODE_RELAXED, ::cuStreamEndCapture must be + * called on this stream from the same thread. + * + * \param hStream - Stream in which to initiate capture + * \param mode - Controls the interaction of this capture sequence with other API + * calls that are potentially unsafe. For more details see + * ::cuThreadExchangeStreamCaptureMode. + * + * \note Kernels captured using this API must not use texture and surface references. + * Reading or writing through any texture or surface reference is undefined + * behavior. This restriction does not apply to texture and surface objects. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuStreamCreate, + * ::cuStreamIsCapturing, + * ::cuStreamEndCapture, + * ::cuThreadExchangeStreamCaptureMode + */ +CUresult CUDAAPI cuStreamBeginCapture(CUstream hStream, CUstreamCaptureMode mode); + +/** + * \brief Begins graph capture on a stream to an existing graph + * + * Begin graph capture on \p hStream, placing new nodes into an existing graph. When a stream is + * in capture mode, all operations pushed into the stream will not be executed, but will instead + * be captured into \p hGraph. The graph will not be instantiable until the user calls + * ::cuStreamEndCapture. + * + * Capture may not be initiated if \p stream is CU_STREAM_LEGACY. Capture must be ended on the + * same stream in which it was initiated, and it may only be initiated if the stream is not + * already in capture mode. The capture mode may be queried via ::cuStreamIsCapturing. A unique id + * representing the capture sequence may be queried via ::cuStreamGetCaptureInfo. + * + * If \p mode is not ::CU_STREAM_CAPTURE_MODE_RELAXED, ::cuStreamEndCapture must be + * called on this stream from the same thread. + * + * \param hStream - Stream in which to initiate capture. + * \param hGraph - Graph to capture into. + * \param dependencies - Dependencies of the first node captured in the stream. Can be NULL if numDependencies is 0. + * \param dependencyData - Optional array of data associated with each dependency. + * \param numDependencies - Number of dependencies. + * \param mode - Controls the interaction of this capture sequence with other API + * calls that are potentially unsafe. For more details see + * ::cuThreadExchangeStreamCaptureMode. + * + * \note Kernels captured using this API must not use texture and surface references. + * Reading or writing through any texture or surface reference is undefined + * behavior. This restriction does not apply to texture and surface objects. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuStreamBeginCapture, + * ::cuStreamCreate, + * ::cuStreamIsCapturing, + * ::cuStreamEndCapture, + * ::cuThreadExchangeStreamCaptureMode, + * ::cuGraphAddNode, + */ +CUresult CUDAAPI cuStreamBeginCaptureToGraph(CUstream hStream, CUgraph hGraph, const CUgraphNode *dependencies, const CUgraphEdgeData *dependencyData, size_t numDependencies, CUstreamCaptureMode mode); + +/** + * \brief Swaps the stream capture interaction mode for a thread + * + * Sets the calling thread's stream capture interaction mode to the value contained + * in \p *mode, and overwrites \p *mode with the previous mode for the thread. To + * facilitate deterministic behavior across function or module boundaries, callers + * are encouraged to use this API in a push-pop fashion: \code + CUstreamCaptureMode mode = desiredMode; + cuThreadExchangeStreamCaptureMode(&mode); + ... + cuThreadExchangeStreamCaptureMode(&mode); // restore previous mode + * \endcode + * + * During stream capture (see ::cuStreamBeginCapture), some actions, such as a call + * to ::cudaMalloc, may be unsafe. In the case of ::cudaMalloc, the operation is + * not enqueued asynchronously to a stream, and is not observed by stream capture. + * Therefore, if the sequence of operations captured via ::cuStreamBeginCapture + * depended on the allocation being replayed whenever the graph is launched, the + * captured graph would be invalid. + * + * Therefore, stream capture places restrictions on API calls that can be made within + * or concurrently to a ::cuStreamBeginCapture-::cuStreamEndCapture sequence. This + * behavior can be controlled via this API and flags to ::cuStreamBeginCapture. + * + * A thread's mode is one of the following: + * - \p CU_STREAM_CAPTURE_MODE_GLOBAL: This is the default mode. If the local thread has + * an ongoing capture sequence that was not initiated with + * \p CU_STREAM_CAPTURE_MODE_RELAXED at \p cuStreamBeginCapture, or if any other thread + * has a concurrent capture sequence initiated with \p CU_STREAM_CAPTURE_MODE_GLOBAL, + * this thread is prohibited from potentially unsafe API calls. + * - \p CU_STREAM_CAPTURE_MODE_THREAD_LOCAL: If the local thread has an ongoing capture + * sequence not initiated with \p CU_STREAM_CAPTURE_MODE_RELAXED, it is prohibited + * from potentially unsafe API calls. Concurrent capture sequences in other threads + * are ignored. + * - \p CU_STREAM_CAPTURE_MODE_RELAXED: The local thread is not prohibited from potentially + * unsafe API calls. Note that the thread is still prohibited from API calls which + * necessarily conflict with stream capture, for example, attempting ::cuEventQuery + * on an event that was last recorded inside a capture sequence. + * + * \param mode - Pointer to mode value to swap with the current mode + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuStreamBeginCapture + */ +CUresult CUDAAPI cuThreadExchangeStreamCaptureMode(CUstreamCaptureMode *mode); + +/** + * \brief Ends capture on a stream, returning the captured graph + * + * End capture on \p hStream, returning the captured graph via \p phGraph. + * Capture must have been initiated on \p hStream via a call to ::cuStreamBeginCapture. + * If capture was invalidated, due to a violation of the rules of stream capture, then + * a NULL graph will be returned. + * + * If the \p mode argument to ::cuStreamBeginCapture was not + * ::CU_STREAM_CAPTURE_MODE_RELAXED, this call must be from the same thread as + * ::cuStreamBeginCapture. + * + * \param hStream - Stream to query + * \param phGraph - The captured graph + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_STREAM_CAPTURE_WRONG_THREAD + * \notefnerr + * + * \sa + * ::cuStreamCreate, + * ::cuStreamBeginCapture, + * ::cuStreamIsCapturing, + * ::cuGraphDestroy + */ +CUresult CUDAAPI cuStreamEndCapture(CUstream hStream, CUgraph *phGraph); + +/** + * \brief Returns a stream's capture status + * + * Return the capture status of \p hStream via \p captureStatus. After a successful + * call, \p *captureStatus will contain one of the following: + * - ::CU_STREAM_CAPTURE_STATUS_NONE: The stream is not capturing. + * - ::CU_STREAM_CAPTURE_STATUS_ACTIVE: The stream is capturing. + * - ::CU_STREAM_CAPTURE_STATUS_INVALIDATED: The stream was capturing but an error + * has invalidated the capture sequence. The capture sequence must be terminated + * with ::cuStreamEndCapture on the stream where it was initiated in order to + * continue using \p hStream. + * + * Note that, if this is called on ::CU_STREAM_LEGACY (the "null stream") while + * a blocking stream in the same context is capturing, it will return + * ::CUDA_ERROR_STREAM_CAPTURE_IMPLICIT and \p *captureStatus is unspecified + * after the call. The blocking stream capture is not invalidated. + * + * When a blocking stream is capturing, the legacy stream is in an + * unusable state until the blocking stream capture is terminated. The legacy + * stream is not supported for stream capture, but attempted use would have an + * implicit dependency on the capturing stream(s). + * + * \param hStream - Stream to query + * \param captureStatus - Returns the stream's capture status + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_STREAM_CAPTURE_IMPLICIT + * \notefnerr + * + * \sa + * ::cuStreamCreate, + * ::cuStreamBeginCapture, + * ::cuStreamEndCapture + */ +CUresult CUDAAPI cuStreamIsCapturing(CUstream hStream, CUstreamCaptureStatus *captureStatus); + + +/** + * \brief Query a stream's capture state + * + * Query stream state related to stream capture. + * + * If called on ::CU_STREAM_LEGACY (the "null stream") while a stream not created + * with ::CU_STREAM_NON_BLOCKING is capturing, returns ::CUDA_ERROR_STREAM_CAPTURE_IMPLICIT. + * + * Valid data (other than capture status) is returned only if both of the following are true: + * - the call returns CUDA_SUCCESS + * - the returned capture status is ::CU_STREAM_CAPTURE_STATUS_ACTIVE + * + * \param hStream - The stream to query + * \param captureStatus_out - Location to return the capture status of the stream; required + * \param id_out - Optional location to return an id for the capture sequence, which is + * unique over the lifetime of the process + * \param graph_out - Optional location to return the graph being captured into. All + * operations other than destroy and node removal are permitted on the graph + * while the capture sequence is in progress. This API does not transfer + * ownership of the graph, which is transferred or destroyed at + * ::cuStreamEndCapture. Note that the graph handle may be invalidated before + * end of capture for certain errors. Nodes that are or become + * unreachable from the original stream at ::cuStreamEndCapture due to direct + * actions on the graph do not trigger ::CUDA_ERROR_STREAM_CAPTURE_UNJOINED. + * \param dependencies_out - Optional location to store a pointer to an array of nodes. + * The next node to be captured in the stream will depend on this set of nodes, + * absent operations such as event wait which modify this set. The array pointer + * is valid until the next API call which operates on the stream or until the + * capture is terminated. The node handles may be copied out and are valid until + * they or the graph is destroyed. The driver-owned array may also be passed + * directly to APIs that operate on the graph (not the stream) without copying. + * \param numDependencies_out - Optional location to store the size of the array + * returned in dependencies_out. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_STREAM_CAPTURE_IMPLICIT + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuStreamGetCaptureInfo_v3 + * ::cuStreamBeginCapture, + * ::cuStreamIsCapturing, + * ::cuStreamUpdateCaptureDependencies + */ +CUresult CUDAAPI cuStreamGetCaptureInfo(CUstream hStream, CUstreamCaptureStatus *captureStatus_out, + cuuint64_t *id_out, CUgraph *graph_out, const CUgraphNode **dependencies_out, size_t *numDependencies_out); + +/** + * \brief Query a stream's capture state (12.3+) + * + * Query stream state related to stream capture. + * + * If called on ::CU_STREAM_LEGACY (the "null stream") while a stream not created + * with ::CU_STREAM_NON_BLOCKING is capturing, returns ::CUDA_ERROR_STREAM_CAPTURE_IMPLICIT. + * + * Valid data (other than capture status) is returned only if both of the following are true: + * - the call returns CUDA_SUCCESS + * - the returned capture status is ::CU_STREAM_CAPTURE_STATUS_ACTIVE + * + * If \p edgeData_out is non-NULL then \p dependencies_out must be as well. If + * \p dependencies_out is non-NULL and \p edgeData_out is NULL, but there is non-zero edge + * data for one or more of the current stream dependencies, the call will return + * ::CUDA_ERROR_LOSSY_QUERY. + * + * \param hStream - The stream to query + * \param captureStatus_out - Location to return the capture status of the stream; required + * \param id_out - Optional location to return an id for the capture sequence, which is + * unique over the lifetime of the process + * \param graph_out - Optional location to return the graph being captured into. All + * operations other than destroy and node removal are permitted on the graph + * while the capture sequence is in progress. This API does not transfer + * ownership of the graph, which is transferred or destroyed at + * ::cuStreamEndCapture. Note that the graph handle may be invalidated before + * end of capture for certain errors. Nodes that are or become + * unreachable from the original stream at ::cuStreamEndCapture due to direct + * actions on the graph do not trigger ::CUDA_ERROR_STREAM_CAPTURE_UNJOINED. + * \param dependencies_out - Optional location to store a pointer to an array of nodes. + * The next node to be captured in the stream will depend on this set of nodes, + * absent operations such as event wait which modify this set. The array pointer + * is valid until the next API call which operates on the stream or until the + * capture is terminated. The node handles may be copied out and are valid until + * they or the graph is destroyed. The driver-owned array may also be passed + * directly to APIs that operate on the graph (not the stream) without copying. + * \param edgeData_out - Optional location to store a pointer to an array of graph edge + * data. This array parallels \c dependencies_out; the next node to be added + * has an edge to \c dependencies_out[i] with annotation \c edgeData_out[i] for + * each \c i. The array pointer is valid until the next API call which operates + * on the stream or until the capture is terminated. + * \param numDependencies_out - Optional location to store the size of the array + * returned in dependencies_out. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_STREAM_CAPTURE_IMPLICIT, + * ::CUDA_ERROR_LOSSY_QUERY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuStreamGetCaptureInfo + * ::cuStreamBeginCapture, + * ::cuStreamIsCapturing, + * ::cuStreamUpdateCaptureDependencies + */ +CUresult CUDAAPI cuStreamGetCaptureInfo_v3(CUstream hStream, CUstreamCaptureStatus *captureStatus_out, + cuuint64_t *id_out, CUgraph *graph_out, const CUgraphNode **dependencies_out, + const CUgraphEdgeData **edgeData_out, size_t *numDependencies_out); + +/** + * \brief Update the set of dependencies in a capturing stream (11.3+) + * + * Modifies the dependency set of a capturing stream. The dependency set is the set + * of nodes that the next captured node in the stream will depend on. + * + * Valid flags are ::CU_STREAM_ADD_CAPTURE_DEPENDENCIES and + * ::CU_STREAM_SET_CAPTURE_DEPENDENCIES. These control whether the set passed to + * the API is added to the existing set or replaces it. A flags value of 0 defaults + * to ::CU_STREAM_ADD_CAPTURE_DEPENDENCIES. + * + * Nodes that are removed from the dependency set via this API do not result in + * ::CUDA_ERROR_STREAM_CAPTURE_UNJOINED if they are unreachable from the stream at + * ::cuStreamEndCapture. + * + * Returns ::CUDA_ERROR_ILLEGAL_STATE if the stream is not capturing. + * + * This API is new in CUDA 11.3. Developers requiring compatibility across minor + * versions to CUDA 11.0 should not use this API or provide a fallback. + * + * \param hStream - The stream to update + * \param dependencies - The set of dependencies to add + * \param numDependencies - The size of the dependencies array + * \param flags - See above + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_ILLEGAL_STATE + * + * \sa + * ::cuStreamBeginCapture, + * ::cuStreamGetCaptureInfo, + */ +CUresult CUDAAPI cuStreamUpdateCaptureDependencies(CUstream hStream, CUgraphNode *dependencies, size_t numDependencies, unsigned int flags); + +/** + * \brief Update the set of dependencies in a capturing stream (12.3+) + * + * Modifies the dependency set of a capturing stream. The dependency set is the set + * of nodes that the next captured node in the stream will depend on along with the + * edge data for those dependencies. + * + * Valid flags are ::CU_STREAM_ADD_CAPTURE_DEPENDENCIES and + * ::CU_STREAM_SET_CAPTURE_DEPENDENCIES. These control whether the set passed to + * the API is added to the existing set or replaces it. A flags value of 0 defaults + * to ::CU_STREAM_ADD_CAPTURE_DEPENDENCIES. + * + * Nodes that are removed from the dependency set via this API do not result in + * ::CUDA_ERROR_STREAM_CAPTURE_UNJOINED if they are unreachable from the stream at + * ::cuStreamEndCapture. + * + * Returns ::CUDA_ERROR_ILLEGAL_STATE if the stream is not capturing. + * + * \param hStream - The stream to update + * \param dependencies - The set of dependencies to add + * \param dependencyData - Optional array of data associated with each dependency. + * \param numDependencies - The size of the dependencies array + * \param flags - See above + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_ILLEGAL_STATE + * + * \sa + * ::cuStreamBeginCapture, + * ::cuStreamGetCaptureInfo, + */ +CUresult CUDAAPI cuStreamUpdateCaptureDependencies_v2(CUstream hStream, CUgraphNode *dependencies, + const CUgraphEdgeData *dependencyData, size_t numDependencies, unsigned int flags); + +/** + * \brief Attach memory to a stream asynchronously + * + * Enqueues an operation in \p hStream to specify stream association of + * \p length bytes of memory starting from \p dptr. This function is a + * stream-ordered operation, meaning that it is dependent on, and will + * only take effect when, previous work in stream has completed. Any + * previous association is automatically replaced. + * + * \p dptr must point to one of the following types of memories: + * - managed memory declared using the __managed__ keyword or allocated with + * ::cuMemAllocManaged. + * - a valid host-accessible region of system-allocated pageable memory. This + * type of memory may only be specified if the device associated with the + * stream reports a non-zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. + * + * For managed allocations, \p length must be either zero or the entire + * allocation's size. Both indicate that the entire allocation's stream + * association is being changed. Currently, it is not possible to change stream + * association for a portion of a managed allocation. + * + * For pageable host allocations, \p length must be non-zero. + * + * The stream association is specified using \p flags which must be + * one of ::CUmemAttach_flags. + * If the ::CU_MEM_ATTACH_GLOBAL flag is specified, the memory can be accessed + * by any stream on any device. + * If the ::CU_MEM_ATTACH_HOST flag is specified, the program makes a guarantee + * that it won't access the memory on the device from any stream on a device that + * has a zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * If the ::CU_MEM_ATTACH_SINGLE flag is specified and \p hStream is associated with + * a device that has a zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS, + * the program makes a guarantee that it will only access the memory on the device + * from \p hStream. It is illegal to attach singly to the NULL stream, because the + * NULL stream is a virtual global stream and not a specific stream. An error will + * be returned in this case. + * + * When memory is associated with a single stream, the Unified Memory system will + * allow CPU access to this memory region so long as all operations in \p hStream + * have completed, regardless of whether other streams are active. In effect, + * this constrains exclusive ownership of the managed memory region by + * an active GPU to per-stream activity instead of whole-GPU activity. + * + * Accessing memory on the device from streams that are not associated with + * it will produce undefined results. No error checking is performed by the + * Unified Memory system to ensure that kernels launched into other streams + * do not access this region. + * + * It is a program's responsibility to order calls to ::cuStreamAttachMemAsync + * via events, synchronization or other means to ensure legal access to memory + * at all times. Data visibility and coherency will be changed appropriately + * for all kernels which follow a stream-association change. + * + * If \p hStream is destroyed while data is associated with it, the association is + * removed and the association reverts to the default visibility of the allocation + * as specified at ::cuMemAllocManaged. For __managed__ variables, the default + * association is always ::CU_MEM_ATTACH_GLOBAL. Note that destroying a stream is an + * asynchronous operation, and as a result, the change to default association won't + * happen until all work in the stream has completed. + * + * \param hStream - Stream in which to enqueue the attach operation + * \param dptr - Pointer to memory (must be a pointer to managed memory or + * to a valid host-accessible region of system-allocated + * pageable memory) + * \param length - Length of memory + * \param flags - Must be one of ::CUmemAttach_flags + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_null_stream + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamWaitEvent, + * ::cuStreamDestroy, + * ::cuMemAllocManaged, + * ::cudaStreamAttachMemAsync + */ +CUresult CUDAAPI cuStreamAttachMemAsync(CUstream hStream, CUdeviceptr dptr, size_t length, unsigned int flags); + +/** + * \brief Determine status of a compute stream + * + * Returns ::CUDA_SUCCESS if all operations in the stream specified by + * \p hStream have completed, or ::CUDA_ERROR_NOT_READY if not. + * + * For the purposes of Unified Memory, a return value of ::CUDA_SUCCESS + * is equivalent to having called ::cuStreamSynchronize(). + * + * \param hStream - Stream to query status of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_READY + * \note_null_stream + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuStreamWaitEvent, + * ::cuStreamDestroy, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamQuery + */ +CUresult CUDAAPI cuStreamQuery(CUstream hStream); + +/** + * \brief Wait until a stream's tasks are completed + * + * Waits until the device has completed all operations in the stream specified + * by \p hStream. If the context was created with the + * ::CU_CTX_SCHED_BLOCKING_SYNC flag, the CPU thread will block until the + * stream is finished with all of its tasks. + * + * \param hStream - Stream to wait for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE + + * \note_null_stream + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuStreamDestroy, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamAddCallback, + * ::cudaStreamSynchronize + */ +CUresult CUDAAPI cuStreamSynchronize(CUstream hStream); + +/** + * \brief Destroys a stream + * + * Destroys the stream specified by \p hStream. + * + * In case the device is still doing work in the stream \p hStream + * when ::cuStreamDestroy() is called, the function will return immediately + * and the resources associated with \p hStream will be released automatically + * once the device has completed all work in \p hStream. + * + * \param hStream - Stream to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamDestroy + */ +CUresult CUDAAPI cuStreamDestroy(CUstream hStream); + +/** + * \brief Copies attributes from source stream to destination stream. + * + * Copies attributes from source stream \p src to destination stream \p dst. + * Both streams must have the same context. + * + * \param[out] dst Destination stream + * \param[in] src Source stream + * For list of attributes see ::CUstreamAttrID + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuStreamCopyAttributes(CUstream dst, CUstream src); + +/** + * \brief Queries stream attribute. + * + * Queries attribute \p attr from \p hStream and stores it in corresponding + * member of \p value_out. + * + * \param[in] hStream + * \param[in] attr + * \param[out] value_out + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuStreamGetAttribute(CUstream hStream, CUstreamAttrID attr, + CUstreamAttrValue *value_out); + +/** + * \brief Sets stream attribute. + * + * Sets attribute \p attr on \p hStream from corresponding attribute of + * \p value. The updated attribute will be applied to subsequent work + * submitted to the stream. It will not affect previously submitted work. + * + * \param[out] hStream + * \param[in] attr + * \param[in] value + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuStreamSetAttribute(CUstream hStream, CUstreamAttrID attr, + const CUstreamAttrValue *value); + +/** @} */ /* END CUDA_STREAM */ + + +/** + * \defgroup CUDA_EVENT Event Management + * + * ___MANBRIEF___ event management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the event management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Creates an event + * + * Creates an event *phEvent for the current context with the flags specified via + * \p Flags. Valid flags include: + * - ::CU_EVENT_DEFAULT: Default event creation flag. + * - ::CU_EVENT_BLOCKING_SYNC: Specifies that the created event should use blocking + * synchronization. A CPU thread that uses ::cuEventSynchronize() to wait on + * an event created with this flag will block until the event has actually + * been recorded. + * - ::CU_EVENT_DISABLE_TIMING: Specifies that the created event does not need + * to record timing data. Events created with this flag specified and + * the ::CU_EVENT_BLOCKING_SYNC flag not specified will provide the best + * performance when used with ::cuStreamWaitEvent() and ::cuEventQuery(). + * - ::CU_EVENT_INTERPROCESS: Specifies that the created event may be used as an + * interprocess event by ::cuIpcGetEventHandle(). ::CU_EVENT_INTERPROCESS must + * be specified along with ::CU_EVENT_DISABLE_TIMING. + * + * \param phEvent - Returns newly created event + * \param Flags - Event creation flags + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa + * ::cuEventRecord, + * ::cuEventQuery, + * ::cuEventSynchronize, + * ::cuEventDestroy, + * ::cuEventElapsedTime, + * ::cudaEventCreate, + * ::cudaEventCreateWithFlags + */ +CUresult CUDAAPI cuEventCreate(CUevent *phEvent, unsigned int Flags); + +/** + * \brief Records an event + * + * Captures in \p hEvent the contents of \p hStream at the time of this call. + * \p hEvent and \p hStream must be from the same context otherwise + * ::CUDA_ERROR_INVALID_HANDLE is returned. + * Calls such as ::cuEventQuery() or ::cuStreamWaitEvent() will then + * examine or wait for completion of the work that was captured. Uses of + * \p hStream after this call do not modify \p hEvent. See note on default + * stream behavior for what is captured in the default case. + * + * ::cuEventRecord() can be called multiple times on the same event and + * will overwrite the previously captured state. Other APIs such as + * ::cuStreamWaitEvent() use the most recently captured state at the time + * of the API call, and are not affected by later calls to + * ::cuEventRecord(). Before the first call to ::cuEventRecord(), an + * event represents an empty set of work, so for example ::cuEventQuery() + * would return ::CUDA_SUCCESS. + * + * \param hEvent - Event to record + * \param hStream - Stream to record event for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * \note_null_stream + * \notefnerr + * + * \sa ::cuEventCreate, + * ::cuEventQuery, + * ::cuEventSynchronize, + * ::cuStreamWaitEvent, + * ::cuEventDestroy, + * ::cuEventElapsedTime, + * ::cudaEventRecord, + * ::cuEventRecordWithFlags + */ +CUresult CUDAAPI cuEventRecord(CUevent hEvent, CUstream hStream); + +/** + * \brief Records an event + * + * Captures in \p hEvent the contents of \p hStream at the time of this call. + * \p hEvent and \p hStream must be from the same context otherwise + * ::CUDA_ERROR_INVALID_HANDLE is returned. + * Calls such as ::cuEventQuery() or ::cuStreamWaitEvent() will then + * examine or wait for completion of the work that was captured. Uses of + * \p hStream after this call do not modify \p hEvent. See note on default + * stream behavior for what is captured in the default case. + * + * ::cuEventRecordWithFlags() can be called multiple times on the same event and + * will overwrite the previously captured state. Other APIs such as + * ::cuStreamWaitEvent() use the most recently captured state at the time + * of the API call, and are not affected by later calls to + * ::cuEventRecordWithFlags(). Before the first call to ::cuEventRecordWithFlags(), an + * event represents an empty set of work, so for example ::cuEventQuery() + * would return ::CUDA_SUCCESS. + * + * flags include: + * - ::CU_EVENT_RECORD_DEFAULT: Default event creation flag. + * - ::CU_EVENT_RECORD_EXTERNAL: Event is captured in the graph as an external + * event node when performing stream capture. This flag is invalid outside + * of stream capture. + * + * \param hEvent - Event to record + * \param hStream - Stream to record event for + * \param flags - See ::CUevent_capture_flags + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * \note_null_stream + * \notefnerr + * + * \sa ::cuEventCreate, + * ::cuEventQuery, + * ::cuEventSynchronize, + * ::cuStreamWaitEvent, + * ::cuEventDestroy, + * ::cuEventElapsedTime, + * ::cuEventRecord, + * ::cudaEventRecord + */ +CUresult CUDAAPI cuEventRecordWithFlags(CUevent hEvent, CUstream hStream, unsigned int flags); + +/** + * \brief Queries an event's status + * + * Queries the status of all work currently captured by \p hEvent. See + * ::cuEventRecord() for details on what is captured by an event. + * + * Returns ::CUDA_SUCCESS if all captured work has been completed, or + * ::CUDA_ERROR_NOT_READY if any captured work is incomplete. + * + * For the purposes of Unified Memory, a return value of ::CUDA_SUCCESS + * is equivalent to having called ::cuEventSynchronize(). + * + * \param hEvent - Event to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_READY + * \notefnerr + * + * \sa ::cuEventCreate, + * ::cuEventRecord, + * ::cuEventSynchronize, + * ::cuEventDestroy, + * ::cuEventElapsedTime, + * ::cudaEventQuery + */ +CUresult CUDAAPI cuEventQuery(CUevent hEvent); + +/** + * \brief Waits for an event to complete + * + * Waits until the completion of all work currently captured in \p hEvent. + * See ::cuEventRecord() for details on what is captured by an event. + * + * Waiting for an event that was created with the ::CU_EVENT_BLOCKING_SYNC + * flag will cause the calling CPU thread to block until the event has + * been completed by the device. If the ::CU_EVENT_BLOCKING_SYNC flag has + * not been set, then the CPU thread will busy-wait until the event has + * been completed by the device. + * + * \param hEvent - Event to wait for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuEventCreate, + * ::cuEventRecord, + * ::cuEventQuery, + * ::cuEventDestroy, + * ::cuEventElapsedTime, + * ::cudaEventSynchronize + */ +CUresult CUDAAPI cuEventSynchronize(CUevent hEvent); + +/** + * \brief Destroys an event + * + * Destroys the event specified by \p hEvent. + * + * An event may be destroyed before it is complete (i.e., while + * ::cuEventQuery() would return ::CUDA_ERROR_NOT_READY). In this case, the + * call does not block on completion of the event, and any associated + * resources will automatically be released asynchronously at completion. + * + * \param hEvent - Event to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuEventCreate, + * ::cuEventRecord, + * ::cuEventQuery, + * ::cuEventSynchronize, + * ::cuEventElapsedTime, + * ::cudaEventDestroy + */ +CUresult CUDAAPI cuEventDestroy(CUevent hEvent); + +/** + * \brief Computes the elapsed time between two events + * + * Computes the elapsed time between two events (in milliseconds with a + * resolution of around 0.5 microseconds). + * + * If either event was last recorded in a non-NULL stream, the resulting time + * may be greater than expected (even if both used the same stream handle). This + * happens because the ::cuEventRecord() operation takes place asynchronously + * and there is no guarantee that the measured latency is actually just between + * the two events. Any number of other different stream operations could execute + * in between the two measured events, thus altering the timing in a significant + * way. + * + * If ::cuEventRecord() has not been called on either event then + * ::CUDA_ERROR_INVALID_HANDLE is returned. If ::cuEventRecord() has been called + * on both events but one or both of them has not yet been completed (that is, + * ::cuEventQuery() would return ::CUDA_ERROR_NOT_READY on at least one of the + * events), ::CUDA_ERROR_NOT_READY is returned. If either event was created with + * the ::CU_EVENT_DISABLE_TIMING flag, then this function will return + * ::CUDA_ERROR_INVALID_HANDLE. + * + * \param pMilliseconds - Time between \p hStart and \p hEnd in ms + * \param hStart - Starting event + * \param hEnd - Ending event + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_READY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuEventCreate, + * ::cuEventRecord, + * ::cuEventQuery, + * ::cuEventSynchronize, + * ::cuEventDestroy, + * ::cudaEventElapsedTime + */ +CUresult CUDAAPI cuEventElapsedTime(float *pMilliseconds, CUevent hStart, CUevent hEnd); + +/** @} */ /* END CUDA_EVENT */ + +/** + * \defgroup CUDA_EXTRES_INTEROP External Resource Interoperability + * + * ___MANBRIEF___ External resource interoperability functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the external resource interoperability functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + + /** + * \brief Imports an external memory object + * + * Imports an externally allocated memory object and returns + * a handle to that in \p extMem_out. + * + * The properties of the handle being imported must be described in + * \p memHandleDesc. The ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC structure + * is defined as follows: + * + * \code + typedef struct CUDA_EXTERNAL_MEMORY_HANDLE_DESC_st { + CUexternalMemoryHandleType type; + union { + int fd; + struct { + void *handle; + const void *name; + } win32; + const void *nvSciBufObject; + } handle; + unsigned long long size; + unsigned int flags; + } CUDA_EXTERNAL_MEMORY_HANDLE_DESC; + * \endcode + * + * where ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type specifies the type + * of handle being imported. ::CUexternalMemoryHandleType is + * defined as: + * + * \code + typedef enum CUexternalMemoryHandleType_enum { + CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD = 1, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32 = 2, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT = 3, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP = 4, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE = 5, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE = 6, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE_KMT = 7, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF = 8 + } CUexternalMemoryHandleType; + * \endcode + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD, then + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::fd must be a valid + * file descriptor referencing a memory object. Ownership of + * the file descriptor is transferred to the CUDA driver when the + * handle is imported successfully. Performing any operations on the + * file descriptor after it is imported results in undefined behavior. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32, then exactly one + * of ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle and + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name must not be + * NULL. If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle + * is not NULL, then it must represent a valid shared NT handle that + * references a memory object. Ownership of this handle is + * not transferred to CUDA after the import operation, so the + * application must release the handle using the appropriate system + * call. If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name + * is not NULL, then it must point to a NULL-terminated array of + * UTF-16 characters that refers to a memory object. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT, then + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle must + * be non-NULL and + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name + * must be NULL. The handle specified must be a globally shared KMT + * handle. This handle does not hold a reference to the underlying + * object, and thus will be invalid when all references to the + * memory object are destroyed. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP, then exactly one + * of ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle and + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name must not be + * NULL. If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle + * is not NULL, then it must represent a valid shared NT handle that + * is returned by ID3D12Device::CreateSharedHandle when referring to a + * ID3D12Heap object. This handle holds a reference to the underlying + * object. If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name + * is not NULL, then it must point to a NULL-terminated array of + * UTF-16 characters that refers to a ID3D12Heap object. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE, then exactly one + * of ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle and + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name must not be + * NULL. If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle + * is not NULL, then it must represent a valid shared NT handle that + * is returned by ID3D12Device::CreateSharedHandle when referring to a + * ID3D12Resource object. This handle holds a reference to the + * underlying object. If + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name + * is not NULL, then it must point to a NULL-terminated array of + * UTF-16 characters that refers to a ID3D12Resource object. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE, then + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle must + * represent a valid shared NT handle that is returned by + * IDXGIResource1::CreateSharedHandle when referring to a + * ID3D11Resource object. If + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name + * is not NULL, then it must point to a NULL-terminated array of + * UTF-16 characters that refers to a ID3D11Resource object. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE_KMT, then + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle must + * represent a valid shared KMT handle that is returned by + * IDXGIResource::GetSharedHandle when referring to a + * ID3D11Resource object and + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name + * must be NULL. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF, then + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::nvSciBufObject must be non-NULL + * and reference a valid NvSciBuf object. + * If the NvSciBuf object imported into CUDA is also mapped by other drivers, then the + * application must use ::cuWaitExternalSemaphoresAsync or ::cuSignalExternalSemaphoresAsync + * as appropriate barriers to maintain coherence between CUDA and the other drivers. + * See ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_SKIP_NVSCIBUF_MEMSYNC and ::CUDA_EXTERNAL_SEMAPHORE_WAIT_SKIP_NVSCIBUF_MEMSYNC + * for memory synchronization. + * + * + * The size of the memory object must be specified in + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::size. + * + * Specifying the flag ::CUDA_EXTERNAL_MEMORY_DEDICATED in + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::flags indicates that the + * resource is a dedicated resource. The definition of what a + * dedicated resource is outside the scope of this extension. + * This flag must be set if ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type + * is one of the following: + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE_KMT + * + * \param extMem_out - Returned handle to an external memory object + * \param memHandleDesc - Memory import handle descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OPERATING_SYSTEM + * \notefnerr + * + * \note If the Vulkan memory imported into CUDA is mapped on the CPU then the + * application must use vkInvalidateMappedMemoryRanges/vkFlushMappedMemoryRanges + * as well as appropriate Vulkan pipeline barriers to maintain coherence between + * CPU and GPU. For more information on these APIs, please refer to "Synchronization + * and Cache Control" chapter from Vulkan specification. + * + * \sa ::cuDestroyExternalMemory, + * ::cuExternalMemoryGetMappedBuffer, + * ::cuExternalMemoryGetMappedMipmappedArray + */ +CUresult CUDAAPI cuImportExternalMemory(CUexternalMemory *extMem_out, const CUDA_EXTERNAL_MEMORY_HANDLE_DESC *memHandleDesc); + +/** + * \brief Maps a buffer onto an imported memory object + * + * Maps a buffer onto an imported memory object and returns a device + * pointer in \p devPtr. + * + * The properties of the buffer being mapped must be described in + * \p bufferDesc. The ::CUDA_EXTERNAL_MEMORY_BUFFER_DESC structure is + * defined as follows: + * + * \code + typedef struct CUDA_EXTERNAL_MEMORY_BUFFER_DESC_st { + unsigned long long offset; + unsigned long long size; + unsigned int flags; + } CUDA_EXTERNAL_MEMORY_BUFFER_DESC; + * \endcode + * + * where ::CUDA_EXTERNAL_MEMORY_BUFFER_DESC::offset is the offset in + * the memory object where the buffer's base address is. + * ::CUDA_EXTERNAL_MEMORY_BUFFER_DESC::size is the size of the buffer. + * ::CUDA_EXTERNAL_MEMORY_BUFFER_DESC::flags must be zero. + * + * The offset and size have to be suitably aligned to match the + * requirements of the external API. Mapping two buffers whose ranges + * overlap may or may not result in the same virtual address being + * returned for the overlapped portion. In such cases, the application + * must ensure that all accesses to that region from the GPU are + * volatile. Otherwise writes made via one address are not guaranteed + * to be visible via the other address, even if they're issued by the + * same thread. It is recommended that applications map the combined + * range instead of mapping separate buffers and then apply the + * appropriate offsets to the returned pointer to derive the + * individual buffers. + * + * The returned pointer \p devPtr must be freed using ::cuMemFree. + * + * \param devPtr - Returned device pointer to buffer + * \param extMem - Handle to external memory object + * \param bufferDesc - Buffer descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuImportExternalMemory, + * ::cuDestroyExternalMemory, + * ::cuExternalMemoryGetMappedMipmappedArray + */ +CUresult CUDAAPI cuExternalMemoryGetMappedBuffer(CUdeviceptr *devPtr, CUexternalMemory extMem, const CUDA_EXTERNAL_MEMORY_BUFFER_DESC *bufferDesc); + +/** + * \brief Maps a CUDA mipmapped array onto an external memory object + * + * Maps a CUDA mipmapped array onto an external object and returns a + * handle to it in \p mipmap. + * + * The properties of the CUDA mipmapped array being mapped must be + * described in \p mipmapDesc. The structure + * ::CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC is defined as follows: + * + * \code + typedef struct CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC_st { + unsigned long long offset; + CUDA_ARRAY3D_DESCRIPTOR arrayDesc; + unsigned int numLevels; + } CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC; + * \endcode + * + * where ::CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC::offset is the + * offset in the memory object where the base level of the mipmap + * chain is. + * ::CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC::arrayDesc describes + * the format, dimensions and type of the base level of the mipmap + * chain. For further details on these parameters, please refer to the + * documentation for ::cuMipmappedArrayCreate. Note that if the mipmapped + * array is bound as a color target in the graphics API, then the flag + * ::CUDA_ARRAY3D_COLOR_ATTACHMENT must be specified in + * ::CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC::arrayDesc::Flags. + * ::CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC::numLevels specifies + * the total number of levels in the mipmap chain. + * + * If \p extMem was imported from a handle of type ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF, then + * ::CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC::numLevels must be equal to 1. + * + * The returned CUDA mipmapped array must be freed using ::cuMipmappedArrayDestroy. + * + * \param mipmap - Returned CUDA mipmapped array + * \param extMem - Handle to external memory object + * \param mipmapDesc - CUDA array descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuImportExternalMemory, + * ::cuDestroyExternalMemory, + * ::cuExternalMemoryGetMappedBuffer + */ +CUresult CUDAAPI cuExternalMemoryGetMappedMipmappedArray(CUmipmappedArray *mipmap, CUexternalMemory extMem, const CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC *mipmapDesc); + +/** + * \brief Destroys an external memory object. + * + * Destroys the specified external memory object. Any existing buffers + * and CUDA mipmapped arrays mapped onto this object must no longer be + * used and must be explicitly freed using ::cuMemFree and + * ::cuMipmappedArrayDestroy respectively. + * + * \param extMem - External memory object to be destroyed + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuImportExternalMemory, + * ::cuExternalMemoryGetMappedBuffer, + * ::cuExternalMemoryGetMappedMipmappedArray + */ +CUresult CUDAAPI cuDestroyExternalMemory(CUexternalMemory extMem); + +/** + * \brief Imports an external semaphore + * + * Imports an externally allocated synchronization object and returns + * a handle to that in \p extSem_out. + * + * The properties of the handle being imported must be described in + * \p semHandleDesc. The ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC is + * defined as follows: + * + * \code + typedef struct CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC_st { + CUexternalSemaphoreHandleType type; + union { + int fd; + struct { + void *handle; + const void *name; + } win32; + const void* NvSciSyncObj; + } handle; + unsigned int flags; + } CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC; + * \endcode + * + * where ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type specifies the type of + * handle being imported. ::CUexternalSemaphoreHandleType is defined + * as: + * + * \code + typedef enum CUexternalSemaphoreHandleType_enum { + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD = 1, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32 = 2, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT = 3, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE = 4, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_FENCE = 5, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC = 6, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX = 7, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX_KMT = 8, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_FD = 9, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_WIN32 = 10 + } CUexternalSemaphoreHandleType; + * \endcode + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::fd must be a valid + * file descriptor referencing a synchronization object. Ownership of + * the file descriptor is transferred to the CUDA driver when the + * handle is imported successfully. Performing any operations on the + * file descriptor after it is imported results in undefined behavior. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32, then exactly one + * of ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle and + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name must not be + * NULL. If + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle + * is not NULL, then it must represent a valid shared NT handle that + * references a synchronization object. Ownership of this handle is + * not transferred to CUDA after the import operation, so the + * application must release the handle using the appropriate system + * call. If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name + * is not NULL, then it must name a valid synchronization object. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle must + * be non-NULL and + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name + * must be NULL. The handle specified must be a globally shared KMT + * handle. This handle does not hold a reference to the underlying + * object, and thus will be invalid when all references to the + * synchronization object are destroyed. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE, then exactly one + * of ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle and + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name must not be + * NULL. If + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle + * is not NULL, then it must represent a valid shared NT handle that + * is returned by ID3D12Device::CreateSharedHandle when referring to a + * ID3D12Fence object. This handle holds a reference to the underlying + * object. If + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name + * is not NULL, then it must name a valid synchronization object that + * refers to a valid ID3D12Fence object. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_FENCE, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle + * represents a valid shared NT handle that is returned by + * ID3D11Fence::CreateSharedHandle. If + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name + * is not NULL, then it must name a valid synchronization object that + * refers to a valid ID3D11Fence object. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::nvSciSyncObj + * represents a valid NvSciSyncObj. + * + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle + * represents a valid shared NT handle that + * is returned by IDXGIResource1::CreateSharedHandle when referring to + * a IDXGIKeyedMutex object. If + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name + * is not NULL, then it must name a valid synchronization object that + * refers to a valid IDXGIKeyedMutex object. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX_KMT, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle + * represents a valid shared KMT handle that + * is returned by IDXGIResource::GetSharedHandle when referring to + * a IDXGIKeyedMutex object and + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name must be NULL. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_FD, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::fd must be a valid + * file descriptor referencing a synchronization object. Ownership of + * the file descriptor is transferred to the CUDA driver when the + * handle is imported successfully. Performing any operations on the + * file descriptor after it is imported results in undefined behavior. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_WIN32, then exactly one + * of ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle and + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name must not be + * NULL. If + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle + * is not NULL, then it must represent a valid shared NT handle that + * references a synchronization object. Ownership of this handle is + * not transferred to CUDA after the import operation, so the + * application must release the handle using the appropriate system + * call. If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name + * is not NULL, then it must name a valid synchronization object. + * + * \param extSem_out - Returned handle to an external semaphore + * \param semHandleDesc - Semaphore import handle descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OPERATING_SYSTEM + * \notefnerr + * + * \sa ::cuDestroyExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuImportExternalSemaphore(CUexternalSemaphore *extSem_out, const CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC *semHandleDesc); + +/** + * \brief Signals a set of external semaphore objects + * + * Enqueues a signal operation on a set of externally allocated + * semaphore object in the specified stream. The operations will be + * executed when all prior operations in the stream complete. + * + * The exact semantics of signaling a semaphore depends on the type of + * the object. + * + * If the semaphore object is any one of the following types: + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT + * then signaling the semaphore will set it to the signaled state. + * + * If the semaphore object is any one of the following types: + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_FENCE, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_FD, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_WIN32 + * then the semaphore will be set to the value specified in + * ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS::params::fence::value. + * + * If the semaphore object is of the type ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC + * this API sets ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS::params::nvSciSync::fence + * to a value that can be used by subsequent waiters of the same NvSciSync object + * to order operations with those currently submitted in \p stream. Such an update + * will overwrite previous contents of + * ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS::params::nvSciSync::fence. By default, + * signaling such an external semaphore object causes appropriate memory synchronization + * operations to be performed over all external memory objects that are imported as + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF. This ensures that any subsequent accesses + * made by other importers of the same set of NvSciBuf memory object(s) are coherent. + * These operations can be skipped by specifying the flag + * ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_SKIP_NVSCIBUF_MEMSYNC, which can be used as a + * performance optimization when data coherency is not required. But specifying this + * flag in scenarios where data coherency is required results in undefined behavior. + * Also, for semaphore object of the type ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC, + * if the NvSciSyncAttrList used to create the NvSciSyncObj had not set the flags in + * ::cuDeviceGetNvSciSyncAttributes to CUDA_NVSCISYNC_ATTR_SIGNAL, this API will return + * CUDA_ERROR_NOT_SUPPORTED. + * NvSciSyncFence associated with semaphore object of the type + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC can be deterministic. For this the + * NvSciSyncAttrList used to create the semaphore object must have value of + * NvSciSyncAttrKey_RequireDeterministicFences key set to true. Deterministic fences + * allow users to enqueue a wait over the semaphore object even before corresponding + * signal is enqueued. For such a semaphore object, CUDA guarantees that each signal + * operation will increment the fence value by '1'. Users are expected to track count + * of signals enqueued on the semaphore object and insert waits accordingly. When such + * a semaphore object is signaled from multiple streams, due to concurrent stream + * execution, it is possible that the order in which the semaphore gets signaled is + * indeterministic. This could lead to waiters of the semaphore getting unblocked + * incorrectly. Users are expected to handle such situations, either by not using the + * same semaphore object with deterministic fence support enabled in different streams + * or by adding explicit dependency amongst such streams so that the semaphore is + * signaled in order. + * + * If the semaphore object is any one of the following types: + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX_KMT + * then the keyed mutex will be released with the key specified in + * ::CUDA_EXTERNAL_SEMAPHORE_PARAMS::params::keyedmutex::key. + * + * \param extSemArray - Set of external semaphores to be signaled + * \param paramsArray - Array of semaphore parameters + * \param numExtSems - Number of semaphores to signal + * \param stream - Stream to enqueue the signal operations in + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuImportExternalSemaphore, + * ::cuDestroyExternalSemaphore, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuSignalExternalSemaphoresAsync(const CUexternalSemaphore *extSemArray, const CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS *paramsArray, unsigned int numExtSems, CUstream stream); + +/** + * \brief Waits on a set of external semaphore objects + * + * Enqueues a wait operation on a set of externally allocated + * semaphore object in the specified stream. The operations will be + * executed when all prior operations in the stream complete. + * + * The exact semantics of waiting on a semaphore depends on the type + * of the object. + * + * If the semaphore object is any one of the following types: + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT + * then waiting on the semaphore will wait until the semaphore reaches + * the signaled state. The semaphore will then be reset to the + * unsignaled state. Therefore for every signal operation, there can + * only be one wait operation. + * + * If the semaphore object is any one of the following types: + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_FENCE, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_FD, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_WIN32 + * then waiting on the semaphore will wait until the value of the + * semaphore is greater than or equal to + * ::CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS::params::fence::value. + * + * If the semaphore object is of the type ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC + * then, waiting on the semaphore will wait until the + * ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS::params::nvSciSync::fence is signaled by the + * signaler of the NvSciSyncObj that was associated with this semaphore object. + * By default, waiting on such an external semaphore object causes appropriate + * memory synchronization operations to be performed over all external memory objects + * that are imported as ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF. This ensures that + * any subsequent accesses made by other importers of the same set of NvSciBuf memory + * object(s) are coherent. These operations can be skipped by specifying the flag + * ::CUDA_EXTERNAL_SEMAPHORE_WAIT_SKIP_NVSCIBUF_MEMSYNC, which can be used as a + * performance optimization when data coherency is not required. But specifying this + * flag in scenarios where data coherency is required results in undefined behavior. + * Also, for semaphore object of the type ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC, + * if the NvSciSyncAttrList used to create the NvSciSyncObj had not set the flags in + * ::cuDeviceGetNvSciSyncAttributes to CUDA_NVSCISYNC_ATTR_WAIT, this API will return + * CUDA_ERROR_NOT_SUPPORTED. + * + * If the semaphore object is any one of the following types: + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX_KMT + * then the keyed mutex will be acquired when it is released with the key + * specified in ::CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS::params::keyedmutex::key + * or until the timeout specified by + * ::CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS::params::keyedmutex::timeoutMs + * has lapsed. The timeout interval can either be a finite value + * specified in milliseconds or an infinite value. In case an infinite + * value is specified the timeout never elapses. The windows INFINITE + * macro must be used to specify infinite timeout. + * + * \param extSemArray - External semaphores to be waited on + * \param paramsArray - Array of semaphore parameters + * \param numExtSems - Number of semaphores to wait on + * \param stream - Stream to enqueue the wait operations in + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_TIMEOUT + * \notefnerr + * + * \sa ::cuImportExternalSemaphore, + * ::cuDestroyExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync + */ +CUresult CUDAAPI cuWaitExternalSemaphoresAsync(const CUexternalSemaphore *extSemArray, const CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS *paramsArray, unsigned int numExtSems, CUstream stream); + +/** + * \brief Destroys an external semaphore + * + * Destroys an external semaphore object and releases any references + * to the underlying resource. Any outstanding signals or waits must + * have completed before the semaphore is destroyed. + * + * \param extSem - External semaphore to be destroyed + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuImportExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuDestroyExternalSemaphore(CUexternalSemaphore extSem); + +/** @} */ /* END CUDA_EXTRES_INTEROP */ + +/** + * \defgroup CUDA_MEMOP Stream Memory Operations + * + * ___MANBRIEF___ Stream memory operations of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the stream memory operations of the low-level CUDA + * driver application programming interface. + * + * Support for the ::CU_STREAM_WAIT_VALUE_NOR flag can be queried with + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_STREAM_WAIT_VALUE_NOR_V2. + * + * Support for the ::cuStreamWriteValue64() and ::cuStreamWaitValue64() + * functions, as well as for the ::CU_STREAM_MEM_OP_WAIT_VALUE_64 and + * ::CU_STREAM_MEM_OP_WRITE_VALUE_64 flags, can be queried with + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_64_BIT_STREAM_MEM_OPS. + * + * Support for both ::CU_STREAM_WAIT_VALUE_FLUSH and + * ::CU_STREAM_MEM_OP_FLUSH_REMOTE_WRITES requires dedicated platform + * hardware features and can be queried with ::cuDeviceGetAttribute() and + * ::CU_DEVICE_ATTRIBUTE_CAN_FLUSH_REMOTE_WRITES. + * + * Note that all memory pointers passed as parameters to these operations + * are device pointers. Where necessary a device pointer should be + * obtained, for example with ::cuMemHostGetDevicePointer(). + * + * None of the operations accepts pointers to managed memory buffers + * (::cuMemAllocManaged). + * + * \note + * Warning: + * Improper use of these APIs may deadlock the application. Synchronization + * ordering established through these APIs is not visible to CUDA. CUDA tasks + * that are (even indirectly) ordered by these APIs should also have that order + * expressed with CUDA-visible dependencies such as events. This ensures that + * the scheduler does not serialize them in an improper order. + * + * @{ + */ + +/** + * \brief Wait on a memory location + * + * Enqueues a synchronization of the stream on the given memory location. Work + * ordered after the operation will block until the given condition on the + * memory is satisfied. By default, the condition is to wait for + * (int32_t)(*addr - value) >= 0, a cyclic greater-or-equal. + * Other condition types can be specified via \p flags. + * + * If the memory was registered via ::cuMemHostRegister(), the device pointer + * should be obtained with ::cuMemHostGetDevicePointer(). This function cannot + * be used with managed memory (::cuMemAllocManaged). + * + * Support for CU_STREAM_WAIT_VALUE_NOR can be queried with ::cuDeviceGetAttribute() and + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_STREAM_WAIT_VALUE_NOR_V2. + * + * \note + * Warning: + * Improper use of this API may deadlock the application. Synchronization + * ordering established through this API is not visible to CUDA. CUDA tasks + * that are (even indirectly) ordered by this API should also have that order + * expressed with CUDA-visible dependencies such as events. This ensures that + * the scheduler does not serialize them in an improper order. + * + * \param stream The stream to synchronize on the memory location. + * \param addr The memory location to wait on. + * \param value The value to compare with the memory location. + * \param flags See ::CUstreamWaitValue_flags. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuStreamWaitValue64, + * ::cuStreamWriteValue32, + * ::cuStreamWriteValue64, + * ::cuStreamBatchMemOp, + * ::cuMemHostRegister, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuStreamWaitValue32(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + +/** + * \brief Wait on a memory location + * + * Enqueues a synchronization of the stream on the given memory location. Work + * ordered after the operation will block until the given condition on the + * memory is satisfied. By default, the condition is to wait for + * (int64_t)(*addr - value) >= 0, a cyclic greater-or-equal. + * Other condition types can be specified via \p flags. + * + * If the memory was registered via ::cuMemHostRegister(), the device pointer + * should be obtained with ::cuMemHostGetDevicePointer(). + * + * Support for this can be queried with ::cuDeviceGetAttribute() and + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_64_BIT_STREAM_MEM_OPS. + * + * \note + * Warning: + * Improper use of this API may deadlock the application. Synchronization + * ordering established through this API is not visible to CUDA. CUDA tasks + * that are (even indirectly) ordered by this API should also have that order + * expressed with CUDA-visible dependencies such as events. This ensures that + * the scheduler does not serialize them in an improper order. + * + * \param stream The stream to synchronize on the memory location. + * \param addr The memory location to wait on. + * \param value The value to compare with the memory location. + * \param flags See ::CUstreamWaitValue_flags. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuStreamWaitValue32, + * ::cuStreamWriteValue32, + * ::cuStreamWriteValue64, + * ::cuStreamBatchMemOp, + * ::cuMemHostRegister, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuStreamWaitValue64(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + +/** + * \brief Write a value to memory + * + * Write a value to memory. + * + * If the memory was registered via ::cuMemHostRegister(), the device pointer + * should be obtained with ::cuMemHostGetDevicePointer(). This function cannot + * be used with managed memory (::cuMemAllocManaged). + * + * \param stream The stream to do the write in. + * \param addr The device address to write to. + * \param value The value to write. + * \param flags See ::CUstreamWriteValue_flags. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuStreamWriteValue64, + * ::cuStreamWaitValue32, + * ::cuStreamWaitValue64, + * ::cuStreamBatchMemOp, + * ::cuMemHostRegister, + * ::cuEventRecord + */ +CUresult CUDAAPI cuStreamWriteValue32(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + +/** + * \brief Write a value to memory + * + * Write a value to memory. + * + * If the memory was registered via ::cuMemHostRegister(), the device pointer + * should be obtained with ::cuMemHostGetDevicePointer(). + * + * Support for this can be queried with ::cuDeviceGetAttribute() and + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_64_BIT_STREAM_MEM_OPS. + * + * \param stream The stream to do the write in. + * \param addr The device address to write to. + * \param value The value to write. + * \param flags See ::CUstreamWriteValue_flags. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuStreamWriteValue32, + * ::cuStreamWaitValue32, + * ::cuStreamWaitValue64, + * ::cuStreamBatchMemOp, + * ::cuMemHostRegister, + * ::cuEventRecord + */ +CUresult CUDAAPI cuStreamWriteValue64(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + +/** + * \brief Batch operations to synchronize the stream via memory operations + * + * This is a batch version of ::cuStreamWaitValue32() and ::cuStreamWriteValue32(). + * Batching operations may avoid some performance overhead in both the API call + * and the device execution versus adding them to the stream in separate API + * calls. The operations are enqueued in the order they appear in the array. + * + * See ::CUstreamBatchMemOpType for the full set of supported operations, and + * ::cuStreamWaitValue32(), ::cuStreamWaitValue64(), ::cuStreamWriteValue32(), + * and ::cuStreamWriteValue64() for details of specific operations. + * + * See related APIs for details on querying support for specific operations. + * + * \note + * Warning: + * Improper use of this API may deadlock the application. Synchronization + * ordering established through this API is not visible to CUDA. CUDA tasks + * that are (even indirectly) ordered by this API should also have that order + * expressed with CUDA-visible dependencies such as events. This ensures that + * the scheduler does not serialize them in an improper order. For more + * information, see the Stream Memory Operations section in the programming + * guide(https://docs.nvidia.com/cuda/cuda-c-programming-guide/index.html). + * + * \param stream The stream to enqueue the operations in. + * \param count The number of operations in the array. Must be less than 256. + * \param paramArray The types and parameters of the individual operations. + * \param flags Reserved for future expansion; must be 0. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuStreamWaitValue32, + * ::cuStreamWaitValue64, + * ::cuStreamWriteValue32, + * ::cuStreamWriteValue64, + * ::cuMemHostRegister + */ +CUresult CUDAAPI cuStreamBatchMemOp(CUstream stream, unsigned int count, CUstreamBatchMemOpParams *paramArray, unsigned int flags); + +/** @} */ /* END CUDA_MEMOP */ + +/** + * \defgroup CUDA_EXEC Execution Control + * + * ___MANBRIEF___ execution control functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the execution control functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns information about a function + * + * Returns in \p *pi the integer value of the attribute \p attrib on the kernel + * given by \p hfunc. The supported attributes are: + * - ::CU_FUNC_ATTRIBUTE_MAX_THREADS_PER_BLOCK: The maximum number of threads + * per block, beyond which a launch of the function would fail. This number + * depends on both the function and the device on which the function is + * currently loaded. + * - ::CU_FUNC_ATTRIBUTE_SHARED_SIZE_BYTES: The size in bytes of + * statically-allocated shared memory per block required by this function. + * This does not include dynamically-allocated shared memory requested by + * the user at runtime. + * - ::CU_FUNC_ATTRIBUTE_CONST_SIZE_BYTES: The size in bytes of user-allocated + * constant memory required by this function. + * - ::CU_FUNC_ATTRIBUTE_LOCAL_SIZE_BYTES: The size in bytes of local memory + * used by each thread of this function. + * - ::CU_FUNC_ATTRIBUTE_NUM_REGS: The number of registers used by each thread + * of this function. + * - ::CU_FUNC_ATTRIBUTE_PTX_VERSION: The PTX virtual architecture version for + * which the function was compiled. This value is the major PTX version * 10 + * + the minor PTX version, so a PTX version 1.3 function would return the + * value 13. Note that this may return the undefined value of 0 for cubins + * compiled prior to CUDA 3.0. + * - ::CU_FUNC_ATTRIBUTE_BINARY_VERSION: The binary architecture version for + * which the function was compiled. This value is the major binary + * version * 10 + the minor binary version, so a binary version 1.3 function + * would return the value 13. Note that this will return a value of 10 for + * legacy cubins that do not have a properly-encoded binary architecture + * version. + * - ::CU_FUNC_CACHE_MODE_CA: The attribute to indicate whether the function has + * been compiled with user specified option "-Xptxas --dlcm=ca" set . + * - ::CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES: The maximum size in bytes of + * dynamically-allocated shared memory. + * - ::CU_FUNC_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT: Preferred shared memory-L1 + * cache split ratio in percent of total shared memory. + * - ::CU_FUNC_ATTRIBUTE_CLUSTER_SIZE_MUST_BE_SET: If this attribute is set, the + * kernel must launch with a valid cluster size specified. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_WIDTH: The required cluster width in + * blocks. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_HEIGHT: The required cluster height in + * blocks. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_DEPTH: The required cluster depth in + * blocks. + * - ::CU_FUNC_ATTRIBUTE_NON_PORTABLE_CLUSTER_SIZE_ALLOWED: Indicates whether + * the function can be launched with non-portable cluster size. 1 is allowed, + * 0 is disallowed. A non-portable cluster size may only function on the + * specific SKUs the program is tested on. The launch might fail if the + * program is run on a different hardware platform. CUDA API provides + * cudaOccupancyMaxActiveClusters to assist with checking whether the desired + * size can be launched on the current device. A portable cluster size is + * guaranteed to be functional on all compute capabilities higher than the + * target compute capability. The portable cluster size for sm_90 is 8 blocks + * per cluster. This value may increase for future compute capabilities. The + * specific hardware unit may support higher cluster sizes that’s not + * guaranteed to be portable. + * - ::CU_FUNC_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE: The block + * scheduling policy of a function. The value type is CUclusterSchedulingPolicy. + * + * With a few execeptions, function attributes may also be queried on unloaded + * function handles returned from ::cuModuleEnumerateFunctions. + * ::CUDA_ERROR_FUNCTION_NOT_LOADED is returned if the attribute requires a fully + * loaded function but the function is not loaded. The loading state of a function + * may be queried using ::cuFuncIsloaded. ::cuFuncLoad may be called to explicitly + * load a function before querying the following attributes that require the function + * to be loaded: + * - ::CU_FUNC_ATTRIBUTE_MAX_THREADS_PER_BLOCK + * - ::CU_FUNC_ATTRIBUTE_CONST_SIZE_BYTES + * - ::CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES + * + * \param pi - Returned attribute value + * \param attrib - Attribute requested + * \param hfunc - Function to query attribute of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_FUNCTION_NOT_LOADED + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncSetCacheConfig, + * ::cuLaunchKernel, + * ::cudaFuncGetAttributes, + * ::cudaFuncSetAttribute, + * ::cuFuncIsLoaded, + * ::cuFuncLoad, + * ::cuKernelGetAttribute + */ +CUresult CUDAAPI cuFuncGetAttribute(int *pi, CUfunction_attribute attrib, CUfunction hfunc); + +/** + * \brief Sets information about a function + * + * This call sets the value of a specified attribute \p attrib on the kernel given + * by \p hfunc to an integer value specified by \p val + * This function returns CUDA_SUCCESS if the new value of the attribute could be + * successfully set. If the set fails, this call will return an error. + * Not all attributes can have values set. Attempting to set a value on a read-only + * attribute will result in an error (CUDA_ERROR_INVALID_VALUE) + * + * Supported attributes for the cuFuncSetAttribute call are: + * - ::CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES: This maximum size in bytes of + * dynamically-allocated shared memory. The value should contain the requested + * maximum size of dynamically-allocated shared memory. The sum of this value and + * the function attribute ::CU_FUNC_ATTRIBUTE_SHARED_SIZE_BYTES cannot exceed the + * device attribute ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK_OPTIN. + * The maximal size of requestable dynamic shared memory may differ by GPU + * architecture. + * - ::CU_FUNC_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT: On devices where the L1 + * cache and shared memory use the same hardware resources, this sets the shared memory + * carveout preference, in percent of the total shared memory. + * See ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_MULTIPROCESSOR + * This is only a hint, and the driver can choose a different ratio if required to execute the function. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_WIDTH: The required cluster width in + * blocks. The width, height, and depth values must either all be 0 or all be + * positive. The validity of the cluster dimensions is checked at launch time. + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_HEIGHT: The required cluster height in + * blocks. The width, height, and depth values must either all be 0 or all be + * positive. The validity of the cluster dimensions is checked at launch time. + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_DEPTH: The required cluster depth in + * blocks. The width, height, and depth values must either all be 0 or all be + * positive. The validity of the cluster dimensions is checked at launch time. + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * - ::CU_FUNC_ATTRIBUTE_NON_PORTABLE_CLUSTER_SIZE_ALLOWED: Indicates whether + * the function can be launched with non-portable cluster size. 1 is allowed, + * 0 is disallowed. + * - ::CU_FUNC_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE: The block + * scheduling policy of a function. The value type is CUclusterSchedulingPolicy. + * + * \param hfunc - Function to query attribute of + * \param attrib - Attribute requested + * \param value - The value to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncSetCacheConfig, + * ::cuLaunchKernel, + * ::cudaFuncGetAttributes, + * ::cudaFuncSetAttribute, + * ::cuKernelSetAttribute + */ +CUresult CUDAAPI cuFuncSetAttribute(CUfunction hfunc, CUfunction_attribute attrib, int value); + +/** + * \brief Sets the preferred cache configuration for a device function + * + * On devices where the L1 cache and shared memory use the same hardware + * resources, this sets through \p config the preferred cache configuration for + * the device function \p hfunc. This is only a preference. The driver will use + * the requested configuration if possible, but it is free to choose a different + * configuration if required to execute \p hfunc. Any context-wide preference + * set via ::cuCtxSetCacheConfig() will be overridden by this per-function + * setting unless the per-function setting is ::CU_FUNC_CACHE_PREFER_NONE. In + * that case, the current context-wide setting will be used. + * + * This setting does nothing on devices where the size of the L1 cache and + * shared memory are fixed. + * + * Launching a kernel with a different preference than the most recent + * preference setting may insert a device-side synchronization point. + * + * + * The supported cache configurations are: + * - ::CU_FUNC_CACHE_PREFER_NONE: no preference for shared memory or L1 (default) + * - ::CU_FUNC_CACHE_PREFER_SHARED: prefer larger shared memory and smaller L1 cache + * - ::CU_FUNC_CACHE_PREFER_L1: prefer larger L1 cache and smaller shared memory + * - ::CU_FUNC_CACHE_PREFER_EQUAL: prefer equal sized L1 cache and shared memory + * + * \param hfunc - Kernel to configure cache for + * \param config - Requested cache configuration + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cuLaunchKernel, + * ::cudaFuncSetCacheConfig, + * ::cuKernelSetCacheConfig + */ +CUresult CUDAAPI cuFuncSetCacheConfig(CUfunction hfunc, CUfunc_cache config); + + +/** + * \brief Returns a module handle + * + * Returns in \p *hmod the handle of the module that function \p hfunc + * is located in. The lifetime of the module corresponds to the lifetime of + * the context it was loaded in or until the module is explicitly unloaded. + * + * The CUDA runtime manages its own modules loaded into the primary context. + * If the handle returned by this API refers to a module loaded by the CUDA runtime, + * calling ::cuModuleUnload() on that module will result in undefined behavior. + * + * \param hmod - Returned module handle + * \param hfunc - Function to retrieve module for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_FOUND + * \notefnerr + * + */ +CUresult CUDAAPI cuFuncGetModule(CUmodule *hmod, CUfunction hfunc); + +/** + * \brief Returns the function name for a ::CUfunction handle + * + * Returns in \p **name the function name associated with the function handle \p hfunc . + * The function name is returned as a null-terminated string. The returned name is only + * valid when the function handle is valid. If the module is unloaded or reloaded, one + * must call the API again to get the updated name. This API may return a mangled name if + * the function is not declared as having C linkage. If either \p **name or \p hfunc + * is NULL, ::CUDA_ERROR_INVALID_VALUE is returned. + * + * \param name - The returned name of the function + * \param hfunc - The function handle to retrieve the name for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + */ +CUresult CUDAAPI cuFuncGetName(const char **name, CUfunction hfunc); + +/** + * \brief Returns the offset and size of a kernel parameter in the device-side parameter layout + * + * Queries the kernel parameter at \p paramIndex into \p func's list of parameters, and returns + * in \p paramOffset and \p paramSize the offset and size, respectively, where the parameter + * will reside in the device-side parameter layout. This information can be used to update kernel + * node parameters from the device via ::cudaGraphKernelNodeSetParam() and + * ::cudaGraphKernelNodeUpdatesApply(). \p paramIndex must be less than the number of parameters + * that \p func takes. \p paramSize can be set to NULL if only the parameter offset is desired. + * + * \param func - The function to query + * \param paramIndex - The parameter index to query + * \param paramOffset - Returns the offset into the device-side parameter layout at which the parameter resides + * \param paramSize - Optionally returns the size of the parameter in the device-side parameter layout + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * +* \sa ::cuKernelGetParamInfo + */ +CUresult CUDAAPI cuFuncGetParamInfo(CUfunction func, size_t paramIndex, size_t *paramOffset, size_t *paramSize); + +typedef enum CUfunctionLoadingState_enum { + CU_FUNCTION_LOADING_STATE_UNLOADED = 0, + CU_FUNCTION_LOADING_STATE_LOADED = 1, + CU_FUNCTION_LOADING_STATE_MAX +} CUfunctionLoadingState; + +/** + * \brief Returns if the function is loaded + * + * Returns in \p state the loading state of \p function. + * + * \param state - returned loading state + * \param function - the function to check + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuFuncLoad, + * ::cuModuleEnumerateFunctions + */ +CUresult CUDAAPI cuFuncIsLoaded(CUfunctionLoadingState *state, CUfunction function); + +/** + * \brief Loads a function + * + * Finalizes function loading for \p function. Calling this API with a + * fully loaded function has no effect. + * + * \param function - the function to load + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuModuleEnumerateFunctions, + * ::cuFuncIsLoaded + */ +CUresult CUDAAPI cuFuncLoad(CUfunction function); + +/** + * \brief Launches a CUDA function ::CUfunction or a CUDA kernel ::CUkernel + * + * Invokes the function ::CUfunction or the kernel ::CUkernel \p f + * on a \p gridDimX x \p gridDimY x \p gridDimZ grid of blocks. + * Each block contains \p blockDimX x \p blockDimY x + * \p blockDimZ threads. + * + * \p sharedMemBytes sets the amount of dynamic shared memory that will be + * available to each thread block. + * + * Kernel parameters to \p f can be specified in one of two ways: + * + * 1) Kernel parameters can be specified via \p kernelParams. If \p f + * has N parameters, then \p kernelParams needs to be an array of N + * pointers. Each of \p kernelParams[0] through \p kernelParams[N-1] + * must point to a region of memory from which the actual kernel + * parameter will be copied. The number of kernel parameters and their + * offsets and sizes do not need to be specified as that information is + * retrieved directly from the kernel's image. + * + * 2) Kernel parameters can also be packaged by the application into + * a single buffer that is passed in via the \p extra parameter. + * This places the burden on the application of knowing each kernel + * parameter's size and alignment/padding within the buffer. Here is + * an example of using the \p extra parameter in this manner: + * \code + size_t argBufferSize; + char argBuffer[256]; + + // populate argBuffer and argBufferSize + + void *config[] = { + CU_LAUNCH_PARAM_BUFFER_POINTER, argBuffer, + CU_LAUNCH_PARAM_BUFFER_SIZE, &argBufferSize, + CU_LAUNCH_PARAM_END + }; + status = cuLaunchKernel(f, gx, gy, gz, bx, by, bz, sh, s, NULL, config); + * \endcode + * + * The \p extra parameter exists to allow ::cuLaunchKernel to take + * additional less commonly used arguments. \p extra specifies a list of + * names of extra settings and their corresponding values. Each extra + * setting name is immediately followed by the corresponding value. The + * list must be terminated with either NULL or ::CU_LAUNCH_PARAM_END. + * + * - ::CU_LAUNCH_PARAM_END, which indicates the end of the \p extra + * array; + * - ::CU_LAUNCH_PARAM_BUFFER_POINTER, which specifies that the next + * value in \p extra will be a pointer to a buffer containing all + * the kernel parameters for launching kernel \p f; + * - ::CU_LAUNCH_PARAM_BUFFER_SIZE, which specifies that the next + * value in \p extra will be a pointer to a size_t containing the + * size of the buffer specified with ::CU_LAUNCH_PARAM_BUFFER_POINTER; + * + * The error ::CUDA_ERROR_INVALID_VALUE will be returned if kernel + * parameters are specified with both \p kernelParams and \p extra + * (i.e. both \p kernelParams and \p extra are non-NULL). + * + * Calling ::cuLaunchKernel() invalidates the persistent function state + * set through the following deprecated APIs: + * ::cuFuncSetBlockShape(), + * ::cuFuncSetSharedSize(), + * ::cuParamSetSize(), + * ::cuParamSeti(), + * ::cuParamSetf(), + * ::cuParamSetv(). + * + * Note that to use ::cuLaunchKernel(), the kernel \p f must either have + * been compiled with toolchain version 3.2 or later so that it will + * contain kernel parameter information, or have no kernel parameters. + * If either of these conditions is not met, then ::cuLaunchKernel() will + * return ::CUDA_ERROR_INVALID_IMAGE. + * + * Note that the API can also be used to launch context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to launch + * the kernel on will either be taken from the specified stream \p hStream + * or the current context in case of NULL stream. + * + * \param f - Function ::CUfunction or Kernel ::CUkernel to launch + * \param gridDimX - Width of grid in blocks + * \param gridDimY - Height of grid in blocks + * \param gridDimZ - Depth of grid in blocks + * \param blockDimX - X dimension of each thread block + * \param blockDimY - Y dimension of each thread block + * \param blockDimZ - Z dimension of each thread block + * \param sharedMemBytes - Dynamic shared-memory size per thread block in bytes + * \param hStream - Stream identifier + * \param kernelParams - Array of pointers to kernel parameters + * \param extra - Extra options + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_IMAGE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_NOT_FOUND + * \note_null_stream + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cudaLaunchKernel, + * ::cuLibraryGetKernel, + * ::cuKernelSetCacheConfig, + * ::cuKernelGetAttribute, + * ::cuKernelSetAttribute + */ +CUresult CUDAAPI cuLaunchKernel(CUfunction f, + unsigned int gridDimX, + unsigned int gridDimY, + unsigned int gridDimZ, + unsigned int blockDimX, + unsigned int blockDimY, + unsigned int blockDimZ, + unsigned int sharedMemBytes, + CUstream hStream, + void **kernelParams, + void **extra); + +/** + * \brief Launches a CUDA function ::CUfunction or a CUDA kernel ::CUkernel with launch-time configuration + * + * Invokes the function ::CUfunction or the kernel ::CUkernel \p f with the specified launch-time configuration + * \p config. + * + * The ::CUlaunchConfig structure is defined as: + * + * \code + * typedef struct CUlaunchConfig_st { + * unsigned int gridDimX; + * unsigned int gridDimY; + * unsigned int gridDimZ; + * unsigned int blockDimX; + * unsigned int blockDimY; + * unsigned int blockDimZ; + * unsigned int sharedMemBytes; + * CUstream hStream; + * CUlaunchAttribute *attrs; + * unsigned int numAttrs; + * } CUlaunchConfig; + * \endcode + * + * where: + * - ::CUlaunchConfig::gridDimX is the width of the grid in blocks. + * - ::CUlaunchConfig::gridDimY is the height of the grid in blocks. + * - ::CUlaunchConfig::gridDimZ is the depth of the grid in blocks. + * - ::CUlaunchConfig::blockDimX is the X dimension of each thread block. + * - ::CUlaunchConfig::blockDimX is the Y dimension of each thread block. + * - ::CUlaunchConfig::blockDimZ is the Z dimension of each thread block. + * - ::CUlaunchConfig::sharedMemBytes is the dynamic shared-memory size per + * thread block in bytes. + * - ::CUlaunchConfig::hStream is the handle to the stream to perform the launch + * in. The CUDA context associated with this stream must match that associated + * with function f. + * - ::CUlaunchConfig::attrs is an array of ::CUlaunchConfig::numAttrs + * continguous ::CUlaunchAttribute elements. The value of this pointer is not + * considered if ::CUlaunchConfig::numAttrs is zero. However, in that case, it + * is recommended to set the pointer to NULL. + * - ::CUlaunchConfig::numAttrs is the number of attributes populating the + * first ::CUlaunchConfig::numAttrs positions of the ::CUlaunchConfig::attrs + * array. + * + * Launch-time configuration is specified by adding entries to + * ::CUlaunchConfig::attrs. Each entry is an attribute ID and a corresponding + * attribute value. + * + * The ::CUlaunchAttribute structure is defined as: + * \code + * typedef struct CUlaunchAttribute_st { + * CUlaunchAttributeID id; + * CUlaunchAttributeValue value; + * } CUlaunchAttribute; + * \endcode + * where: + * - ::CUlaunchAttribute::id is a unique enum identifying the attribute. + * - ::CUlaunchAttribute::value is a union that hold the attribute value. + * + * An example of using the \p config parameter: + * \code + * CUlaunchAttribute coopAttr = {.id = CU_LAUNCH_ATTRIBUTE_COOPERATIVE, + * .value = 1}; + * CUlaunchConfig config = {... // set block and grid dimensions + * .attrs = &coopAttr, + * .numAttrs = 1}; + * + * cuLaunchKernelEx(&config, kernel, NULL, NULL); + * \endcode + * + * The ::CUlaunchAttributeID enum is defined as: + * \code + * typedef enum CUlaunchAttributeID_enum { + * CU_LAUNCH_ATTRIBUTE_IGNORE = 0, + * CU_LAUNCH_ATTRIBUTE_ACCESS_POLICY_WINDOW = 1, + * CU_LAUNCH_ATTRIBUTE_COOPERATIVE = 2, + * CU_LAUNCH_ATTRIBUTE_SYNCHRONIZATION_POLICY = 3, + * CU_LAUNCH_ATTRIBUTE_CLUSTER_DIMENSION = 4, + * CU_LAUNCH_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE = 5, + * CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_STREAM_SERIALIZATION = 6, + * CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_EVENT = 7, + * CU_LAUNCH_ATTRIBUTE_PRIORITY = 8, + * CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP = 9, + * CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN = 10, + * CU_LAUNCH_ATTRIBUTE_LAUNCH_COMPLETION_EVENT = 12, + * CU_LAUNCH_ATTRIBUTE_DEVICE_UPDATABLE_KERNEL_NODE = 13, + * } CUlaunchAttributeID; + * \endcode + * + * and the corresponding ::CUlaunchAttributeValue union as : + * \code + * typedef union CUlaunchAttributeValue_union { + * CUaccessPolicyWindow accessPolicyWindow; + * int cooperative; + * CUsynchronizationPolicy syncPolicy; + * struct { + * unsigned int x; + * unsigned int y; + * unsigned int z; + * } clusterDim; + * CUclusterSchedulingPolicy clusterSchedulingPolicyPreference; + * int programmaticStreamSerializationAllowed; + * struct { + * CUevent event; + * int flags; + * int triggerAtBlockStart; + * } programmaticEvent; + * int priority; + * CUlaunchMemSyncDomainMap memSyncDomainMap; + * CUlaunchMemSyncDomain memSyncDomain; + * struct { + * CUevent event; + * int flags; + * } launchCompletionEvent; + * struct { + * int deviceUpdatable; + * CUgraphDeviceNode devNode; + * } deviceUpdatableKernelNode; + * } CUlaunchAttributeValue; + * \endcode + * + * Setting ::CU_LAUNCH_ATTRIBUTE_COOPERATIVE to a non-zero value causes the + * kernel launch to be a cooperative launch, with exactly the same usage and + * semantics of ::cuLaunchCooperativeKernel. + * + * Setting ::CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_STREAM_SERIALIZATION to a non-zero + * values causes the kernel to use programmatic means to resolve its stream + * dependency -- enabling the CUDA runtime to opportunistically allow the grid's + * execution to overlap with the previous kernel in the stream, if that kernel + * requests the overlap. + * + * ::CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_EVENT records an event along with the + * kernel launch. Event recorded through this launch attribute is guaranteed to + * only trigger after all block in the associated kernel trigger the event. A + * block can trigger the event through PTX launchdep.release or CUDA builtin + * function cudaTriggerProgrammaticLaunchCompletion(). A trigger can also be + * inserted at the beginning of each block's execution if triggerAtBlockStart is + * set to non-0. Note that dependents (including the CPU thread calling + * cuEventSynchronize()) are not guaranteed to observe the release precisely + * when it is released. For example, cuEventSynchronize() may only observe the + * event trigger long after the associated kernel has completed. This recording + * type is primarily meant for establishing programmatic dependency between + * device tasks. The event supplied must not be an interprocess or interop + * event. The event must disable timing (i.e. created with + * ::CU_EVENT_DISABLE_TIMING flag set). + * + * ::CU_LAUNCH_ATTRIBUTE_LAUNCH_COMPLETION_EVENT records an event along with + * the kernel launch. Nominally, the event is triggered once all blocks of the + * kernel have begun execution. Currently this is a best effort. If a kernel B + * has a launch completion dependency on a kernel A, B may wait until A is + * complete. Alternatively, blocks of B may begin before all blocks of A have + * begun, for example: + * + * - If B can claim execution resources unavaiable to A, for example if they + * run on different GPUs. + * - If B is a higher priority than A. + * + * Exercise caution if such an ordering inversion could lead to deadlock. The + * event supplied must not be an interprocess or interop event. The event must + * disable timing (i.e. must be created with the ::CU_EVENT_DISABLE_TIMING flag + * set). + * + * Setting ::CU_LAUNCH_ATTRIBUTE_DEVICE_UPDATABLE_KERNEL_NODE to 1 + * on a captured launch causes the resulting kernel node to be device-updatable. + * This attribute is specific to graphs, and passing it to a launch in a + * non-capturing stream results in an error. Passing a value other than 0 or 1 is + * not allowed. + * + * On success, a handle will be returned via + * ::CUlaunchAttributeValue::deviceUpdatableKernelNode::devNode which can be passed + * to the various device-side update functions to update the node's kernel parameters + * from within another kernel. For more information on the types of device updates + * that can be made, as well as the relevant limitations thereof, see + * ::cudaGraphKernelNodeUpdatesApply. + * + * Kernel nodes which are device-updatable have additional restrictions compared to regular + * kernel nodes. Firstly, device-updatable nodes cannot be removed from their graph via + * ::cuGraphDestroyNode. Additionally, once opted-in to this functionality, a node cannot + * opt out, and any attempt to set the attribute to 0 will result in an error. Graphs + * containing one or more device-updatable node also do not allow multiple instantiation. + * + * + * The effect of other attributes is consistent with their effect when set via + * persistent APIs. + * + * See ::cuStreamSetAttribute for + * - ::CU_LAUNCH_ATTRIBUTE_ACCESS_POLICY_WINDOW + * - ::CU_LAUNCH_ATTRIBUTE_SYNCHRONIZATION_POLICY + * + * See ::cuFuncSetAttribute for + * - ::CU_LAUNCH_ATTRIBUTE_CLUSTER_DIMENSION + * - ::CU_LAUNCH_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE + * + * Kernel parameters to \p f can be specified in the same ways that they can be + * using ::cuLaunchKernel. + * + * Note that the API can also be used to launch context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to launch + * the kernel on will either be taken from the specified stream ::CUlaunchConfig::hStream + * or the current context in case of NULL stream. + * + * \param config - Config to launch + * \param f - Function ::CUfunction or Kernel ::CUkernel to launch + * \param kernelParams - Array of pointers to kernel parameters + * \param extra - Extra options + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_IMAGE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_COOPERATIVE_LAUNCH_TOO_LARGE, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_NOT_FOUND + * \note_null_stream + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cudaLaunchKernel, + * ::cudaLaunchKernelEx, + * ::cuLibraryGetKernel, + * ::cuKernelSetCacheConfig, + * ::cuKernelGetAttribute, + * ::cuKernelSetAttribute + */ +CUresult CUDAAPI cuLaunchKernelEx(const CUlaunchConfig *config, + CUfunction f, + void **kernelParams, + void **extra); + +/** + * \brief Launches a CUDA function ::CUfunction or a CUDA kernel ::CUkernel where thread blocks + * can cooperate and synchronize as they execute + * + * Invokes the function ::CUfunction or the kernel ::CUkernel \p f on a \p gridDimX x \p gridDimY x \p gridDimZ + * grid of blocks. Each block contains \p blockDimX x \p blockDimY x + * \p blockDimZ threads. + * + * \p sharedMemBytes sets the amount of dynamic shared memory that will be + * available to each thread block. + * + * The device on which this kernel is invoked must have a non-zero value for + * the device attribute ::CU_DEVICE_ATTRIBUTE_COOPERATIVE_LAUNCH. + * + * The total number of blocks launched cannot exceed the maximum number of blocks per + * multiprocessor as returned by ::cuOccupancyMaxActiveBlocksPerMultiprocessor (or + * ::cuOccupancyMaxActiveBlocksPerMultiprocessorWithFlags) times the number of multiprocessors + * as specified by the device attribute ::CU_DEVICE_ATTRIBUTE_MULTIPROCESSOR_COUNT. + * + * The kernel cannot make use of CUDA dynamic parallelism. + * + * Kernel parameters must be specified via \p kernelParams. If \p f + * has N parameters, then \p kernelParams needs to be an array of N + * pointers. Each of \p kernelParams[0] through \p kernelParams[N-1] + * must point to a region of memory from which the actual kernel + * parameter will be copied. The number of kernel parameters and their + * offsets and sizes do not need to be specified as that information is + * retrieved directly from the kernel's image. + * + * Calling ::cuLaunchCooperativeKernel() sets persistent function state that is + * the same as function state set through ::cuLaunchKernel API + * + * When the kernel \p f is launched via ::cuLaunchCooperativeKernel(), the previous + * block shape, shared size and parameter info associated with \p f + * is overwritten. + * + * Note that to use ::cuLaunchCooperativeKernel(), the kernel \p f must either have + * been compiled with toolchain version 3.2 or later so that it will + * contain kernel parameter information, or have no kernel parameters. + * If either of these conditions is not met, then ::cuLaunchCooperativeKernel() will + * return ::CUDA_ERROR_INVALID_IMAGE. + * + * Note that the API can also be used to launch context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to launch + * the kernel on will either be taken from the specified stream \p hStream + * or the current context in case of NULL stream. + * + * \param f - Function ::CUfunction or Kernel ::CUkernel to launch + * \param gridDimX - Width of grid in blocks + * \param gridDimY - Height of grid in blocks + * \param gridDimZ - Depth of grid in blocks + * \param blockDimX - X dimension of each thread block + * \param blockDimY - Y dimension of each thread block + * \param blockDimZ - Z dimension of each thread block + * \param sharedMemBytes - Dynamic shared-memory size per thread block in bytes + * \param hStream - Stream identifier + * \param kernelParams - Array of pointers to kernel parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_IMAGE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_COOPERATIVE_LAUNCH_TOO_LARGE, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_NOT_FOUND + * \note_null_stream + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cuLaunchCooperativeKernelMultiDevice, + * ::cudaLaunchCooperativeKernel, + * ::cuLibraryGetKernel, + * ::cuKernelSetCacheConfig, + * ::cuKernelGetAttribute, + * ::cuKernelSetAttribute + */ +CUresult CUDAAPI cuLaunchCooperativeKernel(CUfunction f, + unsigned int gridDimX, + unsigned int gridDimY, + unsigned int gridDimZ, + unsigned int blockDimX, + unsigned int blockDimY, + unsigned int blockDimZ, + unsigned int sharedMemBytes, + CUstream hStream, + void **kernelParams); + +/** + * \brief Launches CUDA functions on multiple devices where thread blocks can cooperate and synchronize as they execute + * + * \deprecated This function is deprecated as of CUDA 11.3. + * + * Invokes kernels as specified in the \p launchParamsList array where each element + * of the array specifies all the parameters required to perform a single kernel launch. + * These kernels can cooperate and synchronize as they execute. The size of the array is + * specified by \p numDevices. + * + * No two kernels can be launched on the same device. All the devices targeted by this + * multi-device launch must be identical. All devices must have a non-zero value for the + * device attribute ::CU_DEVICE_ATTRIBUTE_COOPERATIVE_MULTI_DEVICE_LAUNCH. + * + * All kernels launched must be identical with respect to the compiled code. Note that + * any __device__, __constant__ or __managed__ variables present in the module that owns + * the kernel launched on each device, are independently instantiated on every device. + * It is the application's responsibility to ensure these variables are initialized and + * used appropriately. + * + * The size of the grids as specified in blocks, the size of the blocks themselves + * and the amount of shared memory used by each thread block must also match across + * all launched kernels. + * + * The streams used to launch these kernels must have been created via either ::cuStreamCreate + * or ::cuStreamCreateWithPriority. The NULL stream or ::CU_STREAM_LEGACY or ::CU_STREAM_PER_THREAD + * cannot be used. + * + * The total number of blocks launched per kernel cannot exceed the maximum number of blocks + * per multiprocessor as returned by ::cuOccupancyMaxActiveBlocksPerMultiprocessor (or + * ::cuOccupancyMaxActiveBlocksPerMultiprocessorWithFlags) times the number of multiprocessors + * as specified by the device attribute ::CU_DEVICE_ATTRIBUTE_MULTIPROCESSOR_COUNT. Since the + * total number of blocks launched per device has to match across all devices, the maximum + * number of blocks that can be launched per device will be limited by the device with the + * least number of multiprocessors. + * + * The kernels cannot make use of CUDA dynamic parallelism. + * + * The ::CUDA_LAUNCH_PARAMS structure is defined as: + * \code + typedef struct CUDA_LAUNCH_PARAMS_st + { + CUfunction function; + unsigned int gridDimX; + unsigned int gridDimY; + unsigned int gridDimZ; + unsigned int blockDimX; + unsigned int blockDimY; + unsigned int blockDimZ; + unsigned int sharedMemBytes; + CUstream hStream; + void **kernelParams; + } CUDA_LAUNCH_PARAMS; + * \endcode + * where: + * - ::CUDA_LAUNCH_PARAMS::function specifies the kernel to be launched. All functions must + * be identical with respect to the compiled code. + * Note that you can also specify context-less kernel ::CUkernel by querying the handle + * using ::cuLibraryGetKernel() and then casting to ::CUfunction. In this case, the context to + * launch the kernel on be taken from the specified stream ::CUDA_LAUNCH_PARAMS::hStream. + * - ::CUDA_LAUNCH_PARAMS::gridDimX is the width of the grid in blocks. This must match across + * all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::gridDimY is the height of the grid in blocks. This must match across + * all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::gridDimZ is the depth of the grid in blocks. This must match across + * all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::blockDimX is the X dimension of each thread block. This must match across + * all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::blockDimX is the Y dimension of each thread block. This must match across + * all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::blockDimZ is the Z dimension of each thread block. This must match across + * all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::sharedMemBytes is the dynamic shared-memory size per thread block in bytes. + * This must match across all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::hStream is the handle to the stream to perform the launch in. This cannot + * be the NULL stream or ::CU_STREAM_LEGACY or ::CU_STREAM_PER_THREAD. The CUDA context associated + * with this stream must match that associated with ::CUDA_LAUNCH_PARAMS::function. + * - ::CUDA_LAUNCH_PARAMS::kernelParams is an array of pointers to kernel parameters. If + * ::CUDA_LAUNCH_PARAMS::function has N parameters, then ::CUDA_LAUNCH_PARAMS::kernelParams + * needs to be an array of N pointers. Each of ::CUDA_LAUNCH_PARAMS::kernelParams[0] through + * ::CUDA_LAUNCH_PARAMS::kernelParams[N-1] must point to a region of memory from which the actual + * kernel parameter will be copied. The number of kernel parameters and their offsets and sizes + * do not need to be specified as that information is retrieved directly from the kernel's image. + * + * By default, the kernel won't begin execution on any GPU until all prior work in all the specified + * streams has completed. This behavior can be overridden by specifying the flag + * ::CUDA_COOPERATIVE_LAUNCH_MULTI_DEVICE_NO_PRE_LAUNCH_SYNC. When this flag is specified, each kernel + * will only wait for prior work in the stream corresponding to that GPU to complete before it begins + * execution. + * + * Similarly, by default, any subsequent work pushed in any of the specified streams will not begin + * execution until the kernels on all GPUs have completed. This behavior can be overridden by specifying + * the flag ::CUDA_COOPERATIVE_LAUNCH_MULTI_DEVICE_NO_POST_LAUNCH_SYNC. When this flag is specified, + * any subsequent work pushed in any of the specified streams will only wait for the kernel launched + * on the GPU corresponding to that stream to complete before it begins execution. + * + * Calling ::cuLaunchCooperativeKernelMultiDevice() sets persistent function state that is + * the same as function state set through ::cuLaunchKernel API when called individually for each + * element in \p launchParamsList. + * + * When kernels are launched via ::cuLaunchCooperativeKernelMultiDevice(), the previous + * block shape, shared size and parameter info associated with each ::CUDA_LAUNCH_PARAMS::function + * in \p launchParamsList is overwritten. + * + * Note that to use ::cuLaunchCooperativeKernelMultiDevice(), the kernels must either have + * been compiled with toolchain version 3.2 or later so that it will + * contain kernel parameter information, or have no kernel parameters. + * If either of these conditions is not met, then ::cuLaunchCooperativeKernelMultiDevice() will + * return ::CUDA_ERROR_INVALID_IMAGE. + * + * \param launchParamsList - List of launch parameters, one per device + * \param numDevices - Size of the \p launchParamsList array + * \param flags - Flags to control launch behavior + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_IMAGE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_COOPERATIVE_LAUNCH_TOO_LARGE, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED + * \note_null_stream + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cuLaunchCooperativeKernel, + * ::cudaLaunchCooperativeKernelMultiDevice + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuLaunchCooperativeKernelMultiDevice(CUDA_LAUNCH_PARAMS *launchParamsList, unsigned int numDevices, unsigned int flags); + +/** + * \brief Enqueues a host function call in a stream + * + * Enqueues a host function to run in a stream. The function will be called + * after currently enqueued work and will block work added after it. + * + * The host function must not make any CUDA API calls. Attempting to use a + * CUDA API may result in ::CUDA_ERROR_NOT_PERMITTED, but this is not required. + * The host function must not perform any synchronization that may depend on + * outstanding CUDA work not mandated to run earlier. Host functions without a + * mandated order (such as in independent streams) execute in undefined order + * and may be serialized. + * + * For the purposes of Unified Memory, execution makes a number of guarantees: + *
    + *
  • The stream is considered idle for the duration of the function's + * execution. Thus, for example, the function may always use memory attached + * to the stream it was enqueued in.
  • + *
  • The start of execution of the function has the same effect as + * synchronizing an event recorded in the same stream immediately prior to + * the function. It thus synchronizes streams which have been "joined" + * prior to the function.
  • + *
  • Adding device work to any stream does not have the effect of making + * the stream active until all preceding host functions and stream callbacks + * have executed. Thus, for + * example, a function might use global attached memory even if work has + * been added to another stream, if the work has been ordered behind the + * function call with an event.
  • + *
  • Completion of the function does not cause a stream to become + * active except as described above. The stream will remain idle + * if no device work follows the function, and will remain idle across + * consecutive host functions or stream callbacks without device work in + * between. Thus, for example, + * stream synchronization can be done by signaling from a host function at the + * end of the stream.
  • + *
+ * + * Note that, in contrast to ::cuStreamAddCallback, the function will not be + * called in the event of an error in the CUDA context. + * + * \param hStream - Stream to enqueue function call in + * \param fn - The function to call once preceding stream operations are complete + * \param userData - User-specified data to be passed to the function + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_null_stream + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamWaitEvent, + * ::cuStreamDestroy, + * ::cuMemAllocManaged, + * ::cuStreamAttachMemAsync, + * ::cuStreamAddCallback + */ +CUresult CUDAAPI cuLaunchHostFunc(CUstream hStream, CUhostFn fn, void *userData); + +/** @} */ /* END CUDA_EXEC */ + +/** + * \defgroup CUDA_EXEC_DEPRECATED Execution Control [DEPRECATED] + * + * ___MANBRIEF___ deprecated execution control functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the deprecated execution control functions of the + * low-level CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Sets the block-dimensions for the function + * + * \deprecated + * + * Specifies the \p x, \p y, and \p z dimensions of the thread blocks that are + * created when the kernel given by \p hfunc is launched. + * + * \param hfunc - Kernel to specify dimensions of + * \param x - X dimension + * \param y - Y dimension + * \param z - Z dimension + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuFuncSetSharedSize, + * ::cuFuncSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSeti, + * ::cuParamSetf, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuFuncSetBlockShape(CUfunction hfunc, int x, int y, int z); + +/** + * \brief Sets the dynamic shared-memory size for the function + * + * \deprecated + * + * Sets through \p bytes the amount of dynamic shared memory that will be + * available to each thread block when the kernel given by \p hfunc is launched. + * + * \param hfunc - Kernel to specify dynamic shared-memory size for + * \param bytes - Dynamic shared-memory size per thread in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSeti, + * ::cuParamSetf, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuFuncSetSharedSize(CUfunction hfunc, unsigned int bytes); + +/** + * \brief Sets the parameter size for the function + * + * \deprecated + * + * Sets through \p numbytes the total size in bytes needed by the function + * parameters of the kernel corresponding to \p hfunc. + * + * \param hfunc - Kernel to set parameter size for + * \param numbytes - Size of parameter list in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetf, + * ::cuParamSeti, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuParamSetSize(CUfunction hfunc, unsigned int numbytes); + +/** + * \brief Adds an integer parameter to the function's argument list + * + * \deprecated + * + * Sets an integer parameter that will be specified the next time the + * kernel corresponding to \p hfunc will be invoked. \p offset is a byte offset. + * + * \param hfunc - Kernel to add parameter to + * \param offset - Offset to add parameter to argument list + * \param value - Value of parameter + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSetf, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuParamSeti(CUfunction hfunc, int offset, unsigned int value); + +/** + * \brief Adds a floating-point parameter to the function's argument list + * + * \deprecated + * + * Sets a floating-point parameter that will be specified the next time the + * kernel corresponding to \p hfunc will be invoked. \p offset is a byte offset. + * + * \param hfunc - Kernel to add parameter to + * \param offset - Offset to add parameter to argument list + * \param value - Value of parameter + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSeti, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuParamSetf(CUfunction hfunc, int offset, float value); + +/** + * \brief Adds arbitrary data to the function's argument list + * + * \deprecated + * + * Copies an arbitrary amount of data (specified in \p numbytes) from \p ptr + * into the parameter space of the kernel corresponding to \p hfunc. \p offset + * is a byte offset. + * + * \param hfunc - Kernel to add data to + * \param offset - Offset to add data to argument list + * \param ptr - Pointer to arbitrary data + * \param numbytes - Size of data to copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSetf, + * ::cuParamSeti, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuParamSetv(CUfunction hfunc, int offset, void *ptr, unsigned int numbytes); + +/** + * \brief Launches a CUDA function + * + * \deprecated + * + * Invokes the kernel \p f on a 1 x 1 x 1 grid of blocks. The block + * contains the number of threads specified by a previous call to + * ::cuFuncSetBlockShape(). + * + * The block shape, dynamic shared memory size, and parameter information + * must be set using + * ::cuFuncSetBlockShape(), + * ::cuFuncSetSharedSize(), + * ::cuParamSetSize(), + * ::cuParamSeti(), + * ::cuParamSetf(), and + * ::cuParamSetv() + * prior to calling this function. + * + * Launching a function via ::cuLaunchKernel() invalidates the function's + * block shape, dynamic shared memory size, and parameter information. After + * launching via cuLaunchKernel, this state must be re-initialized prior to + * calling this function. Failure to do so results in undefined behavior. + * + * \param f - Kernel to launch + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSetf, + * ::cuParamSeti, + * ::cuParamSetv, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuLaunch(CUfunction f); + +/** + * \brief Launches a CUDA function + * + * \deprecated + * + * Invokes the kernel \p f on a \p grid_width x \p grid_height grid of + * blocks. Each block contains the number of threads specified by a previous + * call to ::cuFuncSetBlockShape(). + * + * The block shape, dynamic shared memory size, and parameter information + * must be set using + * ::cuFuncSetBlockShape(), + * ::cuFuncSetSharedSize(), + * ::cuParamSetSize(), + * ::cuParamSeti(), + * ::cuParamSetf(), and + * ::cuParamSetv() + * prior to calling this function. + * + * Launching a function via ::cuLaunchKernel() invalidates the function's + * block shape, dynamic shared memory size, and parameter information. After + * launching via cuLaunchKernel, this state must be re-initialized prior to + * calling this function. Failure to do so results in undefined behavior. + * + * \param f - Kernel to launch + * \param grid_width - Width of grid in blocks + * \param grid_height - Height of grid in blocks + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSetf, + * ::cuParamSeti, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuLaunchGrid(CUfunction f, int grid_width, int grid_height); + +/** + * \brief Launches a CUDA function + * + * \deprecated + * + * Invokes the kernel \p f on a \p grid_width x \p grid_height grid of + * blocks. Each block contains the number of threads specified by a previous + * call to ::cuFuncSetBlockShape(). + * + * The block shape, dynamic shared memory size, and parameter information + * must be set using + * ::cuFuncSetBlockShape(), + * ::cuFuncSetSharedSize(), + * ::cuParamSetSize(), + * ::cuParamSeti(), + * ::cuParamSetf(), and + * ::cuParamSetv() + * prior to calling this function. + * + * Launching a function via ::cuLaunchKernel() invalidates the function's + * block shape, dynamic shared memory size, and parameter information. After + * launching via cuLaunchKernel, this state must be re-initialized prior to + * calling this function. Failure to do so results in undefined behavior. + * + * \param f - Kernel to launch + * \param grid_width - Width of grid in blocks + * \param grid_height - Height of grid in blocks + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED + * + * \note In certain cases where cubins are created with no ABI (i.e., using \p ptxas \p --abi-compile \p no), + * this function may serialize kernel launches. The CUDA driver retains asynchronous behavior by + * growing the per-thread stack as needed per launch and not shrinking it afterwards. + * + * \note_null_stream + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSetf, + * ::cuParamSeti, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuLaunchGridAsync(CUfunction f, int grid_width, int grid_height, CUstream hStream); + + +/** + * \brief Adds a texture-reference to the function's argument list + * + * \deprecated + * + * Makes the CUDA array or linear memory bound to the texture reference + * \p hTexRef available to a device program as a texture. In this version of + * CUDA, the texture-reference must be obtained via ::cuModuleGetTexRef() and + * the \p texunit parameter must be set to ::CU_PARAM_TR_DEFAULT. + * + * \param hfunc - Kernel to add texture-reference to + * \param texunit - Texture unit (must be ::CU_PARAM_TR_DEFAULT) + * \param hTexRef - Texture-reference to add to argument list + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuParamSetTexRef(CUfunction hfunc, int texunit, CUtexref hTexRef); + +/** + * \brief Sets the shared memory configuration for a device function. + * + * \deprecated + * + * On devices with configurable shared memory banks, this function will + * force all subsequent launches of the specified device function to have + * the given shared memory bank size configuration. On any given launch of the + * function, the shared memory configuration of the device will be temporarily + * changed if needed to suit the function's preferred configuration. Changes in + * shared memory configuration between subsequent launches of functions, + * may introduce a device side synchronization point. + * + * Any per-function setting of shared memory bank size set via + * ::cuFuncSetSharedMemConfig will override the context wide setting set with + * ::cuCtxSetSharedMemConfig. + * + * Changing the shared memory bank size will not increase shared memory usage + * or affect occupancy of kernels, but may have major effects on performance. + * Larger bank sizes will allow for greater potential bandwidth to shared memory, + * but will change what kinds of accesses to shared memory will result in bank + * conflicts. + * + * This function will do nothing on devices with fixed shared memory bank size. + * + * The supported bank configurations are: + * - ::CU_SHARED_MEM_CONFIG_DEFAULT_BANK_SIZE: use the context's shared memory + * configuration when launching this function. + * - ::CU_SHARED_MEM_CONFIG_FOUR_BYTE_BANK_SIZE: set shared memory bank width to + * be natively four bytes when launching this function. + * - ::CU_SHARED_MEM_CONFIG_EIGHT_BYTE_BANK_SIZE: set shared memory bank width to + * be natively eight bytes when launching this function. + * + * \param hfunc - kernel to be given a shared memory config + * \param config - requested shared memory configuration + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuCtxGetSharedMemConfig, + * ::cuCtxSetSharedMemConfig, + * ::cuFuncGetAttribute, + * ::cuLaunchKernel, + * ::cudaFuncSetSharedMemConfig + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuFuncSetSharedMemConfig(CUfunction hfunc, CUsharedconfig config); + +/** @} */ /* END CUDA_EXEC_DEPRECATED */ + +/** + * \defgroup CUDA_GRAPH Graph Management + * + * ___MANBRIEF___ graph management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the graph management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Creates a graph + * + * Creates an empty graph, which is returned via \p phGraph. + * + * \param phGraph - Returns newly created graph + * \param flags - Graph creation flags, must be 0 + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode, + * ::cuGraphInstantiate, + * ::cuGraphDestroy, + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphGetEdges, + * ::cuGraphClone + */ +CUresult CUDAAPI cuGraphCreate(CUgraph *phGraph, unsigned int flags); + +/** + * \brief Creates a kernel execution node and adds it to a graph + * + * Creates a new kernel execution node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and arguments specified in \p nodeParams. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * The CUDA_KERNEL_NODE_PARAMS structure is defined as: + * + * \code + * typedef struct CUDA_KERNEL_NODE_PARAMS_st { + * CUfunction func; + * unsigned int gridDimX; + * unsigned int gridDimY; + * unsigned int gridDimZ; + * unsigned int blockDimX; + * unsigned int blockDimY; + * unsigned int blockDimZ; + * unsigned int sharedMemBytes; + * void **kernelParams; + * void **extra; + * CUkernel kern; + * CUcontext ctx; + * } CUDA_KERNEL_NODE_PARAMS; + * \endcode + * + * When the graph is launched, the node will invoke kernel \p func on a (\p gridDimX x + * \p gridDimY x \p gridDimZ) grid of blocks. Each block contains + * (\p blockDimX x \p blockDimY x \p blockDimZ) threads. + * + * \p sharedMemBytes sets the amount of dynamic shared memory that will be + * available to each thread block. + * + * Kernel parameters to \p func can be specified in one of two ways: + * + * 1) Kernel parameters can be specified via \p kernelParams. If the kernel has N + * parameters, then \p kernelParams needs to be an array of N pointers. Each pointer, + * from \p kernelParams[0] to \p kernelParams[N-1], points to the region of memory from which the actual + * parameter will be copied. The number of kernel parameters and their offsets and sizes do not need + * to be specified as that information is retrieved directly from the kernel's image. + * + * 2) Kernel parameters for non-cooperative kernels can also be packaged by the application into a single + * buffer that is passed in via \p extra. This places the burden on the application of knowing each + * kernel parameter's size and alignment/padding within the buffer. The \p extra parameter exists + * to allow this function to take additional less commonly used arguments. \p extra specifies + * a list of names of extra settings and their corresponding values. Each extra setting name is + * immediately followed by the corresponding value. The list must be terminated with either NULL or + * CU_LAUNCH_PARAM_END. + * + * - ::CU_LAUNCH_PARAM_END, which indicates the end of the \p extra + * array; + * - ::CU_LAUNCH_PARAM_BUFFER_POINTER, which specifies that the next + * value in \p extra will be a pointer to a buffer + * containing all the kernel parameters for launching kernel + * \p func; + * - ::CU_LAUNCH_PARAM_BUFFER_SIZE, which specifies that the next + * value in \p extra will be a pointer to a size_t + * containing the size of the buffer specified with + * ::CU_LAUNCH_PARAM_BUFFER_POINTER; + * + * The error ::CUDA_ERROR_INVALID_VALUE will be returned if kernel parameters are specified with both + * \p kernelParams and \p extra (i.e. both \p kernelParams and \p extra are non-NULL). + * ::CUDA_ERROR_INVALID_VALUE will be returned if \p extra is used for a cooperative kernel. + * + * The \p kernelParams or \p extra array, as well as the argument values it points to, + * are copied during this call. + * + * \note Kernels launched using graphs must not use texture and surface references. Reading or + * writing through any texture or surface reference is undefined behavior. + * This restriction does not apply to texture and surface objects. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Parameters for the GPU execution node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuLaunchKernel, + * ::cuLaunchCooperativeKernel, + * ::cuGraphKernelNodeGetParams, + * ::cuGraphKernelNodeSetParams, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddKernelNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_KERNEL_NODE_PARAMS *nodeParams); + +/** + * \brief Returns a kernel node's parameters + * + * Returns the parameters of kernel node \p hNode in \p nodeParams. + * The \p kernelParams or \p extra array returned in \p nodeParams, + * as well as the argument values it points to, are owned by the node. + * This memory remains valid until the node is destroyed or its + * parameters are modified, and should not be modified + * directly. Use ::cuGraphKernelNodeSetParams to update the + * parameters of this node. + * + * The params will contain either \p kernelParams or \p extra, + * according to which of these was most recently set on the node. + * + * \param hNode - Node to get the parameters for + * \param nodeParams - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuLaunchKernel, + * ::cuGraphAddKernelNode, + * ::cuGraphKernelNodeSetParams + */ +CUresult CUDAAPI cuGraphKernelNodeGetParams(CUgraphNode hNode, CUDA_KERNEL_NODE_PARAMS *nodeParams); + +/** + * \brief Sets a kernel node's parameters + * + * Sets the parameters of kernel node \p hNode to \p nodeParams. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuLaunchKernel, + * ::cuGraphAddKernelNode, + * ::cuGraphKernelNodeGetParams + */ +CUresult CUDAAPI cuGraphKernelNodeSetParams(CUgraphNode hNode, const CUDA_KERNEL_NODE_PARAMS *nodeParams); + +/** + * \brief Creates a memcpy node and adds it to a graph + * + * Creates a new memcpy node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * When the graph is launched, the node will perform the memcpy described by \p copyParams. + * See ::cuMemcpy3D() for a description of the structure and its restrictions. + * + * Memcpy nodes have some additional restrictions with regards to managed memory, if the + * system contains at least one device which has a zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. If one or more of the operands refer + * to managed memory, then using the memory type ::CU_MEMORYTYPE_UNIFIED is disallowed + * for those operand(s). The managed memory will be treated as residing on either the + * host or the device, depending on which memory type is specified. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param copyParams - Parameters for the memory copy + * \param ctx - Context on which to run the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuMemcpy3D, + * ::cuGraphMemcpyNodeGetParams, + * ::cuGraphMemcpyNodeSetParams, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddMemcpyNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_MEMCPY3D *copyParams, CUcontext ctx); + +/** + * \brief Returns a memcpy node's parameters + * + * Returns the parameters of memcpy node \p hNode in \p nodeParams. + * + * \param hNode - Node to get the parameters for + * \param nodeParams - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuMemcpy3D, + * ::cuGraphAddMemcpyNode, + * ::cuGraphMemcpyNodeSetParams + */ +CUresult CUDAAPI cuGraphMemcpyNodeGetParams(CUgraphNode hNode, CUDA_MEMCPY3D *nodeParams); + +/** + * \brief Sets a memcpy node's parameters + * + * Sets the parameters of memcpy node \p hNode to \p nodeParams. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuMemcpy3D, + * ::cuGraphAddMemcpyNode, + * ::cuGraphMemcpyNodeGetParams + */ +CUresult CUDAAPI cuGraphMemcpyNodeSetParams(CUgraphNode hNode, const CUDA_MEMCPY3D *nodeParams); + +/** + * \brief Creates a memset node and adds it to a graph + * + * Creates a new memset node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * The element size must be 1, 2, or 4 bytes. + * When the graph is launched, the node will perform the memset described by \p memsetParams. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param memsetParams - Parameters for the memory set + * \param ctx - Context on which to run the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_CONTEXT + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuMemsetD2D32, + * ::cuGraphMemsetNodeGetParams, + * ::cuGraphMemsetNodeSetParams, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemcpyNode + */ +CUresult CUDAAPI cuGraphAddMemsetNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_MEMSET_NODE_PARAMS *memsetParams, CUcontext ctx); + +/** + * \brief Returns a memset node's parameters + * + * Returns the parameters of memset node \p hNode in \p nodeParams. + * + * \param hNode - Node to get the parameters for + * \param nodeParams - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuMemsetD2D32, + * ::cuGraphAddMemsetNode, + * ::cuGraphMemsetNodeSetParams + */ +CUresult CUDAAPI cuGraphMemsetNodeGetParams(CUgraphNode hNode, CUDA_MEMSET_NODE_PARAMS *nodeParams); + +/** + * \brief Sets a memset node's parameters + * + * Sets the parameters of memset node \p hNode to \p nodeParams. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuMemsetD2D32, + * ::cuGraphAddMemsetNode, + * ::cuGraphMemsetNodeGetParams + */ +CUresult CUDAAPI cuGraphMemsetNodeSetParams(CUgraphNode hNode, const CUDA_MEMSET_NODE_PARAMS *nodeParams); + +/** + * \brief Creates a host execution node and adds it to a graph + * + * Creates a new CPU execution node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and arguments specified in \p nodeParams. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * When the graph is launched, the node will invoke the specified CPU function. + * Host nodes are not supported under MPS with pre-Volta GPUs. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Parameters for the host node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuLaunchHostFunc, + * ::cuGraphHostNodeGetParams, + * ::cuGraphHostNodeSetParams, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddHostNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_HOST_NODE_PARAMS *nodeParams); + +/** + * \brief Returns a host node's parameters + * + * Returns the parameters of host node \p hNode in \p nodeParams. + * + * \param hNode - Node to get the parameters for + * \param nodeParams - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuLaunchHostFunc, + * ::cuGraphAddHostNode, + * ::cuGraphHostNodeSetParams + */ +CUresult CUDAAPI cuGraphHostNodeGetParams(CUgraphNode hNode, CUDA_HOST_NODE_PARAMS *nodeParams); + +/** + * \brief Sets a host node's parameters + * + * Sets the parameters of host node \p hNode to \p nodeParams. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuLaunchHostFunc, + * ::cuGraphAddHostNode, + * ::cuGraphHostNodeGetParams + */ +CUresult CUDAAPI cuGraphHostNodeSetParams(CUgraphNode hNode, const CUDA_HOST_NODE_PARAMS *nodeParams); + +/** + * \brief Creates a child graph node and adds it to a graph + * + * Creates a new node which executes an embedded graph, and adds it to \p hGraph with + * \p numDependencies dependencies specified via \p dependencies. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * If \p hGraph contains allocation or free nodes, this call will return an error. + * + * The node executes an embedded child graph. The child graph is cloned in this call. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param childGraph - The graph to clone into this node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphChildGraphNodeGetGraph, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode, + * ::cuGraphClone + */ +CUresult CUDAAPI cuGraphAddChildGraphNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, CUgraph childGraph); + +/** + * \brief Gets a handle to the embedded graph of a child graph node + * + * Gets a handle to the embedded graph in a child graph node. This call + * does not clone the graph. Changes to the graph will be reflected in + * the node, and the node retains ownership of the graph. + * + * Allocation and free nodes cannot be added to the returned graph. + * Attempting to do so will return an error. + * + * \param hNode - Node to get the embedded graph for + * \param phGraph - Location to store a handle to the graph + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddChildGraphNode, + * ::cuGraphNodeFindInClone + */ +CUresult CUDAAPI cuGraphChildGraphNodeGetGraph(CUgraphNode hNode, CUgraph *phGraph); + +/** + * \brief Creates an empty node and adds it to a graph + * + * Creates a new node which performs no operation, and adds it to \p hGraph with + * \p numDependencies dependencies specified via \p dependencies. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * An empty node performs no operation during execution, but can be used for + * transitive ordering. For example, a phased execution graph with 2 groups of n + * nodes with a barrier between them can be represented using an empty node and + * 2*n dependency edges, rather than no empty node and n^2 dependency edges. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddEmptyNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies); + +/** + * \brief Creates an event record node and adds it to a graph + * + * Creates a new event record node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and event specified in \p event. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * Each launch of the graph will record \p event to capture execution of the + * node's dependencies. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param event - Event for the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphAddEventWaitNode, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddEventRecordNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, CUevent event); + +/** + * \brief Returns the event associated with an event record node + * + * Returns the event of event record node \p hNode in \p event_out. + * + * \param hNode - Node to get the event for + * \param event_out - Pointer to return the event + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddEventRecordNode, + * ::cuGraphEventRecordNodeSetEvent, + * ::cuGraphEventWaitNodeGetEvent, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuGraphEventRecordNodeGetEvent(CUgraphNode hNode, CUevent *event_out); + +/** + * \brief Sets an event record node's event + * + * Sets the event of event record node \p hNode to \p event. + * + * \param hNode - Node to set the event for + * \param event - Event to use + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuGraphAddEventRecordNode, + * ::cuGraphEventRecordNodeGetEvent, + * ::cuGraphEventWaitNodeSetEvent, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuGraphEventRecordNodeSetEvent(CUgraphNode hNode, CUevent event); + +/** + * \brief Creates an event wait node and adds it to a graph + * + * Creates a new event wait node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and event specified in \p event. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * The graph node will wait for all work captured in \p event. See ::cuEventRecord() + * for details on what is captured by an event. \p event may be from a different context + * or device than the launch stream. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param event - Event for the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphAddEventRecordNode, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddEventWaitNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, CUevent event); + +/** + * \brief Returns the event associated with an event wait node + * + * Returns the event of event wait node \p hNode in \p event_out. + * + * \param hNode - Node to get the event for + * \param event_out - Pointer to return the event + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddEventWaitNode, + * ::cuGraphEventWaitNodeSetEvent, + * ::cuGraphEventRecordNodeGetEvent, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuGraphEventWaitNodeGetEvent(CUgraphNode hNode, CUevent *event_out); + +/** + * \brief Sets an event wait node's event + * + * Sets the event of event wait node \p hNode to \p event. + * + * \param hNode - Node to set the event for + * \param event - Event to use + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuGraphAddEventWaitNode, + * ::cuGraphEventWaitNodeGetEvent, + * ::cuGraphEventRecordNodeSetEvent, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuGraphEventWaitNodeSetEvent(CUgraphNode hNode, CUevent event); + +/** + * \brief Creates an external semaphore signal node and adds it to a graph + * + * Creates a new external semaphore signal node and adds it to \p hGraph with \p + * numDependencies dependencies specified via \p dependencies and arguments specified + * in \p nodeParams. It is possible for \p numDependencies to be 0, in which case the + * node will be placed at the root of the graph. \p dependencies may not have any + * duplicate entries. A handle to the new node will be returned in \p phGraphNode. + * + * Performs a signal operation on a set of externally allocated semaphore objects + * when the node is launched. The operation(s) will occur after all of the node's + * dependencies have completed. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Parameters for the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphExternalSemaphoresSignalNodeGetParams, + * ::cuGraphExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuImportExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddEventRecordNode, + * ::cuGraphAddEventWaitNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddExternalSemaphoresSignalNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_EXT_SEM_SIGNAL_NODE_PARAMS *nodeParams); + +/** + * \brief Returns an external semaphore signal node's parameters + * + * Returns the parameters of an external semaphore signal node \p hNode in \p params_out. + * The \p extSemArray and \p paramsArray returned in \p params_out, + * are owned by the node. This memory remains valid until the node is destroyed or its + * parameters are modified, and should not be modified + * directly. Use ::cuGraphExternalSemaphoresSignalNodeSetParams to update the + * parameters of this node. + * + * \param hNode - Node to get the parameters for + * \param params_out - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuLaunchKernel, + * ::cuGraphAddExternalSemaphoresSignalNode, + * ::cuGraphExternalSemaphoresSignalNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuGraphExternalSemaphoresSignalNodeGetParams(CUgraphNode hNode, CUDA_EXT_SEM_SIGNAL_NODE_PARAMS *params_out); + +/** + * \brief Sets an external semaphore signal node's parameters + * + * Sets the parameters of an external semaphore signal node \p hNode to \p nodeParams. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuGraphAddExternalSemaphoresSignalNode, + * ::cuGraphExternalSemaphoresSignalNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuGraphExternalSemaphoresSignalNodeSetParams(CUgraphNode hNode, const CUDA_EXT_SEM_SIGNAL_NODE_PARAMS *nodeParams); + +/** + * \brief Creates an external semaphore wait node and adds it to a graph + * + * Creates a new external semaphore wait node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and arguments specified in \p nodeParams. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. A handle + * to the new node will be returned in \p phGraphNode. + * + * Performs a wait operation on a set of externally allocated semaphore objects + * when the node is launched. The node's dependencies will not be launched until + * the wait operation has completed. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Parameters for the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphExternalSemaphoresWaitNodeGetParams, + * ::cuGraphExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphAddExternalSemaphoresSignalNode, + * ::cuImportExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddEventRecordNode, + * ::cuGraphAddEventWaitNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddExternalSemaphoresWaitNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_EXT_SEM_WAIT_NODE_PARAMS *nodeParams); + +/** + * \brief Returns an external semaphore wait node's parameters + * + * Returns the parameters of an external semaphore wait node \p hNode in \p params_out. + * The \p extSemArray and \p paramsArray returned in \p params_out, + * are owned by the node. This memory remains valid until the node is destroyed or its + * parameters are modified, and should not be modified + * directly. Use ::cuGraphExternalSemaphoresSignalNodeSetParams to update the + * parameters of this node. + * + * \param hNode - Node to get the parameters for + * \param params_out - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuLaunchKernel, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuGraphExternalSemaphoresWaitNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuGraphExternalSemaphoresWaitNodeGetParams(CUgraphNode hNode, CUDA_EXT_SEM_WAIT_NODE_PARAMS *params_out); + +/** + * \brief Sets an external semaphore wait node's parameters + * + * Sets the parameters of an external semaphore wait node \p hNode to \p nodeParams. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuGraphExternalSemaphoresWaitNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuGraphExternalSemaphoresWaitNodeSetParams(CUgraphNode hNode, const CUDA_EXT_SEM_WAIT_NODE_PARAMS *nodeParams); + +/** + * \brief Creates a batch memory operation node and adds it to a graph + * + * Creates a new batch memory operation node and adds it to \p hGraph with \p + * numDependencies dependencies specified via \p dependencies and arguments specified in \p nodeParams. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * When the node is added, the paramArray inside \p nodeParams is copied and therefore it can be + * freed after the call returns. + * + * \note + * Warning: + * Improper use of this API may deadlock the application. Synchronization + * ordering established through this API is not visible to CUDA. CUDA tasks + * that are (even indirectly) ordered by this API should also have that order + * expressed with CUDA-visible dependencies such as events. This ensures that + * the scheduler does not serialize them in an improper order. For more + * information, see the Stream Memory Operations section in the programming + * guide(https://docs.nvidia.com/cuda/cuda-c-programming-guide/index.html). + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Parameters for the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuStreamBatchMemOp, + * ::cuStreamWaitValue32, + * ::cuStreamWriteValue32, + * ::cuStreamWaitValue64, + * ::cuStreamWriteValue64, + * ::cuGraphBatchMemOpNodeGetParams, + * ::cuGraphBatchMemOpNodeSetParams, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddBatchMemOpNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_BATCH_MEM_OP_NODE_PARAMS *nodeParams); + +/** + * \brief Returns a batch mem op node's parameters + * + * Returns the parameters of batch mem op node \p hNode in \p nodeParams_out. + * The \p paramArray returned in \p nodeParams_out is owned by the node. + * This memory remains valid until the node is destroyed or its + * parameters are modified, and should not be modified + * directly. Use ::cuGraphBatchMemOpNodeSetParams to update the + * parameters of this node. + * + * \param hNode - Node to get the parameters for + * \param nodeParams_out - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuStreamBatchMemOp, + * ::cuGraphAddBatchMemOpNode, + * ::cuGraphBatchMemOpNodeSetParams + */ +CUresult CUDAAPI cuGraphBatchMemOpNodeGetParams(CUgraphNode hNode, CUDA_BATCH_MEM_OP_NODE_PARAMS *nodeParams_out); + +/** + * \brief Sets a batch mem op node's parameters + * + * Sets the parameters of batch mem op node \p hNode to \p nodeParams. + * + * The paramArray inside \p nodeParams is copied and therefore it can be + * freed after the call returns. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuStreamBatchMemOp, + * ::cuGraphAddBatchMemOpNode, + * ::cuGraphBatchMemOpNodeGetParams + */ +CUresult CUDAAPI cuGraphBatchMemOpNodeSetParams(CUgraphNode hNode, const CUDA_BATCH_MEM_OP_NODE_PARAMS *nodeParams); + +/** + * \brief Sets the parameters for a batch mem op node in the given graphExec + * + * Sets the parameters of a batch mem op node in an executable graph \p hGraphExec. + * The node is identified by the corresponding node \p hNode in the + * non-executable graph, from which the executable graph was instantiated. + * + * The following fields on operations may be modified on an executable graph: + * + * op.waitValue.address + * op.waitValue.value[64] + * op.waitValue.flags bits corresponding to wait type (i.e. CU_STREAM_WAIT_VALUE_FLUSH bit cannot be modified) + * op.writeValue.address + * op.writeValue.value[64] + * + * Other fields, such as the context, count or type of operations, and other types of operations such as membars, + * may not be modified. + * + * \p hNode must not have been removed from the original graph. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * The paramArray inside \p nodeParams is copied and therefore it can be + * freed after the call returns. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Batch mem op node from the graph from which graphExec was instantiated + * \param nodeParams - Updated Parameters to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuStreamBatchMemOp, + * ::cuGraphAddBatchMemOpNode, + * ::cuGraphBatchMemOpNodeGetParams, + * ::cuGraphBatchMemOpNodeSetParams, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecBatchMemOpNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_BATCH_MEM_OP_NODE_PARAMS *nodeParams); + +/** + * \brief Creates an allocation node and adds it to a graph + * + * Creates a new allocation node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and arguments specified in \p nodeParams. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. A handle + * to the new node will be returned in \p phGraphNode. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Parameters for the node + * + * When ::cuGraphAddMemAllocNode creates an allocation node, it returns the address of the allocation in + * \p nodeParams.dptr. The allocation's address remains fixed across instantiations and launches. + * + * If the allocation is freed in the same graph, by creating a free node using ::cuGraphAddMemFreeNode, + * the allocation can be accessed by nodes ordered after the allocation node but before the free node. + * These allocations cannot be freed outside the owning graph, and they can only be freed once in the + * owning graph. + * + * If the allocation is not freed in the same graph, then it can be accessed not only by nodes in the + * graph which are ordered after the allocation node, but also by stream operations ordered after the + * graph's execution but before the allocation is freed. + * + * Allocations which are not freed in the same graph can be freed by: + * - passing the allocation to ::cuMemFreeAsync or ::cuMemFree; + * - launching a graph with a free node for that allocation; or + * - specifying ::CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH during instantiation, which makes + * each launch behave as though it called ::cuMemFreeAsync for every unfreed allocation. + * + * It is not possible to free an allocation in both the owning graph and another graph. If the allocation + * is freed in the same graph, a free node cannot be added to another graph. If the allocation is freed + * in another graph, a free node can no longer be added to the owning graph. + * + * The following restrictions apply to graphs which contain allocation and/or memory free nodes: + * - Nodes and edges of the graph cannot be deleted. + * - The graph cannot be used in a child node. + * - Only one instantiation of the graph may exist at any point in time. + * - The graph cannot be cloned. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphAddMemFreeNode, + * ::cuGraphMemAllocNodeGetParams, + * ::cuDeviceGraphMemTrim, + * ::cuDeviceGetGraphMemAttribute, + * ::cuDeviceSetGraphMemAttribute, + * ::cuMemAllocAsync, + * ::cuMemFreeAsync, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddEventRecordNode, + * ::cuGraphAddEventWaitNode, + * ::cuGraphAddExternalSemaphoresSignalNode, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddMemAllocNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, CUDA_MEM_ALLOC_NODE_PARAMS *nodeParams); + +/** + * \brief Returns a memory alloc node's parameters + * + * Returns the parameters of a memory alloc node \p hNode in \p params_out. + * The \p poolProps and \p accessDescs returned in \p params_out, are owned by the + * node. This memory remains valid until the node is destroyed. The returned + * parameters must not be modified. + * + * \param hNode - Node to get the parameters for + * \param params_out - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddMemAllocNode, + * ::cuGraphMemFreeNodeGetParams + */ +CUresult CUDAAPI cuGraphMemAllocNodeGetParams(CUgraphNode hNode, CUDA_MEM_ALLOC_NODE_PARAMS *params_out); + +/** + * \brief Creates a memory free node and adds it to a graph + * + * Creates a new memory free node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and arguments specified in \p nodeParams. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. A handle + * to the new node will be returned in \p phGraphNode. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param dptr - Address of memory to free + * + * ::cuGraphAddMemFreeNode will return ::CUDA_ERROR_INVALID_VALUE if the user attempts to free: + * - an allocation twice in the same graph. + * - an address that was not returned by an allocation node. + * - an invalid address. + * + * The following restrictions apply to graphs which contain allocation and/or memory free nodes: + * - Nodes and edges of the graph cannot be deleted. + * - The graph cannot be used in a child node. + * - Only one instantiation of the graph may exist at any point in time. + * - The graph cannot be cloned. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphAddMemAllocNode, + * ::cuGraphMemFreeNodeGetParams, + * ::cuDeviceGraphMemTrim, + * ::cuDeviceGetGraphMemAttribute, + * ::cuDeviceSetGraphMemAttribute, + * ::cuMemAllocAsync, + * ::cuMemFreeAsync, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddEventRecordNode, + * ::cuGraphAddEventWaitNode, + * ::cuGraphAddExternalSemaphoresSignalNode, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddMemFreeNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, CUdeviceptr dptr); + +/** + * \brief Returns a memory free node's parameters + * + * Returns the address of a memory free node \p hNode in \p dptr_out. + * + * \param hNode - Node to get the parameters for + * \param dptr_out - Pointer to return the device address + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddMemFreeNode, + * ::cuGraphMemAllocNodeGetParams + */ +CUresult CUDAAPI cuGraphMemFreeNodeGetParams(CUgraphNode hNode, CUdeviceptr *dptr_out); + +/** + * \brief Free unused memory that was cached on the specified device for use with graphs back to the OS. + * + * Blocks which are not in use by a graph that is either currently executing or scheduled to execute are + * freed back to the operating system. + * + * \param device - The device for which cached memory should be freed. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_DEVICE + * + * \sa + * ::cuGraphAddMemAllocNode, + * ::cuGraphAddMemFreeNode, + * ::cuDeviceSetGraphMemAttribute, + * ::cuDeviceGetGraphMemAttribute + */ +CUresult CUDAAPI cuDeviceGraphMemTrim(CUdevice device); + +/** + * \brief Query asynchronous allocation attributes related to graphs + * + * Valid attributes are: + * + * - ::CU_GRAPH_MEM_ATTR_USED_MEM_CURRENT: Amount of memory, in bytes, currently associated with graphs + * - ::CU_GRAPH_MEM_ATTR_USED_MEM_HIGH: High watermark of memory, in bytes, associated with graphs since the + * last time it was reset. High watermark can only be reset to zero. + * - ::CU_GRAPH_MEM_ATTR_RESERVED_MEM_CURRENT: Amount of memory, in bytes, currently allocated for use by + * the CUDA graphs asynchronous allocator. + * - ::CU_GRAPH_MEM_ATTR_RESERVED_MEM_HIGH: High watermark of memory, in bytes, currently allocated for use by + * the CUDA graphs asynchronous allocator. + * + * \param device - Specifies the scope of the query + * \param attr - attribute to get + * \param value - retrieved value + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_DEVICE + * + * \sa + * ::cuDeviceSetGraphMemAttribute, + * ::cuGraphAddMemAllocNode, + * ::cuGraphAddMemFreeNode + */ +CUresult CUDAAPI cuDeviceGetGraphMemAttribute(CUdevice device, CUgraphMem_attribute attr, void* value); + +/** + * \brief Set asynchronous allocation attributes related to graphs + * + * Valid attributes are: + * + * - ::CU_GRAPH_MEM_ATTR_USED_MEM_HIGH: High watermark of memory, in bytes, associated with graphs since the + * last time it was reset. High watermark can only be reset to zero. + * - ::CU_GRAPH_MEM_ATTR_RESERVED_MEM_HIGH: High watermark of memory, in bytes, currently allocated for use by + * the CUDA graphs asynchronous allocator. + * + * \param device - Specifies the scope of the query + * \param attr - attribute to get + * \param value - pointer to value to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_DEVICE + * + * \sa + * ::cuDeviceGetGraphMemAttribute, + * ::cuGraphAddMemAllocNode, + * ::cuGraphAddMemFreeNode + */ +CUresult CUDAAPI cuDeviceSetGraphMemAttribute(CUdevice device, CUgraphMem_attribute attr, void* value); + +/** + * \brief Clones a graph + * + * This function creates a copy of \p originalGraph and returns it in \p phGraphClone. + * All parameters are copied into the cloned graph. The original graph may be modified + * after this call without affecting the clone. + * + * Child graph nodes in the original graph are recursively copied into the clone. + * + * \param phGraphClone - Returns newly created cloned graph + * \param originalGraph - Graph to clone + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate, + * ::cuGraphNodeFindInClone + */ +CUresult CUDAAPI cuGraphClone(CUgraph *phGraphClone, CUgraph originalGraph); + +/** + * \brief Finds a cloned version of a node + * + * This function returns the node in \p hClonedGraph corresponding to \p hOriginalNode + * in the original graph. + * + * \p hClonedGraph must have been cloned from \p hOriginalGraph via ::cuGraphClone. + * \p hOriginalNode must have been in \p hOriginalGraph at the time of the call to + * ::cuGraphClone, and the corresponding cloned node in \p hClonedGraph must not have + * been removed. The cloned node is then returned via \p phClonedNode. + * + * \param phNode - Returns handle to the cloned node + * \param hOriginalNode - Handle to the original node + * \param hClonedGraph - Cloned graph to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphClone + */ +CUresult CUDAAPI cuGraphNodeFindInClone(CUgraphNode *phNode, CUgraphNode hOriginalNode, CUgraph hClonedGraph); + +/** + * \brief Returns a node's type + * + * Returns the node type of \p hNode in \p type. + * + * \param hNode - Node to query + * \param type - Pointer to return the node type + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphChildGraphNodeGetGraph, + * ::cuGraphKernelNodeGetParams, + * ::cuGraphKernelNodeSetParams, + * ::cuGraphHostNodeGetParams, + * ::cuGraphHostNodeSetParams, + * ::cuGraphMemcpyNodeGetParams, + * ::cuGraphMemcpyNodeSetParams, + * ::cuGraphMemsetNodeGetParams, + * ::cuGraphMemsetNodeSetParams + */ +CUresult CUDAAPI cuGraphNodeGetType(CUgraphNode hNode, CUgraphNodeType *type); + +/** + * \brief Returns a graph's nodes + * + * Returns a list of \p hGraph's nodes. \p nodes may be NULL, in which case this + * function will return the number of nodes in \p numNodes. Otherwise, + * \p numNodes entries will be filled in. If \p numNodes is higher than the actual + * number of nodes, the remaining entries in \p nodes will be set to NULL, and the + * number of nodes actually obtained will be returned in \p numNodes. + * + * \param hGraph - Graph to query + * \param nodes - Pointer to return the nodes + * \param numNodes - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate, + * ::cuGraphGetRootNodes, + * ::cuGraphGetEdges, + * ::cuGraphNodeGetType, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphGetNodes(CUgraph hGraph, CUgraphNode *nodes, size_t *numNodes); + +/** + * \brief Returns a graph's root nodes + * + * Returns a list of \p hGraph's root nodes. \p rootNodes may be NULL, in which case this + * function will return the number of root nodes in \p numRootNodes. Otherwise, + * \p numRootNodes entries will be filled in. If \p numRootNodes is higher than the actual + * number of root nodes, the remaining entries in \p rootNodes will be set to NULL, and the + * number of nodes actually obtained will be returned in \p numRootNodes. + * + * \param hGraph - Graph to query + * \param rootNodes - Pointer to return the root nodes + * \param numRootNodes - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate, + * ::cuGraphGetNodes, + * ::cuGraphGetEdges, + * ::cuGraphNodeGetType, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphGetRootNodes(CUgraph hGraph, CUgraphNode *rootNodes, size_t *numRootNodes); + +/** + * \brief Returns a graph's dependency edges + * + * Returns a list of \p hGraph's dependency edges. Edges are returned via corresponding + * indices in \p from and \p to; that is, the node in \p to[i] has a dependency on the + * node in \p from[i]. \p from and \p to may both be NULL, in which + * case this function only returns the number of edges in \p numEdges. Otherwise, + * \p numEdges entries will be filled in. If \p numEdges is higher than the actual + * number of edges, the remaining entries in \p from and \p to will be set to NULL, and + * the number of edges actually returned will be written to \p numEdges. + * + * \param hGraph - Graph to get the edges from + * \param from - Location to return edge endpoints + * \param to - Location to return edge endpoints + * \param numEdges - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphAddDependencies, + * ::cuGraphRemoveDependencies, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphGetEdges(CUgraph hGraph, CUgraphNode *from, CUgraphNode *to, size_t *numEdges); + +/** + * \brief Returns a graph's dependency edges (12.3+) + * + * Returns a list of \p hGraph's dependency edges. Edges are returned via corresponding + * indices in \p from, \p to and \p edgeData; that is, the node in \p to[i] has a + * dependency on the node in \p from[i] with data \p edgeData[i]. \p from and \p to may + * both be NULL, in which case this function only returns the number of edges in + * \p numEdges. Otherwise, \p numEdges entries will be filled in. If \p numEdges is higher + * than the actual number of edges, the remaining entries in \p from and \p to will be + * set to NULL, and the number of edges actually returned will be written to \p numEdges. + * \p edgeData may alone be NULL, in which case the edges must all have default (zeroed) + * edge data. Attempting a lossy query via NULL \p edgeData will result in + * ::CUDA_ERROR_LOSSY_QUERY. If \p edgeData is non-NULL then \p from and \p to must be + * as well. + * + * \param hGraph - Graph to get the edges from + * \param from - Location to return edge endpoints + * \param to - Location to return edge endpoints + * \param edgeData - Optional location to return edge data + * \param numEdges - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_LOSSY_QUERY, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphAddDependencies, + * ::cuGraphRemoveDependencies, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphGetEdges_v2(CUgraph hGraph, CUgraphNode *from, CUgraphNode *to, CUgraphEdgeData *edgeData, size_t *numEdges); + +/** + * \brief Returns a node's dependencies + * + * Returns a list of \p node's dependencies. \p dependencies may be NULL, in which case this + * function will return the number of dependencies in \p numDependencies. Otherwise, + * \p numDependencies entries will be filled in. If \p numDependencies is higher than the actual + * number of dependencies, the remaining entries in \p dependencies will be set to NULL, and the + * number of nodes actually obtained will be returned in \p numDependencies. + * + * \param hNode - Node to query + * \param dependencies - Pointer to return the dependencies + * \param numDependencies - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeGetDependentNodes, + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphGetEdges, + * ::cuGraphAddDependencies, + * ::cuGraphRemoveDependencies + */ +CUresult CUDAAPI cuGraphNodeGetDependencies(CUgraphNode hNode, CUgraphNode *dependencies, size_t *numDependencies); + +/** + * \brief Returns a node's dependencies (12.3+) + * + * Returns a list of \p node's dependencies. \p dependencies may be NULL, in which case this + * function will return the number of dependencies in \p numDependencies. Otherwise, + * \p numDependencies entries will be filled in. If \p numDependencies is higher than the actual + * number of dependencies, the remaining entries in \p dependencies will be set to NULL, and the + * number of nodes actually obtained will be returned in \p numDependencies. + * + * Note that if an edge has non-zero (non-default) edge data and \p edgeData is NULL, + * this API will return ::CUDA_ERROR_LOSSY_QUERY. If \p edgeData is non-NULL, then + * \p dependencies must be as well. + * + * \param hNode - Node to query + * \param dependencies - Pointer to return the dependencies + * \param edgeData - Optional array to return edge data for each dependency + * \param numDependencies - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_LOSSY_QUERY, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeGetDependentNodes, + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphGetEdges, + * ::cuGraphAddDependencies, + * ::cuGraphRemoveDependencies + */ +CUresult CUDAAPI cuGraphNodeGetDependencies_v2(CUgraphNode hNode, CUgraphNode *dependencies, CUgraphEdgeData *edgeData, size_t *numDependencies); + +/** + * \brief Returns a node's dependent nodes + * + * Returns a list of \p node's dependent nodes. \p dependentNodes may be NULL, in which + * case this function will return the number of dependent nodes in \p numDependentNodes. + * Otherwise, \p numDependentNodes entries will be filled in. If \p numDependentNodes is + * higher than the actual number of dependent nodes, the remaining entries in + * \p dependentNodes will be set to NULL, and the number of nodes actually obtained will + * be returned in \p numDependentNodes. + * + * \param hNode - Node to query + * \param dependentNodes - Pointer to return the dependent nodes + * \param numDependentNodes - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeGetDependencies, + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphGetEdges, + * ::cuGraphAddDependencies, + * ::cuGraphRemoveDependencies + */ +CUresult CUDAAPI cuGraphNodeGetDependentNodes(CUgraphNode hNode, CUgraphNode *dependentNodes, size_t *numDependentNodes); + +/** + * \brief Returns a node's dependent nodes (12.3+) + * + * Returns a list of \p node's dependent nodes. \p dependentNodes may be NULL, in which + * case this function will return the number of dependent nodes in \p numDependentNodes. + * Otherwise, \p numDependentNodes entries will be filled in. If \p numDependentNodes is + * higher than the actual number of dependent nodes, the remaining entries in + * \p dependentNodes will be set to NULL, and the number of nodes actually obtained will + * be returned in \p numDependentNodes. + * + * Note that if an edge has non-zero (non-default) edge data and \p edgeData is NULL, + * this API will return ::CUDA_ERROR_LOSSY_QUERY. If \p edgeData is non-NULL, then + * \p dependentNodes must be as well. + * + * \param hNode - Node to query + * \param dependentNodes - Pointer to return the dependent nodes + * \param edgeData - Optional pointer to return edge data for dependent nodes + * \param numDependentNodes - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_LOSSY_QUERY, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeGetDependencies, + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphGetEdges, + * ::cuGraphAddDependencies, + * ::cuGraphRemoveDependencies + */ +CUresult CUDAAPI cuGraphNodeGetDependentNodes_v2(CUgraphNode hNode, CUgraphNode *dependentNodes, CUgraphEdgeData *edgeData, size_t *numDependentNodes); + +/** + * \brief Adds dependency edges to a graph + * + * The number of dependencies to be added is defined by \p numDependencies + * Elements in \p from and \p to at corresponding indices define a dependency. + * Each node in \p from and \p to must belong to \p hGraph. + * + * If \p numDependencies is 0, elements in \p from and \p to will be ignored. + * Specifying an existing dependency will return an error. + * + * \param hGraph - Graph to which dependencies are added + * \param from - Array of nodes that provide the dependencies + * \param to - Array of dependent nodes + * \param numDependencies - Number of dependencies to be added + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphRemoveDependencies, + * ::cuGraphGetEdges, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphAddDependencies(CUgraph hGraph, const CUgraphNode *from, const CUgraphNode *to, size_t numDependencies); + +/** + * \brief Adds dependency edges to a graph (12.3+) + * + * The number of dependencies to be added is defined by \p numDependencies + * Elements in \p from and \p to at corresponding indices define a dependency. + * Each node in \p from and \p to must belong to \p hGraph. + * + * If \p numDependencies is 0, elements in \p from and \p to will be ignored. + * Specifying an existing dependency will return an error. + * + * \param hGraph - Graph to which dependencies are added + * \param from - Array of nodes that provide the dependencies + * \param to - Array of dependent nodes + * \param edgeData - Optional array of edge data. If NULL, default (zeroed) edge data is assumed. + * \param numDependencies - Number of dependencies to be added + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphRemoveDependencies, + * ::cuGraphGetEdges, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphAddDependencies_v2(CUgraph hGraph, const CUgraphNode *from, const CUgraphNode *to, const CUgraphEdgeData *edgeData, size_t numDependencies); + +/** + * \brief Removes dependency edges from a graph + * + * The number of \p dependencies to be removed is defined by \p numDependencies. + * Elements in \p from and \p to at corresponding indices define a dependency. + * Each node in \p from and \p to must belong to \p hGraph. + * + * If \p numDependencies is 0, elements in \p from and \p to will be ignored. + * Specifying a non-existing dependency will return an error. + * + * Dependencies cannot be removed from graphs which contain allocation or free nodes. + * Any attempt to do so will return an error. + * + * \param hGraph - Graph from which to remove dependencies + * \param from - Array of nodes that provide the dependencies + * \param to - Array of dependent nodes + * \param numDependencies - Number of dependencies to be removed + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddDependencies, + * ::cuGraphGetEdges, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphRemoveDependencies(CUgraph hGraph, const CUgraphNode *from, const CUgraphNode *to, size_t numDependencies); + +/** + * \brief Removes dependency edges from a graph (12.3+) + * + * The number of \p dependencies to be removed is defined by \p numDependencies. + * Elements in \p from and \p to at corresponding indices define a dependency. + * Each node in \p from and \p to must belong to \p hGraph. + * + * If \p numDependencies is 0, elements in \p from and \p to will be ignored. + * Specifying an edge that does not exist in the graph, with data matching + * \p edgeData, results in an error. \p edgeData is nullable, which is equivalent + * to passing default (zeroed) data for each edge. + * + * Dependencies cannot be removed from graphs which contain allocation or free nodes. + * Any attempt to do so will return an error. + * + * \param hGraph - Graph from which to remove dependencies + * \param from - Array of nodes that provide the dependencies + * \param to - Array of dependent nodes + * \param edgeData - Optional array of edge data. If NULL, edge data is assumed to + * be default (zeroed). + * \param numDependencies - Number of dependencies to be removed + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddDependencies, + * ::cuGraphGetEdges, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphRemoveDependencies_v2(CUgraph hGraph, const CUgraphNode *from, const CUgraphNode *to, const CUgraphEdgeData *edgeData, size_t numDependencies); + +/** + * \brief Remove a node from the graph + * + * Removes \p hNode from its graph. This operation also severs any dependencies of other nodes + * on \p hNode and vice versa. + * + * Nodes which belong to a graph which contains allocation or free nodes cannot be destroyed. + * Any attempt to do so will return an error. + * + * \param hNode - Node to remove + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphDestroyNode(CUgraphNode hNode); + +/** + * \brief Creates an executable graph from a graph + * + * Instantiates \p hGraph as an executable graph. The graph is validated for any + * structural constraints or intra-node constraints which were not previously + * validated. If instantiation is successful, a handle to the instantiated graph + * is returned in \p phGraphExec. + * + * The \p flags parameter controls the behavior of instantiation and subsequent + * graph launches. Valid flags are: + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH, which configures a + * graph containing memory allocation nodes to automatically free any + * unfreed memory allocations before the graph is relaunched. + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_DEVICE_LAUNCH, which configures the graph for launch + * from the device. If this flag is passed, the executable graph handle returned can be + * used to launch the graph from both the host and device. This flag can only be used + * on platforms which support unified addressing. This flag cannot be used in + * conjunction with ::CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH. + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_USE_NODE_PRIORITY, which causes the graph + * to use the priorities from the per-node attributes rather than the priority + * of the launch stream during execution. Note that priorities are only available + * on kernel nodes, and are copied from stream priority during stream capture. + * + * If \p hGraph contains any allocation or free nodes, there can be at most one + * executable graph in existence for that graph at a time. An attempt to instantiate + * a second executable graph before destroying the first with ::cuGraphExecDestroy + * will result in an error. + * The same also applies if \p hGraph contains any device-updatable kernel nodes. + * + * If \p hGraph contains kernels which call device-side cudaGraphLaunch() from multiple + * contexts, this will result in an error. + * + * Graphs instantiated for launch on the device have additional restrictions which do not + * apply to host graphs: + * + * - The graph's nodes must reside on a single context. + * - The graph can only contain kernel nodes, memcpy nodes, memset nodes, and child graph nodes. + * - The graph cannot be empty and must contain at least one kernel, memcpy, or memset node. + * Operation-specific restrictions are outlined below. + * - Kernel nodes: + * - Use of CUDA Dynamic Parallelism is not permitted. + * - Cooperative launches are permitted as long as MPS is not in use. + * - Memcpy nodes: + * - Only copies involving device memory and/or pinned device-mapped host memory are permitted. + * - Copies involving CUDA arrays are not permitted. + * - Both operands must be accessible from the current context, and the current context must + * match the context of other nodes in the graph. + * + * \param phGraphExec - Returns instantiated graph + * \param hGraph - Graph to instantiate + * \param flags - Flags to control instantiation. See ::CUgraphInstantiate_flags. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphInstantiate, + * ::cuGraphCreate, + * ::cuGraphUpload, + * ::cuGraphLaunch, + * ::cuGraphExecDestroy + */ +CUresult CUDAAPI cuGraphInstantiate(CUgraphExec *phGraphExec, CUgraph hGraph, unsigned long long flags); + +/** + * \brief Creates an executable graph from a graph + * + * Instantiates \p hGraph as an executable graph according to the \p instantiateParams structure. + * The graph is validated for any structural constraints or intra-node constraints + * which were not previously validated. If instantiation is successful, a handle to + * the instantiated graph is returned in \p phGraphExec. + * + * \p instantiateParams controls the behavior of instantiation and subsequent + * graph launches, as well as returning more detailed information in the event of an error. + * ::CUDA_GRAPH_INSTANTIATE_PARAMS is defined as: + * + * \code + typedef struct { + cuuint64_t flags; + CUstream hUploadStream; + CUgraphNode hErrNode_out; + CUgraphInstantiateResult result_out; + } CUDA_GRAPH_INSTANTIATE_PARAMS; + * \endcode + * + * The \p flags field controls the behavior of instantiation and subsequent + * graph launches. Valid flags are: + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH, which configures a + * graph containing memory allocation nodes to automatically free any + * unfreed memory allocations before the graph is relaunched. + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_UPLOAD, which will perform an upload of the graph + * into \p hUploadStream once the graph has been instantiated. + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_DEVICE_LAUNCH, which configures the graph for launch + * from the device. If this flag is passed, the executable graph handle returned can be + * used to launch the graph from both the host and device. This flag can only be used + * on platforms which support unified addressing. This flag cannot be used in + * conjunction with ::CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH. + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_USE_NODE_PRIORITY, which causes the graph + * to use the priorities from the per-node attributes rather than the priority + * of the launch stream during execution. Note that priorities are only available + * on kernel nodes, and are copied from stream priority during stream capture. + * + * If \p hGraph contains any allocation or free nodes, there can be at most one + * executable graph in existence for that graph at a time. An attempt to instantiate a + * second executable graph before destroying the first with ::cuGraphExecDestroy will + * result in an error. + * The same also applies if \p hGraph contains any device-updatable kernel nodes. + * + * If \p hGraph contains kernels which call device-side cudaGraphLaunch() from multiple + * contexts, this will result in an error. + * + * Graphs instantiated for launch on the device have additional restrictions which do not + * apply to host graphs: + * + * - The graph's nodes must reside on a single context. + * - The graph can only contain kernel nodes, memcpy nodes, memset nodes, and child graph nodes. + * - The graph cannot be empty and must contain at least one kernel, memcpy, or memset node. + * Operation-specific restrictions are outlined below. + * - Kernel nodes: + * - Use of CUDA Dynamic Parallelism is not permitted. + * - Cooperative launches are permitted as long as MPS is not in use. + * - Memcpy nodes: + * - Only copies involving device memory and/or pinned device-mapped host memory are permitted. + * - Copies involving CUDA arrays are not permitted. + * - Both operands must be accessible from the current context, and the current context must + * match the context of other nodes in the graph. + * + * In the event of an error, the \p result_out and \p hErrNode_out fields will contain more + * information about the nature of the error. Possible error reporting includes: + * + * - ::CUDA_GRAPH_INSTANTIATE_ERROR, if passed an invalid value or if an unexpected error occurred + * which is described by the return value of the function. \p hErrNode_out will be set to NULL. + * - ::CUDA_GRAPH_INSTANTIATE_INVALID_STRUCTURE, if the graph structure is invalid. \p hErrNode_out + * will be set to one of the offending nodes. + * - ::CUDA_GRAPH_INSTANTIATE_NODE_OPERATION_NOT_SUPPORTED, if the graph is instantiated for device + * launch but contains a node of an unsupported node type, or a node which performs unsupported + * operations, such as use of CUDA dynamic parallelism within a kernel node. \p hErrNode_out will + * be set to this node. + * - ::CUDA_GRAPH_INSTANTIATE_MULTIPLE_CTXS_NOT_SUPPORTED, if the graph is instantiated for device + * launch but a node’s context differs from that of another node. This error can also be returned + * if a graph is not instantiated for device launch and it contains kernels which call device-side + * cudaGraphLaunch() from multiple contexts. \p hErrNode_out will be set to this node. + * + * If instantiation is successful, \p result_out will be set to ::CUDA_GRAPH_INSTANTIATE_SUCCESS, + * and \p hErrNode_out will be set to NULL. + * + * \param phGraphExec - Returns instantiated graph + * \param hGraph - Graph to instantiate + * \param instantiateParams - Instantiation parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate, + * ::cuGraphInstantiate, + * ::cuGraphExecDestroy + */ +CUresult CUDAAPI cuGraphInstantiateWithParams(CUgraphExec *phGraphExec, CUgraph hGraph, CUDA_GRAPH_INSTANTIATE_PARAMS *instantiateParams); + +/** + * \brief Query the instantiation flags of an executable graph + * + * Returns the flags that were passed to instantiation for the given executable graph. + * ::CUDA_GRAPH_INSTANTIATE_FLAG_UPLOAD will not be returned by this API as it does + * not affect the resulting executable graph. + * + * \param hGraphExec - The executable graph to query + * \param flags - Returns the instantiation flags + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphInstantiate, + * ::cuGraphInstantiateWithParams + */ +CUresult CUDAAPI cuGraphExecGetFlags(CUgraphExec hGraphExec, cuuint64_t *flags); + +/** + * \brief Sets the parameters for a kernel node in the given graphExec + * + * Sets the parameters of a kernel node in an executable graph \p hGraphExec. + * The node is identified by the corresponding node \p hNode in the + * non-executable graph, from which the executable graph was instantiated. + * + * \p hNode must not have been removed from the original graph. All \p nodeParams + * fields may change, but the following restrictions apply to \p func updates: + * + * - The owning context of the function cannot change. + * - A node whose function originally did not use CUDA dynamic parallelism cannot be updated + * to a function which uses CDP + * - A node whose function originally did not make device-side update calls cannot be updated + * to a function which makes device-side update calls. + * - If \p hGraphExec was not instantiated for device launch, a node whose function originally + * did not use device-side cudaGraphLaunch() cannot be updated to a function which uses + * device-side cudaGraphLaunch() unless the node resides on the same context as nodes which + * contained such calls at instantiate-time. If no such calls were present at instantiation, + * these updates cannot be performed at all. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * If \p hNode is a device-updatable kernel node, the next upload/launch of \p hGraphExec + * will overwrite any previous device-side updates. Additionally, applying host updates to a + * device-updatable kernel node while it is being updated from the device will result in + * undefined behavior. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - kernel node from the graph from which graphExec was instantiated + * \param nodeParams - Updated Parameters to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddKernelNode, + * ::cuGraphKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecKernelNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_KERNEL_NODE_PARAMS *nodeParams); + +/** + * \brief Sets the parameters for a memcpy node in the given graphExec. + * + * Updates the work represented by \p hNode in \p hGraphExec as though \p hNode had + * contained \p copyParams at instantiation. hNode must remain in the graph which was + * used to instantiate \p hGraphExec. Changed edges to and from hNode are ignored. + * + * The source and destination memory in \p copyParams must be allocated from the same + * contexts as the original source and destination memory. Both the instantiation-time + * memory operands and the memory operands in \p copyParams must be 1-dimensional. + * Zero-length operations are not supported. + * + * The modifications only affect future launches of \p hGraphExec. Already enqueued + * or running launches of \p hGraphExec are not affected by this call. hNode is also + * not modified by this call. + * + * Returns CUDA_ERROR_INVALID_VALUE if the memory operands' mappings changed or + * either the original or new memory operands are multidimensional. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Memcpy node from the graph which was used to instantiate graphExec + * \param copyParams - The updated parameters to set + * \param ctx - Context on which to run the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddMemcpyNode, + * ::cuGraphMemcpyNodeSetParams, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecMemcpyNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_MEMCPY3D *copyParams, CUcontext ctx); + +/** + * \brief Sets the parameters for a memset node in the given graphExec. + * + * Updates the work represented by \p hNode in \p hGraphExec as though \p hNode had + * contained \p memsetParams at instantiation. hNode must remain in the graph which was + * used to instantiate \p hGraphExec. Changed edges to and from hNode are ignored. + * + * Zero sized operations are not supported. + * + * The new destination pointer in memsetParams must be to the same kind of allocation + * as the original destination pointer and have the same context association and device mapping + * as the original destination pointer. + * + * Both the value and pointer address may be updated. + * Changing other aspects of the memset (width, height, element size or pitch) may cause the update to be rejected. + * Specifically, for 2d memsets, all dimension changes are rejected. + * For 1d memsets, changes in height are explicitly rejected and other changes are oportunistically allowed + * if the resulting work maps onto the work resources already allocated for the node. + * + * The modifications only affect future launches of \p hGraphExec. Already enqueued + * or running launches of \p hGraphExec are not affected by this call. hNode is also + * not modified by this call. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Memset node from the graph which was used to instantiate graphExec + * \param memsetParams - The updated parameters to set + * \param ctx - Context on which to run the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddMemsetNode, + * ::cuGraphMemsetNodeSetParams, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecMemsetNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_MEMSET_NODE_PARAMS *memsetParams, CUcontext ctx); + +/** + * \brief Sets the parameters for a host node in the given graphExec. + * + * Updates the work represented by \p hNode in \p hGraphExec as though \p hNode had + * contained \p nodeParams at instantiation. hNode must remain in the graph which was + * used to instantiate \p hGraphExec. Changed edges to and from hNode are ignored. + * + * The modifications only affect future launches of \p hGraphExec. Already enqueued + * or running launches of \p hGraphExec are not affected by this call. hNode is also + * not modified by this call. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Host node from the graph which was used to instantiate graphExec + * \param nodeParams - The updated parameters to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddHostNode, + * ::cuGraphHostNodeSetParams, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecHostNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_HOST_NODE_PARAMS *nodeParams); + +/** + * \brief Updates node parameters in the child graph node in the given graphExec. + * + * Updates the work represented by \p hNode in \p hGraphExec as though the nodes contained + * in \p hNode's graph had the parameters contained in \p childGraph's nodes at instantiation. + * \p hNode must remain in the graph which was used to instantiate \p hGraphExec. + * Changed edges to and from \p hNode are ignored. + * + * The modifications only affect future launches of \p hGraphExec. Already enqueued + * or running launches of \p hGraphExec are not affected by this call. \p hNode is also + * not modified by this call. + * + * The topology of \p childGraph, as well as the node insertion order, must match that + * of the graph contained in \p hNode. See ::cuGraphExecUpdate() for a list of restrictions + * on what can be updated in an instantiated graph. The update is recursive, so child graph + * nodes contained within the top level child graph will also be updated. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Host node from the graph which was used to instantiate graphExec + * \param childGraph - The graph supplying the updated parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddChildGraphNode, + * ::cuGraphChildGraphNodeGetGraph, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecChildGraphNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, CUgraph childGraph); + +/** + * \brief Sets the event for an event record node in the given graphExec + * + * Sets the event of an event record node in an executable graph \p hGraphExec. + * The node is identified by the corresponding node \p hNode in the + * non-executable graph, from which the executable graph was instantiated. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - event record node from the graph from which graphExec was instantiated + * \param event - Updated event to use + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddEventRecordNode, + * ::cuGraphEventRecordNodeGetEvent, + * ::cuGraphEventWaitNodeSetEvent, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecEventRecordNodeSetEvent(CUgraphExec hGraphExec, CUgraphNode hNode, CUevent event); + +/** + * \brief Sets the event for an event wait node in the given graphExec + * + * Sets the event of an event wait node in an executable graph \p hGraphExec. + * The node is identified by the corresponding node \p hNode in the + * non-executable graph, from which the executable graph was instantiated. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - event wait node from the graph from which graphExec was instantiated + * \param event - Updated event to use + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddEventWaitNode, + * ::cuGraphEventWaitNodeGetEvent, + * ::cuGraphEventRecordNodeSetEvent, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecEventWaitNodeSetEvent(CUgraphExec hGraphExec, CUgraphNode hNode, CUevent event); + +/** + * \brief Sets the parameters for an external semaphore signal node in the given graphExec + * + * Sets the parameters of an external semaphore signal node in an executable graph \p hGraphExec. + * The node is identified by the corresponding node \p hNode in the + * non-executable graph, from which the executable graph was instantiated. + * + * \p hNode must not have been removed from the original graph. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * Changing \p nodeParams->numExtSems is not supported. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - semaphore signal node from the graph from which graphExec was instantiated + * \param nodeParams - Updated Parameters to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddExternalSemaphoresSignalNode, + * ::cuImportExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecExternalSemaphoresSignalNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_EXT_SEM_SIGNAL_NODE_PARAMS *nodeParams); + +/** + * \brief Sets the parameters for an external semaphore wait node in the given graphExec + * + * Sets the parameters of an external semaphore wait node in an executable graph \p hGraphExec. + * The node is identified by the corresponding node \p hNode in the + * non-executable graph, from which the executable graph was instantiated. + * + * \p hNode must not have been removed from the original graph. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * Changing \p nodeParams->numExtSems is not supported. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - semaphore wait node from the graph from which graphExec was instantiated + * \param nodeParams - Updated Parameters to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuImportExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecExternalSemaphoresWaitNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_EXT_SEM_WAIT_NODE_PARAMS *nodeParams); + +/** + * \brief Enables or disables the specified node in the given graphExec + * + * Sets \p hNode to be either enabled or disabled. Disabled nodes are functionally equivalent + * to empty nodes until they are reenabled. Existing node parameters are not affected by + * disabling/enabling the node. + * + * The node is identified by the corresponding node \p hNode in the non-executable + * graph, from which the executable graph was instantiated. + * + * \p hNode must not have been removed from the original graph. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * If \p hNode is a device-updatable kernel node, the next upload/launch of \p hGraphExec + * will overwrite any previous device-side updates. Additionally, applying host updates to a + * device-updatable kernel node while it is being updated from the device will result in + * undefined behavior. + * + * \note Currently only kernel, memset and memcpy nodes are supported. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Node from the graph from which graphExec was instantiated + * \param isEnabled - Node is enabled if != 0, otherwise the node is disabled + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeGetEnabled, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + * ::cuGraphLaunch + */ +CUresult CUDAAPI cuGraphNodeSetEnabled(CUgraphExec hGraphExec, CUgraphNode hNode, unsigned int isEnabled); + +/** + * \brief Query whether a node in the given graphExec is enabled + * + * Sets isEnabled to 1 if \p hNode is enabled, or 0 if \p hNode is disabled. + * + * The node is identified by the corresponding node \p hNode in the non-executable + * graph, from which the executable graph was instantiated. + * + * \p hNode must not have been removed from the original graph. + * + * \note Currently only kernel, memset and memcpy nodes are supported. + * \note This function will not reflect device-side updates for device-updatable kernel nodes. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Node from the graph from which graphExec was instantiated + * \param isEnabled - Location to return the enabled status of the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetEnabled, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + * ::cuGraphLaunch + */ +CUresult CUDAAPI cuGraphNodeGetEnabled(CUgraphExec hGraphExec, CUgraphNode hNode, unsigned int *isEnabled); + +/** + * \brief Uploads an executable graph in a stream + * + * Uploads \p hGraphExec to the device in \p hStream without executing it. Uploads of + * the same \p hGraphExec will be serialized. Each upload is ordered behind both any + * previous work in \p hStream and any previous launches of \p hGraphExec. + * Uses memory cached by \p stream to back the allocations owned by \p hGraphExec. + * + * \param hGraphExec - Executable graph to upload + * \param hStream - Stream in which to upload the graph + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphInstantiate, + * ::cuGraphLaunch, + * ::cuGraphExecDestroy + */ +CUresult CUDAAPI cuGraphUpload(CUgraphExec hGraphExec, CUstream hStream); + +/** + * \brief Launches an executable graph in a stream + * + * Executes \p hGraphExec in \p hStream. Only one instance of \p hGraphExec may be executing + * at a time. Each launch is ordered behind both any previous work in \p hStream + * and any previous launches of \p hGraphExec. To execute a graph concurrently, it must be + * instantiated multiple times into multiple executable graphs. + * + * If any allocations created by \p hGraphExec remain unfreed (from a previous launch) and + * \p hGraphExec was not instantiated with ::CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH, + * the launch will fail with ::CUDA_ERROR_INVALID_VALUE. + * + * \param hGraphExec - Executable graph to launch + * \param hStream - Stream in which to launch the graph + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphInstantiate, + * ::cuGraphUpload, + * ::cuGraphExecDestroy + */ +CUresult CUDAAPI cuGraphLaunch(CUgraphExec hGraphExec, CUstream hStream); + +/** + * \brief Destroys an executable graph + * + * Destroys the executable graph specified by \p hGraphExec, as well + * as all of its executable nodes. If the executable graph is + * in-flight, it will not be terminated, but rather freed + * asynchronously on completion. + * + * \param hGraphExec - Executable graph to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphInstantiate, + * ::cuGraphUpload, + * ::cuGraphLaunch + */ +CUresult CUDAAPI cuGraphExecDestroy(CUgraphExec hGraphExec); + +/** + * \brief Destroys a graph + * + * Destroys the graph specified by \p hGraph, as well as all of its nodes. + * + * \param hGraph - Graph to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate + */ +CUresult CUDAAPI cuGraphDestroy(CUgraph hGraph); + +/** + * \brief Check whether an executable graph can be updated with a graph and perform the update if possible + * + * Updates the node parameters in the instantiated graph specified by \p hGraphExec with the + * node parameters in a topologically identical graph specified by \p hGraph. + * + * Limitations: + * + * - Kernel nodes: + * - The owning context of the function cannot change. + * - A node whose function originally did not use CUDA dynamic parallelism cannot be updated + * to a function which uses CDP. + * - A node whose function originally did not make device-side update calls cannot be updated + * to a function which makes device-side update calls. + * - A cooperative node cannot be updated to a non-cooperative node, and vice-versa. + * - If the graph was instantiated with CUDA_GRAPH_INSTANTIATE_FLAG_USE_NODE_PRIORITY, the + * priority attribute cannot change. Equality is checked on the originally requested + * priority values, before they are clamped to the device's supported range. + * - If \p hGraphExec was not instantiated for device launch, a node whose function originally + * did not use device-side cudaGraphLaunch() cannot be updated to a function which uses + * device-side cudaGraphLaunch() unless the node resides on the same context as nodes which + * contained such calls at instantiate-time. If no such calls were present at instantiation, + * these updates cannot be performed at all. + * - Neither \p hGraph nor \p hGraphExec may contain device-updatable kernel nodes. + * - Memset and memcpy nodes: + * - The CUDA device(s) to which the operand(s) was allocated/mapped cannot change. + * - The source/destination memory must be allocated from the same contexts as the original + * source/destination memory. + * - For 2d memsets, only address and assinged value may be updated. + * - For 1d memsets, updating dimensions is also allowed, but may fail if the resulting operation doesn't + * map onto the work resources already allocated for the node. + * - Additional memcpy node restrictions: + * - Changing either the source or destination memory type(i.e. CU_MEMORYTYPE_DEVICE, + * CU_MEMORYTYPE_ARRAY, etc.) is not supported. + * - External semaphore wait nodes and record nodes: + * - Changing the number of semaphores is not supported. + * - Conditional nodes: + * - Changing node parameters is not supported. + * - Changeing parameters of nodes within the conditional body graph is subject to the rules above. + * - Conditional handle flags and default values are updated as part of the graph update. + * + * Note: The API may add further restrictions in future releases. The return code should always be checked. + * + * cuGraphExecUpdate sets the result member of \p resultInfo to CU_GRAPH_EXEC_UPDATE_ERROR_TOPOLOGY_CHANGED + * under the following conditions: + * - The count of nodes directly in \p hGraphExec and \p hGraph differ, in which case resultInfo->errorNode + * is set to NULL. + * - \p hGraph has more exit nodes than \p hGraph, in which case resultInfo->errorNode is set to one of + * the exit nodes in hGraph. + * - A node in \p hGraph has a different number of dependencies than the node from \p hGraphExec it is paired with, + * in which case resultInfo->errorNode is set to the node from \p hGraph. + * - A node in \p hGraph has a dependency that does not match with the corresponding dependency of the paired node + * from \p hGraphExec. resultInfo->errorNode will be set to the node from \p hGraph. resultInfo->errorFromNode + * will be set to the mismatched dependency. The dependencies are paired based on edge order and a dependency + * does not match when the nodes are already paired based on other edges examined in the graph. + * + * cuGraphExecUpdate sets the result member of \p resultInfo to: + * - CU_GRAPH_EXEC_UPDATE_ERROR if passed an invalid value. + * - CU_GRAPH_EXEC_UPDATE_ERROR_TOPOLOGY_CHANGED if the graph topology changed + * - CU_GRAPH_EXEC_UPDATE_ERROR_NODE_TYPE_CHANGED if the type of a node changed, in which case + * \p hErrorNode_out is set to the node from \p hGraph. + * - CU_GRAPH_EXEC_UPDATE_ERROR_UNSUPPORTED_FUNCTION_CHANGE if the function changed in an unsupported + * way(see note above), in which case \p hErrorNode_out is set to the node from \p hGraph + * - CU_GRAPH_EXEC_UPDATE_ERROR_PARAMETERS_CHANGED if any parameters to a node changed in a way + * that is not supported, in which case \p hErrorNode_out is set to the node from \p hGraph. + * - CU_GRAPH_EXEC_UPDATE_ERROR_ATTRIBUTES_CHANGED if any attributes of a node changed in a way + * that is not supported, in which case \p hErrorNode_out is set to the node from \p hGraph. + * - CU_GRAPH_EXEC_UPDATE_ERROR_NOT_SUPPORTED if something about a node is unsupported, like + * the node's type or configuration, in which case \p hErrorNode_out is set to the node from \p hGraph + * + * If the update fails for a reason not listed above, the result member of \p resultInfo will be set + * to CU_GRAPH_EXEC_UPDATE_ERROR. If the update succeeds, the result member will be set to CU_GRAPH_EXEC_UPDATE_SUCCESS. + * + * cuGraphExecUpdate returns CUDA_SUCCESS when the updated was performed successfully. It returns + * CUDA_ERROR_GRAPH_EXEC_UPDATE_FAILURE if the graph update was not performed because it included + * changes which violated constraints specific to instantiated graph update. + * + * \param hGraphExec The instantiated graph to be updated + * \param hGraph The graph containing the updated parameters + * \param resultInfo the error info structure + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_GRAPH_EXEC_UPDATE_FAILURE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecUpdate(CUgraphExec hGraphExec, CUgraph hGraph, CUgraphExecUpdateResultInfo *resultInfo); + +/** + * \brief Copies attributes from source node to destination node. + * + * Copies attributes from source node \p src to destination node \p dst. + * Both node must have the same context. + * + * \param[out] dst Destination node + * \param[in] src Source node + * For list of attributes see ::CUkernelNodeAttrID + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuGraphKernelNodeCopyAttributes(CUgraphNode dst, CUgraphNode src); + +/** + * \brief Queries node attribute. + * + * Queries attribute \p attr from node \p hNode and stores it in corresponding + * member of \p value_out. + * + * \param[in] hNode + * \param[in] attr + * \param[out] value_out + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuGraphKernelNodeGetAttribute(CUgraphNode hNode, CUkernelNodeAttrID attr, + CUkernelNodeAttrValue *value_out); + +/** + * \brief Sets node attribute. + * + * Sets attribute \p attr on node \p hNode from corresponding attribute of + * \p value. + * + * \param[out] hNode + * \param[in] attr + * \param[out] value + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuGraphKernelNodeSetAttribute(CUgraphNode hNode, CUkernelNodeAttrID attr, + const CUkernelNodeAttrValue *value); + +/** + * \brief Write a DOT file describing graph structure + * + * Using the provided \p hGraph, write to \p path a DOT formatted description of the graph. + * By default this includes the graph topology, node types, node id, kernel names and memcpy direction. + * \p flags can be specified to write more detailed information about each node type such as + * parameter values, kernel attributes, node and function handles. + * + * \param hGraph - The graph to create a DOT file from + * \param path - The path to write the DOT file to + * \param flags - Flags from CUgraphDebugDot_flags for specifying which additional node information to write + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OPERATING_SYSTEM + */ +CUresult CUDAAPI cuGraphDebugDotPrint(CUgraph hGraph, const char *path, unsigned int flags); + +/** + * \brief Create a user object + * + * Create a user object with the specified destructor callback and initial reference count. The + * initial references are owned by the caller. + * + * Destructor callbacks cannot make CUDA API calls and should avoid blocking behavior, as they + * are executed by a shared internal thread. Another thread may be signaled to perform such + * actions, if it does not block forward progress of tasks scheduled through CUDA. + * + * See CUDA User Objects in the CUDA C++ Programming Guide for more information on user objects. + * + * \param object_out - Location to return the user object handle + * \param ptr - The pointer to pass to the destroy function + * \param destroy - Callback to free the user object when it is no longer in use + * \param initialRefcount - The initial refcount to create the object with, typically 1. The + * initial references are owned by the calling thread. + * \param flags - Currently it is required to pass ::CU_USER_OBJECT_NO_DESTRUCTOR_SYNC, + * which is the only defined flag. This indicates that the destroy + * callback cannot be waited on by any CUDA API. Users requiring + * synchronization of the callback should signal its completion + * manually. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuUserObjectRetain, + * ::cuUserObjectRelease, + * ::cuGraphRetainUserObject, + * ::cuGraphReleaseUserObject, + * ::cuGraphCreate + */ +CUresult CUDAAPI cuUserObjectCreate(CUuserObject *object_out, void *ptr, CUhostFn destroy, + unsigned int initialRefcount, unsigned int flags); + +/** + * \brief Retain a reference to a user object + * + * Retains new references to a user object. The new references are owned by the caller. + * + * See CUDA User Objects in the CUDA C++ Programming Guide for more information on user objects. + * + * \param object - The object to retain + * \param count - The number of references to retain, typically 1. Must be nonzero + * and not larger than INT_MAX. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuUserObjectCreate, + * ::cuUserObjectRelease, + * ::cuGraphRetainUserObject, + * ::cuGraphReleaseUserObject, + * ::cuGraphCreate + */ +CUresult CUDAAPI cuUserObjectRetain(CUuserObject object, unsigned int count); + +/** + * \brief Release a reference to a user object + * + * Releases user object references owned by the caller. The object's destructor is invoked if + * the reference count reaches zero. + * + * It is undefined behavior to release references not owned by the caller, or to use a user + * object handle after all references are released. + * + * See CUDA User Objects in the CUDA C++ Programming Guide for more information on user objects. + * + * \param object - The object to release + * \param count - The number of references to release, typically 1. Must be nonzero + * and not larger than INT_MAX. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuUserObjectCreate, + * ::cuUserObjectRetain, + * ::cuGraphRetainUserObject, + * ::cuGraphReleaseUserObject, + * ::cuGraphCreate + */ +CUresult CUDAAPI cuUserObjectRelease(CUuserObject object, unsigned int count); + +/** + * \brief Retain a reference to a user object from a graph + * + * Creates or moves user object references that will be owned by a CUDA graph. + * + * See CUDA User Objects in the CUDA C++ Programming Guide for more information on user objects. + * + * \param graph - The graph to associate the reference with + * \param object - The user object to retain a reference for + * \param count - The number of references to add to the graph, typically 1. Must be + * nonzero and not larger than INT_MAX. + * \param flags - The optional flag ::CU_GRAPH_USER_OBJECT_MOVE transfers references + * from the calling thread, rather than create new references. Pass 0 + * to create new references. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuUserObjectCreate, + * ::cuUserObjectRetain, + * ::cuUserObjectRelease, + * ::cuGraphReleaseUserObject, + * ::cuGraphCreate + */ +CUresult CUDAAPI cuGraphRetainUserObject(CUgraph graph, CUuserObject object, unsigned int count, unsigned int flags); + +/** + * \brief Release a user object reference from a graph + * + * Releases user object references owned by a graph. + * + * See CUDA User Objects in the CUDA C++ Programming Guide for more information on user objects. + * + * \param graph - The graph that will release the reference + * \param object - The user object to release a reference for + * \param count - The number of references to release, typically 1. Must be nonzero + * and not larger than INT_MAX. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuUserObjectCreate, + * ::cuUserObjectRetain, + * ::cuUserObjectRelease, + * ::cuGraphRetainUserObject, + * ::cuGraphCreate + */ +CUresult CUDAAPI cuGraphReleaseUserObject(CUgraph graph, CUuserObject object, unsigned int count); + +/** + * \brief Adds a node of arbitrary type to a graph + * + * Creates a new node in \p hGraph described by \p nodeParams with \p numDependencies + * dependencies specified via \p dependencies. \p numDependencies may be 0. + * \p dependencies may be null if \p numDependencies is 0. \p dependencies may not have + * any duplicate entries. + * + * \p nodeParams is a tagged union. The node type should be specified in the \p type field, + * and type-specific parameters in the corresponding union member. All unused bytes - that + * is, \p reserved0 and all bytes past the utilized union member - must be set to zero. + * It is recommended to use brace initialization or memset to ensure all bytes are + * initialized. + * + * Note that for some node types, \p nodeParams may contain "out parameters" which are + * modified during the call, such as \p nodeParams->alloc.dptr. + * + * A handle to the new node will be returned in \p phGraphNode. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Specification of the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate, + * ::cuGraphNodeSetParams, + * ::cuGraphExecNodeSetParams + */ +CUresult CUDAAPI cuGraphAddNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, CUgraphNodeParams *nodeParams); + +/** + * \brief Adds a node of arbitrary type to a graph (12.3+) + * + * Creates a new node in \p hGraph described by \p nodeParams with \p numDependencies + * dependencies specified via \p dependencies. \p numDependencies may be 0. + * \p dependencies may be null if \p numDependencies is 0. \p dependencies may not have + * any duplicate entries. + * + * \p nodeParams is a tagged union. The node type should be specified in the \p type field, + * and type-specific parameters in the corresponding union member. All unused bytes - that + * is, \p reserved0 and all bytes past the utilized union member - must be set to zero. + * It is recommended to use brace initialization or memset to ensure all bytes are + * initialized. + * + * Note that for some node types, \p nodeParams may contain "out parameters" which are + * modified during the call, such as \p nodeParams->alloc.dptr. + * + * A handle to the new node will be returned in \p phGraphNode. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param dependencyData - Optional edge data for the dependencies. If NULL, the data is + * assumed to be default (zeroed) for all dependencies. + * \param numDependencies - Number of dependencies + * \param nodeParams - Specification of the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate, + * ::cuGraphNodeSetParams, + * ::cuGraphExecNodeSetParams + */ +CUresult CUDAAPI cuGraphAddNode_v2(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, const CUgraphEdgeData *dependencyData, size_t numDependencies, CUgraphNodeParams *nodeParams); + +/** + * \brief Update's a graph node's parameters + * + * Sets the parameters of graph node \p hNode to \p nodeParams. The node type specified by + * \p nodeParams->type must match the type of \p hNode. \p nodeParams must be fully + * initialized and all unused bytes (reserved, padding) zeroed. + * + * Modifying parameters is not supported for node types CU_GRAPH_NODE_TYPE_MEM_ALLOC and + * CU_GRAPH_NODE_TYPE_MEM_FREE. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphExecNodeSetParams + */ +CUresult CUDAAPI cuGraphNodeSetParams(CUgraphNode hNode, CUgraphNodeParams *nodeParams); + +/** + * \brief Update's a graph node's parameters in an instantiated graph + * + * Sets the parameters of a node in an executable graph \p hGraphExec. The node is identified + * by the corresponding node \p hNode in the non-executable graph from which the executable + * graph was instantiated. \p hNode must not have been removed from the original graph. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * Allowed changes to parameters on executable graphs are as follows: + * + *
Node typeAllowed changes + *
kernelSee ::cuGraphExecKernelNodeSetParams + *
memcpyAddresses for 1-dimensional copies if allocated in same context; see ::cuGraphExecMemcpyNodeSetParams + *
memsetAddresses for 1-dimensional memsets if allocated in same context; see ::cuGraphExecMemsetNodeSetParams + *
hostUnrestricted + *
child graphTopology must match and restrictions apply recursively; see ::cuGraphExecUpdate + *
event waitUnrestricted + *
event recordUnrestricted + *
external semaphore signalNumber of semaphore operations cannot change + *
external semaphore waitNumber of semaphore operations cannot change + *
memory allocationAPI unsupported + *
memory freeAPI unsupported + *
batch memopsAddresses, values, and operation type for wait operations; see ::cuGraphExecBatchMemOpNodeSetParams + *
+ * + * \param hGraphExec - The executable graph in which to update the specified node + * \param hNode - Corresponding node from the graph from which graphExec was instantiated + * \param nodeParams - Updated Parameters to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphNodeSetParams + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, CUgraphNodeParams *nodeParams); + +/** + * \brief Create a conditional handle + * + * Creates a conditional handle associated with \p hGraph. + * + * The conditional handle must be associated with a conditional node in this graph or one of its children. + * + * Handles not associated with a conditional node may cause graph instantiation to fail. + * + * Handles can only be set from the context with which they are associated. + * + * \param pHandle_out - Pointer used to return the handle to the caller. + * \param hGraph - Graph which will contain the conditional node using this handle. + * \param ctx - Context for the handle and associated conditional node. + * \param defaultLaunchValue - Optional initial value for the conditional variable. + * \param flags - Currently must be CU_GRAPH_COND_ASSIGN_DEFAULT or 0. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode + */ +CUresult CUDAAPI cuGraphConditionalHandleCreate(CUgraphConditionalHandle *pHandle_out, CUgraph hGraph, CUcontext ctx, unsigned int defaultLaunchValue, unsigned int flags); + +/** @} */ /* END CUDA_GRAPH */ + +/** + * \defgroup CUDA_OCCUPANCY Occupancy + * + * ___MANBRIEF___ occupancy calculation functions of the low-level CUDA driver + * API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the occupancy calculation functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns occupancy of a function + * + * Returns in \p *numBlocks the number of the maximum active blocks per + * streaming multiprocessor. + * + * Note that the API can also be used with context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will be the current context. + * + * \param numBlocks - Returned occupancy + * \param func - Kernel for which occupancy is calculated + * \param blockSize - Block size the kernel is intended to be launched with + * \param dynamicSMemSize - Per-block dynamic shared memory usage intended, in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cudaOccupancyMaxActiveBlocksPerMultiprocessor + */ +CUresult CUDAAPI cuOccupancyMaxActiveBlocksPerMultiprocessor(int *numBlocks, CUfunction func, int blockSize, size_t dynamicSMemSize); + +/** + * \brief Returns occupancy of a function + * + * Returns in \p *numBlocks the number of the maximum active blocks per + * streaming multiprocessor. + * + * The \p Flags parameter controls how special cases are handled. The + * valid flags are: + * + * - ::CU_OCCUPANCY_DEFAULT, which maintains the default behavior as + * ::cuOccupancyMaxActiveBlocksPerMultiprocessor; + * + * - ::CU_OCCUPANCY_DISABLE_CACHING_OVERRIDE, which suppresses the + * default behavior on platform where global caching affects + * occupancy. On such platforms, if caching is enabled, but + * per-block SM resource usage would result in zero occupancy, the + * occupancy calculator will calculate the occupancy as if caching + * is disabled. Setting ::CU_OCCUPANCY_DISABLE_CACHING_OVERRIDE makes + * the occupancy calculator to return 0 in such cases. More information + * can be found about this feature in the "Unified L1/Texture Cache" + * section of the Maxwell tuning guide. + * + * Note that the API can also be with launch context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will be the current context. + * + * \param numBlocks - Returned occupancy + * \param func - Kernel for which occupancy is calculated + * \param blockSize - Block size the kernel is intended to be launched with + * \param dynamicSMemSize - Per-block dynamic shared memory usage intended, in bytes + * \param flags - Requested behavior for the occupancy calculator + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cudaOccupancyMaxActiveBlocksPerMultiprocessorWithFlags + */ +CUresult CUDAAPI cuOccupancyMaxActiveBlocksPerMultiprocessorWithFlags(int *numBlocks, CUfunction func, int blockSize, size_t dynamicSMemSize, unsigned int flags); + +/** + * \brief Suggest a launch configuration with reasonable occupancy + * + * Returns in \p *blockSize a reasonable block size that can achieve + * the maximum occupancy (or, the maximum number of active warps with + * the fewest blocks per multiprocessor), and in \p *minGridSize the + * minimum grid size to achieve the maximum occupancy. + * + * If \p blockSizeLimit is 0, the configurator will use the maximum + * block size permitted by the device / function instead. + * + * If per-block dynamic shared memory allocation is not needed, the + * user should leave both \p blockSizeToDynamicSMemSize and \p + * dynamicSMemSize as 0. + * + * If per-block dynamic shared memory allocation is needed, then if + * the dynamic shared memory size is constant regardless of block + * size, the size should be passed through \p dynamicSMemSize, and \p + * blockSizeToDynamicSMemSize should be NULL. + * + * Otherwise, if the per-block dynamic shared memory size varies with + * different block sizes, the user needs to provide a unary function + * through \p blockSizeToDynamicSMemSize that computes the dynamic + * shared memory needed by \p func for any given block size. \p + * dynamicSMemSize is ignored. An example signature is: + * + * \code + * // Take block size, returns dynamic shared memory needed + * size_t blockToSmem(int blockSize); + * \endcode + * + * Note that the API can also be used with context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will be the current context. + * + * \param minGridSize - Returned minimum grid size needed to achieve the maximum occupancy + * \param blockSize - Returned maximum block size that can achieve the maximum occupancy + * \param func - Kernel for which launch configuration is calculated + * \param blockSizeToDynamicSMemSize - A function that calculates how much per-block dynamic shared memory \p func uses based on the block size + * \param dynamicSMemSize - Dynamic shared memory usage intended, in bytes + * \param blockSizeLimit - The maximum block size \p func is designed to handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cudaOccupancyMaxPotentialBlockSize + */ +CUresult CUDAAPI cuOccupancyMaxPotentialBlockSize(int *minGridSize, int *blockSize, CUfunction func, CUoccupancyB2DSize blockSizeToDynamicSMemSize, size_t dynamicSMemSize, int blockSizeLimit); + +/** + * \brief Suggest a launch configuration with reasonable occupancy + * + * An extended version of ::cuOccupancyMaxPotentialBlockSize. In + * addition to arguments passed to ::cuOccupancyMaxPotentialBlockSize, + * ::cuOccupancyMaxPotentialBlockSizeWithFlags also takes a \p Flags + * parameter. + * + * The \p Flags parameter controls how special cases are handled. The + * valid flags are: + * + * - ::CU_OCCUPANCY_DEFAULT, which maintains the default behavior as + * ::cuOccupancyMaxPotentialBlockSize; + * + * - ::CU_OCCUPANCY_DISABLE_CACHING_OVERRIDE, which suppresses the + * default behavior on platform where global caching affects + * occupancy. On such platforms, the launch configurations that + * produces maximal occupancy might not support global + * caching. Setting ::CU_OCCUPANCY_DISABLE_CACHING_OVERRIDE + * guarantees that the the produced launch configuration is global + * caching compatible at a potential cost of occupancy. More information + * can be found about this feature in the "Unified L1/Texture Cache" + * section of the Maxwell tuning guide. + * + * Note that the API can also be used with context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will be the current context. + * + * \param minGridSize - Returned minimum grid size needed to achieve the maximum occupancy + * \param blockSize - Returned maximum block size that can achieve the maximum occupancy + * \param func - Kernel for which launch configuration is calculated + * \param blockSizeToDynamicSMemSize - A function that calculates how much per-block dynamic shared memory \p func uses based on the block size + * \param dynamicSMemSize - Dynamic shared memory usage intended, in bytes + * \param blockSizeLimit - The maximum block size \p func is designed to handle + * \param flags - Options + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cudaOccupancyMaxPotentialBlockSizeWithFlags + */ +CUresult CUDAAPI cuOccupancyMaxPotentialBlockSizeWithFlags(int *minGridSize, int *blockSize, CUfunction func, CUoccupancyB2DSize blockSizeToDynamicSMemSize, size_t dynamicSMemSize, int blockSizeLimit, unsigned int flags); + +/** + * \brief Returns dynamic shared memory available per block when launching \p numBlocks blocks on SM + * + * Returns in \p *dynamicSmemSize the maximum size of dynamic shared memory to allow \p numBlocks blocks per SM. + * + * Note that the API can also be used with context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will be the current context. + * + * \param dynamicSmemSize - Returned maximum dynamic shared memory + * \param func - Kernel function for which occupancy is calculated + * \param numBlocks - Number of blocks to fit on SM + * \param blockSize - Size of the blocks + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + */ +CUresult CUDAAPI cuOccupancyAvailableDynamicSMemPerBlock(size_t *dynamicSmemSize, CUfunction func, int numBlocks, int blockSize); + +/** + * \brief Given the kernel function (\p func) and launch configuration + * (\p config), return the maximum cluster size in \p *clusterSize. + * + * The cluster dimensions in \p config are ignored. If func has a required + * cluster size set (see ::cudaFuncGetAttributes / ::cuFuncGetAttribute),\p + * *clusterSize will reflect the required cluster size. + * + * By default this function will always return a value that's portable on + * future hardware. A higher value may be returned if the kernel function + * allows non-portable cluster sizes. + * + * This function will respect the compile time launch bounds. + * + * Note that the API can also be used with context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will either be taken from the specified stream \p config->hStream + * or the current context in case of NULL stream. + * + * \param clusterSize - Returned maximum cluster size that can be launched + * for the given kernel function and launch configuration + * \param func - Kernel function for which maximum cluster + * size is calculated + * \param config - Launch configuration for the given kernel function + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cudaFuncGetAttributes, + * ::cuFuncGetAttribute + */ +CUresult CUDAAPI cuOccupancyMaxPotentialClusterSize(int *clusterSize, CUfunction func, const CUlaunchConfig *config); + +/** + * \brief Given the kernel function (\p func) and launch configuration + * (\p config), return the maximum number of clusters that could co-exist + * on the target device in \p *numClusters. + * + * If the function has required cluster size already set (see + * ::cudaFuncGetAttributes / ::cuFuncGetAttribute), the cluster size + * from config must either be unspecified or match the required size. + * Without required sizes, the cluster size must be specified in config, + * else the function will return an error. + * + * Note that various attributes of the kernel function may affect occupancy + * calculation. Runtime environment may affect how the hardware schedules + * the clusters, so the calculated occupancy is not guaranteed to be achievable. + * + * Note that the API can also be used with context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will either be taken from the specified stream \p config->hStream + * or the current context in case of NULL stream. + * + * \param numClusters - Returned maximum number of clusters that + * could co-exist on the target device + * \param func - Kernel function for which maximum number + * of clusters are calculated + * \param config - Launch configuration for the given kernel function + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_CLUSTER_SIZE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cudaFuncGetAttributes, + * ::cuFuncGetAttribute + */ +CUresult CUDAAPI cuOccupancyMaxActiveClusters(int *numClusters, CUfunction func, const CUlaunchConfig *config); +/** @} */ /* END CUDA_OCCUPANCY */ + +/** + * \defgroup CUDA_TEXREF_DEPRECATED Texture Reference Management [DEPRECATED] + * + * ___MANBRIEF___ deprecated texture reference management functions of the + * low-level CUDA driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the deprecated texture reference management + * functions of the low-level CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Binds an array as a texture reference + * + * \deprecated + * + * Binds the CUDA array \p hArray to the texture reference \p hTexRef. Any + * previous address or CUDA array state associated with the texture reference + * is superseded by this function. \p Flags must be set to + * ::CU_TRSA_OVERRIDE_FORMAT. Any CUDA array previously bound to \p hTexRef is + * unbound. + * + * \param hTexRef - Texture reference to bind + * \param hArray - Array to bind + * \param Flags - Options (must be ::CU_TRSA_OVERRIDE_FORMAT) + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetArray(CUtexref hTexRef, CUarray hArray, unsigned int Flags); + +/** + * \brief Binds a mipmapped array to a texture reference + * + * \deprecated + * + * Binds the CUDA mipmapped array \p hMipmappedArray to the texture reference \p hTexRef. + * Any previous address or CUDA array state associated with the texture reference + * is superseded by this function. \p Flags must be set to ::CU_TRSA_OVERRIDE_FORMAT. + * Any CUDA array previously bound to \p hTexRef is unbound. + * + * \param hTexRef - Texture reference to bind + * \param hMipmappedArray - Mipmapped array to bind + * \param Flags - Options (must be ::CU_TRSA_OVERRIDE_FORMAT) + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetMipmappedArray(CUtexref hTexRef, CUmipmappedArray hMipmappedArray, unsigned int Flags); + +/** + * \brief Binds an address as a texture reference + * + * \deprecated + * + * Binds a linear address range to the texture reference \p hTexRef. Any + * previous address or CUDA array state associated with the texture reference + * is superseded by this function. Any memory previously bound to \p hTexRef + * is unbound. + * + * Since the hardware enforces an alignment requirement on texture base + * addresses, ::cuTexRefSetAddress() passes back a byte offset in + * \p *ByteOffset that must be applied to texture fetches in order to read from + * the desired memory. This offset must be divided by the texel size and + * passed to kernels that read from the texture so they can be applied to the + * ::tex1Dfetch() function. + * + * If the device memory pointer was returned from ::cuMemAlloc(), the offset + * is guaranteed to be 0 and NULL may be passed as the \p ByteOffset parameter. + * + * The total number of elements (or texels) in the linear address range + * cannot exceed ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LINEAR_WIDTH. + * The number of elements is computed as (\p bytes / bytesPerElement), + * where bytesPerElement is determined from the data format and number of + * components set using ::cuTexRefSetFormat(). + * + * \param ByteOffset - Returned byte offset + * \param hTexRef - Texture reference to bind + * \param dptr - Device pointer to bind + * \param bytes - Size of memory to bind in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetAddress(size_t *ByteOffset, CUtexref hTexRef, CUdeviceptr dptr, size_t bytes); + +/** + * \brief Binds an address as a 2D texture reference + * + * \deprecated + * + * Binds a linear address range to the texture reference \p hTexRef. Any + * previous address or CUDA array state associated with the texture reference + * is superseded by this function. Any memory previously bound to \p hTexRef + * is unbound. + * + * Using a ::tex2D() function inside a kernel requires a call to either + * ::cuTexRefSetArray() to bind the corresponding texture reference to an + * array, or ::cuTexRefSetAddress2D() to bind the texture reference to linear + * memory. + * + * Function calls to ::cuTexRefSetFormat() cannot follow calls to + * ::cuTexRefSetAddress2D() for the same texture reference. + * + * It is required that \p dptr be aligned to the appropriate hardware-specific + * texture alignment. You can query this value using the device attribute + * ::CU_DEVICE_ATTRIBUTE_TEXTURE_ALIGNMENT. If an unaligned \p dptr is + * supplied, ::CUDA_ERROR_INVALID_VALUE is returned. + * + * \p Pitch has to be aligned to the hardware-specific texture pitch alignment. + * This value can be queried using the device attribute + * ::CU_DEVICE_ATTRIBUTE_TEXTURE_PITCH_ALIGNMENT. If an unaligned \p Pitch is + * supplied, ::CUDA_ERROR_INVALID_VALUE is returned. + * + * Width and Height, which are specified in elements (or texels), cannot exceed + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_WIDTH and + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_HEIGHT respectively. + * \p Pitch, which is specified in bytes, cannot exceed + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_PITCH. + * + * \param hTexRef - Texture reference to bind + * \param desc - Descriptor of CUDA array + * \param dptr - Device pointer to bind + * \param Pitch - Line pitch in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetAddress2D(CUtexref hTexRef, const CUDA_ARRAY_DESCRIPTOR *desc, CUdeviceptr dptr, size_t Pitch); + +/** + * \brief Sets the format for a texture reference + * + * \deprecated + * + * Specifies the format of the data to be read by the texture reference + * \p hTexRef. \p fmt and \p NumPackedComponents are exactly analogous to the + * ::Format and ::NumChannels members of the ::CUDA_ARRAY_DESCRIPTOR structure: + * They specify the format of each component and the number of components per + * array element. + * + * \param hTexRef - Texture reference + * \param fmt - Format to set + * \param NumPackedComponents - Number of components per array element + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat, + * ::cudaCreateChannelDesc + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetFormat(CUtexref hTexRef, CUarray_format fmt, int NumPackedComponents); + +/** + * \brief Sets the addressing mode for a texture reference + * + * \deprecated + * + * Specifies the addressing mode \p am for the given dimension \p dim of the + * texture reference \p hTexRef. If \p dim is zero, the addressing mode is + * applied to the first parameter of the functions used to fetch from the + * texture; if \p dim is 1, the second, and so on. ::CUaddress_mode is defined + * as: + * \code + typedef enum CUaddress_mode_enum { + CU_TR_ADDRESS_MODE_WRAP = 0, + CU_TR_ADDRESS_MODE_CLAMP = 1, + CU_TR_ADDRESS_MODE_MIRROR = 2, + CU_TR_ADDRESS_MODE_BORDER = 3 + } CUaddress_mode; + * \endcode + * + * Note that this call has no effect if \p hTexRef is bound to linear memory. + * Also, if the flag, ::CU_TRSF_NORMALIZED_COORDINATES, is not set, the only + * supported address mode is ::CU_TR_ADDRESS_MODE_CLAMP. + * + * \param hTexRef - Texture reference + * \param dim - Dimension + * \param am - Addressing mode to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetAddressMode(CUtexref hTexRef, int dim, CUaddress_mode am); + +/** + * \brief Sets the filtering mode for a texture reference + * + * \deprecated + * + * Specifies the filtering mode \p fm to be used when reading memory through + * the texture reference \p hTexRef. ::CUfilter_mode_enum is defined as: + * + * \code + typedef enum CUfilter_mode_enum { + CU_TR_FILTER_MODE_POINT = 0, + CU_TR_FILTER_MODE_LINEAR = 1 + } CUfilter_mode; + * \endcode + * + * Note that this call has no effect if \p hTexRef is bound to linear memory. + * + * \param hTexRef - Texture reference + * \param fm - Filtering mode to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetFilterMode(CUtexref hTexRef, CUfilter_mode fm); + +/** + * \brief Sets the mipmap filtering mode for a texture reference + * + * \deprecated + * + * Specifies the mipmap filtering mode \p fm to be used when reading memory through + * the texture reference \p hTexRef. ::CUfilter_mode_enum is defined as: + * + * \code + typedef enum CUfilter_mode_enum { + CU_TR_FILTER_MODE_POINT = 0, + CU_TR_FILTER_MODE_LINEAR = 1 + } CUfilter_mode; + * \endcode + * + * Note that this call has no effect if \p hTexRef is not bound to a mipmapped array. + * + * \param hTexRef - Texture reference + * \param fm - Filtering mode to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetMipmapFilterMode(CUtexref hTexRef, CUfilter_mode fm); + +/** + * \brief Sets the mipmap level bias for a texture reference + * + * \deprecated + * + * Specifies the mipmap level bias \p bias to be added to the specified mipmap level when + * reading memory through the texture reference \p hTexRef. + * + * Note that this call has no effect if \p hTexRef is not bound to a mipmapped array. + * + * \param hTexRef - Texture reference + * \param bias - Mipmap level bias + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetMipmapLevelBias(CUtexref hTexRef, float bias); + +/** + * \brief Sets the mipmap min/max mipmap level clamps for a texture reference + * + * \deprecated + * + * Specifies the min/max mipmap level clamps, \p minMipmapLevelClamp and \p maxMipmapLevelClamp + * respectively, to be used when reading memory through the texture reference + * \p hTexRef. + * + * Note that this call has no effect if \p hTexRef is not bound to a mipmapped array. + * + * \param hTexRef - Texture reference + * \param minMipmapLevelClamp - Mipmap min level clamp + * \param maxMipmapLevelClamp - Mipmap max level clamp + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetMipmapLevelClamp(CUtexref hTexRef, float minMipmapLevelClamp, float maxMipmapLevelClamp); + +/** + * \brief Sets the maximum anisotropy for a texture reference + * + * \deprecated + * + * Specifies the maximum anisotropy \p maxAniso to be used when reading memory through + * the texture reference \p hTexRef. + * + * Note that this call has no effect if \p hTexRef is bound to linear memory. + * + * \param hTexRef - Texture reference + * \param maxAniso - Maximum anisotropy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetMaxAnisotropy(CUtexref hTexRef, unsigned int maxAniso); + +/** + * \brief Sets the border color for a texture reference + * + * \deprecated + * + * Specifies the value of the RGBA color via the \p pBorderColor to the texture reference + * \p hTexRef. The color value supports only float type and holds color components in + * the following sequence: + * pBorderColor[0] holds 'R' component + * pBorderColor[1] holds 'G' component + * pBorderColor[2] holds 'B' component + * pBorderColor[3] holds 'A' component + * + * Note that the color values can be set only when the Address mode is set to + * CU_TR_ADDRESS_MODE_BORDER using ::cuTexRefSetAddressMode. + * Applications using integer border color values have to "reinterpret_cast" their values to float. + * + * \param hTexRef - Texture reference + * \param pBorderColor - RGBA color + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddressMode, + * ::cuTexRefGetAddressMode, ::cuTexRefGetBorderColor + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetBorderColor(CUtexref hTexRef, float *pBorderColor); + +/** + * \brief Sets the flags for a texture reference + * + * \deprecated + * + * Specifies optional flags via \p Flags to specify the behavior of data + * returned through the texture reference \p hTexRef. The valid flags are: + * + * - ::CU_TRSF_READ_AS_INTEGER, which suppresses the default behavior of + * having the texture promote integer data to floating point data in the + * range [0, 1]. Note that texture with 32-bit integer format + * would not be promoted, regardless of whether or not this + * flag is specified; + * - ::CU_TRSF_NORMALIZED_COORDINATES, which suppresses the + * default behavior of having the texture coordinates range + * from [0, Dim) where Dim is the width or height of the CUDA + * array. Instead, the texture coordinates [0, 1.0) reference + * the entire breadth of the array dimension; + * - ::CU_TRSF_DISABLE_TRILINEAR_OPTIMIZATION, which disables any trilinear + * filtering optimizations. Trilinear optimizations improve texture filtering + * performance by allowing bilinear filtering on textures in scenarios where + * it can closely approximate the expected results. + * + * \param hTexRef - Texture reference + * \param Flags - Optional flags to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetFlags(CUtexref hTexRef, unsigned int Flags); + +/** + * \brief Gets the address associated with a texture reference + * + * \deprecated + * + * Returns in \p *pdptr the base address bound to the texture reference + * \p hTexRef, or returns ::CUDA_ERROR_INVALID_VALUE if the texture reference + * is not bound to any device memory range. + * + * \param pdptr - Returned device address + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetAddress(CUdeviceptr *pdptr, CUtexref hTexRef); + +/** + * \brief Gets the array bound to a texture reference + * + * \deprecated + * + * Returns in \p *phArray the CUDA array bound to the texture reference + * \p hTexRef, or returns ::CUDA_ERROR_INVALID_VALUE if the texture reference + * is not bound to any CUDA array. + * + * \param phArray - Returned array + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetArray(CUarray *phArray, CUtexref hTexRef); + +/** + * \brief Gets the mipmapped array bound to a texture reference + * + * \deprecated + * + * Returns in \p *phMipmappedArray the CUDA mipmapped array bound to the texture + * reference \p hTexRef, or returns ::CUDA_ERROR_INVALID_VALUE if the texture reference + * is not bound to any CUDA mipmapped array. + * + * \param phMipmappedArray - Returned mipmapped array + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetMipmappedArray(CUmipmappedArray *phMipmappedArray, CUtexref hTexRef); + +/** + * \brief Gets the addressing mode used by a texture reference + * + * \deprecated + * + * Returns in \p *pam the addressing mode corresponding to the + * dimension \p dim of the texture reference \p hTexRef. Currently, the only + * valid value for \p dim are 0 and 1. + * + * \param pam - Returned addressing mode + * \param hTexRef - Texture reference + * \param dim - Dimension + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetAddressMode(CUaddress_mode *pam, CUtexref hTexRef, int dim); + +/** + * \brief Gets the filter-mode used by a texture reference + * + * \deprecated + * + * Returns in \p *pfm the filtering mode of the texture reference + * \p hTexRef. + * + * \param pfm - Returned filtering mode + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetFilterMode(CUfilter_mode *pfm, CUtexref hTexRef); + +/** + * \brief Gets the format used by a texture reference + * + * \deprecated + * + * Returns in \p *pFormat and \p *pNumChannels the format and number + * of components of the CUDA array bound to the texture reference \p hTexRef. + * If \p pFormat or \p pNumChannels is NULL, it will be ignored. + * + * \param pFormat - Returned format + * \param pNumChannels - Returned number of components + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetFormat(CUarray_format *pFormat, int *pNumChannels, CUtexref hTexRef); + +/** + * \brief Gets the mipmap filtering mode for a texture reference + * + * \deprecated + * + * Returns the mipmap filtering mode in \p pfm that's used when reading memory through + * the texture reference \p hTexRef. + * + * \param pfm - Returned mipmap filtering mode + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetMipmapFilterMode(CUfilter_mode *pfm, CUtexref hTexRef); + +/** + * \brief Gets the mipmap level bias for a texture reference + * + * \deprecated + * + * Returns the mipmap level bias in \p pBias that's added to the specified mipmap + * level when reading memory through the texture reference \p hTexRef. + * + * \param pbias - Returned mipmap level bias + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetMipmapLevelBias(float *pbias, CUtexref hTexRef); + +/** + * \brief Gets the min/max mipmap level clamps for a texture reference + * + * \deprecated + * + * Returns the min/max mipmap level clamps in \p pminMipmapLevelClamp and \p pmaxMipmapLevelClamp + * that's used when reading memory through the texture reference \p hTexRef. + * + * \param pminMipmapLevelClamp - Returned mipmap min level clamp + * \param pmaxMipmapLevelClamp - Returned mipmap max level clamp + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetMipmapLevelClamp(float *pminMipmapLevelClamp, float *pmaxMipmapLevelClamp, CUtexref hTexRef); + +/** + * \brief Gets the maximum anisotropy for a texture reference + * + * \deprecated + * + * Returns the maximum anisotropy in \p pmaxAniso that's used when reading memory through + * the texture reference \p hTexRef. + * + * \param pmaxAniso - Returned maximum anisotropy + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetMaxAnisotropy(int *pmaxAniso, CUtexref hTexRef); + +/** + * \brief Gets the border color used by a texture reference + * + * \deprecated + * + * Returns in \p pBorderColor, values of the RGBA color used by + * the texture reference \p hTexRef. + * The color value is of type float and holds color components in + * the following sequence: + * pBorderColor[0] holds 'R' component + * pBorderColor[1] holds 'G' component + * pBorderColor[2] holds 'B' component + * pBorderColor[3] holds 'A' component + * + * \param hTexRef - Texture reference + * \param pBorderColor - Returned Type and Value of RGBA color + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddressMode, + * ::cuTexRefSetAddressMode, ::cuTexRefSetBorderColor + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetBorderColor(float *pBorderColor, CUtexref hTexRef); + +/** + * \brief Gets the flags used by a texture reference + * + * \deprecated + * + * Returns in \p *pFlags the flags of the texture reference \p hTexRef. + * + * \param pFlags - Returned flags + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetFlags(unsigned int *pFlags, CUtexref hTexRef); + +/** + * \brief Creates a texture reference + * + * \deprecated + * + * Creates a texture reference and returns its handle in \p *pTexRef. Once + * created, the application must call ::cuTexRefSetArray() or + * ::cuTexRefSetAddress() to associate the reference with allocated memory. + * Other texture reference functions are used to specify the format and + * interpretation (addressing, filtering, etc.) to be used when the memory is + * read through this texture reference. + * + * \param pTexRef - Returned texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefDestroy + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefCreate(CUtexref *pTexRef); + +/** + * \brief Destroys a texture reference + * + * \deprecated + * + * Destroys the texture reference specified by \p hTexRef. + * + * \param hTexRef - Texture reference to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefCreate + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefDestroy(CUtexref hTexRef); + +/** @} */ /* END CUDA_TEXREF_DEPRECATED */ + + +/** + * \defgroup CUDA_SURFREF_DEPRECATED Surface Reference Management [DEPRECATED] + * + * ___MANBRIEF___ surface reference management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the surface reference management functions of the + * low-level CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Sets the CUDA array for a surface reference. + * + * \deprecated + * + * Sets the CUDA array \p hArray to be read and written by the surface reference + * \p hSurfRef. Any previous CUDA array state associated with the surface + * reference is superseded by this function. \p Flags must be set to 0. + * The ::CUDA_ARRAY3D_SURFACE_LDST flag must have been set for the CUDA array. + * Any CUDA array previously bound to \p hSurfRef is unbound. + + * \param hSurfRef - Surface reference handle + * \param hArray - CUDA array handle + * \param Flags - set to 0 + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuModuleGetSurfRef, + * ::cuSurfRefGetArray + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuSurfRefSetArray(CUsurfref hSurfRef, CUarray hArray, unsigned int Flags); + +/** + * \brief Passes back the CUDA array bound to a surface reference. + * + * \deprecated + * + * Returns in \p *phArray the CUDA array bound to the surface reference + * \p hSurfRef, or returns ::CUDA_ERROR_INVALID_VALUE if the surface reference + * is not bound to any CUDA array. + + * \param phArray - Surface reference handle + * \param hSurfRef - Surface reference handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuModuleGetSurfRef, ::cuSurfRefSetArray + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuSurfRefGetArray(CUarray *phArray, CUsurfref hSurfRef); + +/** @} */ /* END CUDA_SURFREF_DEPRECATED */ + +/** + * \defgroup CUDA_TEXOBJECT Texture Object Management + * + * ___MANBRIEF___ texture object management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the texture object management functions of the + * low-level CUDA driver application programming interface. The texture + * object API is only supported on devices of compute capability 3.0 or higher. + * + * @{ + */ + +/** + * \brief Creates a texture object + * + * Creates a texture object and returns it in \p pTexObject. \p pResDesc describes + * the data to texture from. \p pTexDesc describes how the data should be sampled. + * \p pResViewDesc is an optional argument that specifies an alternate format for + * the data described by \p pResDesc, and also describes the subresource region + * to restrict access to when texturing. \p pResViewDesc can only be specified if + * the type of resource is a CUDA array or a CUDA mipmapped array not in a block + * compressed format. + * + * Texture objects are only supported on devices of compute capability 3.0 or higher. + * Additionally, a texture object is an opaque value, and, as such, should only be + * accessed through CUDA API calls. + * + * The ::CUDA_RESOURCE_DESC structure is defined as: + * \code + typedef struct CUDA_RESOURCE_DESC_st + { + CUresourcetype resType; + + union { + struct { + CUarray hArray; + } array; + struct { + CUmipmappedArray hMipmappedArray; + } mipmap; + struct { + CUdeviceptr devPtr; + CUarray_format format; + unsigned int numChannels; + size_t sizeInBytes; + } linear; + struct { + CUdeviceptr devPtr; + CUarray_format format; + unsigned int numChannels; + size_t width; + size_t height; + size_t pitchInBytes; + } pitch2D; + } res; + + unsigned int flags; + } CUDA_RESOURCE_DESC; + + * \endcode + * where: + * - ::CUDA_RESOURCE_DESC::resType specifies the type of resource to texture from. + * CUresourceType is defined as: + * \code + typedef enum CUresourcetype_enum { + CU_RESOURCE_TYPE_ARRAY = 0x00, + CU_RESOURCE_TYPE_MIPMAPPED_ARRAY = 0x01, + CU_RESOURCE_TYPE_LINEAR = 0x02, + CU_RESOURCE_TYPE_PITCH2D = 0x03 + } CUresourcetype; + * \endcode + * + * \par + * If ::CUDA_RESOURCE_DESC::resType is set to ::CU_RESOURCE_TYPE_ARRAY, ::CUDA_RESOURCE_DESC::res::array::hArray + * must be set to a valid CUDA array handle. + * + * \par + * If ::CUDA_RESOURCE_DESC::resType is set to ::CU_RESOURCE_TYPE_MIPMAPPED_ARRAY, ::CUDA_RESOURCE_DESC::res::mipmap::hMipmappedArray + * must be set to a valid CUDA mipmapped array handle. + * + * \par + * If ::CUDA_RESOURCE_DESC::resType is set to ::CU_RESOURCE_TYPE_LINEAR, ::CUDA_RESOURCE_DESC::res::linear::devPtr + * must be set to a valid device pointer, that is aligned to ::CU_DEVICE_ATTRIBUTE_TEXTURE_ALIGNMENT. + * ::CUDA_RESOURCE_DESC::res::linear::format and ::CUDA_RESOURCE_DESC::res::linear::numChannels + * describe the format of each component and the number of components per array element. ::CUDA_RESOURCE_DESC::res::linear::sizeInBytes + * specifies the size of the array in bytes. The total number of elements in the linear address range cannot exceed + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LINEAR_WIDTH. The number of elements is computed as (sizeInBytes / (sizeof(format) * numChannels)). + * + * \par + * If ::CUDA_RESOURCE_DESC::resType is set to ::CU_RESOURCE_TYPE_PITCH2D, ::CUDA_RESOURCE_DESC::res::pitch2D::devPtr + * must be set to a valid device pointer, that is aligned to ::CU_DEVICE_ATTRIBUTE_TEXTURE_ALIGNMENT. + * ::CUDA_RESOURCE_DESC::res::pitch2D::format and ::CUDA_RESOURCE_DESC::res::pitch2D::numChannels + * describe the format of each component and the number of components per array element. ::CUDA_RESOURCE_DESC::res::pitch2D::width + * and ::CUDA_RESOURCE_DESC::res::pitch2D::height specify the width and height of the array in elements, and cannot exceed + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_WIDTH and ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_HEIGHT respectively. + * ::CUDA_RESOURCE_DESC::res::pitch2D::pitchInBytes specifies the pitch between two rows in bytes and has to be aligned to + * ::CU_DEVICE_ATTRIBUTE_TEXTURE_PITCH_ALIGNMENT. Pitch cannot exceed ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_PITCH. + * + * - ::flags must be set to zero. + * + * + * The ::CUDA_TEXTURE_DESC struct is defined as + * \code + typedef struct CUDA_TEXTURE_DESC_st { + CUaddress_mode addressMode[3]; + CUfilter_mode filterMode; + unsigned int flags; + unsigned int maxAnisotropy; + CUfilter_mode mipmapFilterMode; + float mipmapLevelBias; + float minMipmapLevelClamp; + float maxMipmapLevelClamp; + } CUDA_TEXTURE_DESC; + * \endcode + * where + * - ::CUDA_TEXTURE_DESC::addressMode specifies the addressing mode for each dimension of the texture data. ::CUaddress_mode is defined as: + * \code + typedef enum CUaddress_mode_enum { + CU_TR_ADDRESS_MODE_WRAP = 0, + CU_TR_ADDRESS_MODE_CLAMP = 1, + CU_TR_ADDRESS_MODE_MIRROR = 2, + CU_TR_ADDRESS_MODE_BORDER = 3 + } CUaddress_mode; + * \endcode + * This is ignored if ::CUDA_RESOURCE_DESC::resType is ::CU_RESOURCE_TYPE_LINEAR. Also, if the flag, ::CU_TRSF_NORMALIZED_COORDINATES + * is not set, the only supported address mode is ::CU_TR_ADDRESS_MODE_CLAMP. + * + * - ::CUDA_TEXTURE_DESC::filterMode specifies the filtering mode to be used when fetching from the texture. CUfilter_mode is defined as: + * \code + typedef enum CUfilter_mode_enum { + CU_TR_FILTER_MODE_POINT = 0, + CU_TR_FILTER_MODE_LINEAR = 1 + } CUfilter_mode; + * \endcode + * This is ignored if ::CUDA_RESOURCE_DESC::resType is ::CU_RESOURCE_TYPE_LINEAR. + * + * - ::CUDA_TEXTURE_DESC::flags can be any combination of the following: + * - ::CU_TRSF_READ_AS_INTEGER, which suppresses the default behavior of + * having the texture promote integer data to floating point data in the + * range [0, 1]. Note that texture with 32-bit integer format would not be + * promoted, regardless of whether or not this flag is specified. + * - ::CU_TRSF_NORMALIZED_COORDINATES, which suppresses the default behavior + * of having the texture coordinates range from [0, Dim) where Dim is the + * width or height of the CUDA array. Instead, the texture coordinates + * [0, 1.0) reference the entire breadth of the array dimension; Note that + * for CUDA mipmapped arrays, this flag has to be set. + * - ::CU_TRSF_DISABLE_TRILINEAR_OPTIMIZATION, which disables any trilinear + * filtering optimizations. Trilinear optimizations improve texture filtering + * performance by allowing bilinear filtering on textures in scenarios where + * it can closely approximate the expected results. + * - ::CU_TRSF_SEAMLESS_CUBEMAP, which enables seamless cube map filtering. + * This flag can only be specified if the underlying resource is a CUDA array + * or a CUDA mipmapped array that was created with the flag ::CUDA_ARRAY3D_CUBEMAP. + * When seamless cube map filtering is enabled, texture address modes specified + * by ::CUDA_TEXTURE_DESC::addressMode are ignored. Instead, if the ::CUDA_TEXTURE_DESC::filterMode + * is set to ::CU_TR_FILTER_MODE_POINT the address mode ::CU_TR_ADDRESS_MODE_CLAMP + * will be applied for all dimensions. If the ::CUDA_TEXTURE_DESC::filterMode is + * set to ::CU_TR_FILTER_MODE_LINEAR seamless cube map filtering will be performed + * when sampling along the cube face borders. + * + * - ::CUDA_TEXTURE_DESC::maxAnisotropy specifies the maximum anisotropy ratio to be used when doing anisotropic filtering. This value will be + * clamped to the range [1,16]. + * + * - ::CUDA_TEXTURE_DESC::mipmapFilterMode specifies the filter mode when the calculated mipmap level lies between two defined mipmap levels. + * + * - ::CUDA_TEXTURE_DESC::mipmapLevelBias specifies the offset to be applied to the calculated mipmap level. + * + * - ::CUDA_TEXTURE_DESC::minMipmapLevelClamp specifies the lower end of the mipmap level range to clamp access to. + * + * - ::CUDA_TEXTURE_DESC::maxMipmapLevelClamp specifies the upper end of the mipmap level range to clamp access to. + * + * + * The ::CUDA_RESOURCE_VIEW_DESC struct is defined as + * \code + typedef struct CUDA_RESOURCE_VIEW_DESC_st + { + CUresourceViewFormat format; + size_t width; + size_t height; + size_t depth; + unsigned int firstMipmapLevel; + unsigned int lastMipmapLevel; + unsigned int firstLayer; + unsigned int lastLayer; + } CUDA_RESOURCE_VIEW_DESC; + * \endcode + * where: + * - ::CUDA_RESOURCE_VIEW_DESC::format specifies how the data contained in the CUDA array or CUDA mipmapped array should + * be interpreted. Note that this can incur a change in size of the texture data. If the resource view format is a block + * compressed format, then the underlying CUDA array or CUDA mipmapped array has to have a base of format ::CU_AD_FORMAT_UNSIGNED_INT32. + * with 2 or 4 channels, depending on the block compressed format. For ex., BC1 and BC4 require the underlying CUDA array to have + * a format of ::CU_AD_FORMAT_UNSIGNED_INT32 with 2 channels. The other BC formats require the underlying resource to have the same base + * format but with 4 channels. + * + * - ::CUDA_RESOURCE_VIEW_DESC::width specifies the new width of the texture data. If the resource view format is a block + * compressed format, this value has to be 4 times the original width of the resource. For non block compressed formats, + * this value has to be equal to that of the original resource. + * + * - ::CUDA_RESOURCE_VIEW_DESC::height specifies the new height of the texture data. If the resource view format is a block + * compressed format, this value has to be 4 times the original height of the resource. For non block compressed formats, + * this value has to be equal to that of the original resource. + * + * - ::CUDA_RESOURCE_VIEW_DESC::depth specifies the new depth of the texture data. This value has to be equal to that of the + * original resource. + * + * - ::CUDA_RESOURCE_VIEW_DESC::firstMipmapLevel specifies the most detailed mipmap level. This will be the new mipmap level zero. + * For non-mipmapped resources, this value has to be zero.::CUDA_TEXTURE_DESC::minMipmapLevelClamp and ::CUDA_TEXTURE_DESC::maxMipmapLevelClamp + * will be relative to this value. For ex., if the firstMipmapLevel is set to 2, and a minMipmapLevelClamp of 1.2 is specified, + * then the actual minimum mipmap level clamp will be 3.2. + * + * - ::CUDA_RESOURCE_VIEW_DESC::lastMipmapLevel specifies the least detailed mipmap level. For non-mipmapped resources, this value + * has to be zero. + * + * - ::CUDA_RESOURCE_VIEW_DESC::firstLayer specifies the first layer index for layered textures. This will be the new layer zero. + * For non-layered resources, this value has to be zero. + * + * - ::CUDA_RESOURCE_VIEW_DESC::lastLayer specifies the last layer index for layered textures. For non-layered resources, + * this value has to be zero. + * + * + * \param pTexObject - Texture object to create + * \param pResDesc - Resource descriptor + * \param pTexDesc - Texture descriptor + * \param pResViewDesc - Resource view descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexObjectDestroy, + * ::cudaCreateTextureObject + */ +CUresult CUDAAPI cuTexObjectCreate(CUtexObject *pTexObject, const CUDA_RESOURCE_DESC *pResDesc, const CUDA_TEXTURE_DESC *pTexDesc, const CUDA_RESOURCE_VIEW_DESC *pResViewDesc); + +/** + * \brief Destroys a texture object + * + * Destroys the texture object specified by \p texObject. + * + * \param texObject - Texture object to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexObjectCreate, + * ::cudaDestroyTextureObject + */ +CUresult CUDAAPI cuTexObjectDestroy(CUtexObject texObject); + +/** + * \brief Returns a texture object's resource descriptor + * + * Returns the resource descriptor for the texture object specified by \p texObject. + * + * \param pResDesc - Resource descriptor + * \param texObject - Texture object + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexObjectCreate, + * ::cudaGetTextureObjectResourceDesc, + */ +CUresult CUDAAPI cuTexObjectGetResourceDesc(CUDA_RESOURCE_DESC *pResDesc, CUtexObject texObject); + +/** + * \brief Returns a texture object's texture descriptor + * + * Returns the texture descriptor for the texture object specified by \p texObject. + * + * \param pTexDesc - Texture descriptor + * \param texObject - Texture object + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexObjectCreate, + * ::cudaGetTextureObjectTextureDesc + */ +CUresult CUDAAPI cuTexObjectGetTextureDesc(CUDA_TEXTURE_DESC *pTexDesc, CUtexObject texObject); + +/** + * \brief Returns a texture object's resource view descriptor + * + * Returns the resource view descriptor for the texture object specified by \p texObject. + * If no resource view was set for \p texObject, the ::CUDA_ERROR_INVALID_VALUE is returned. + * + * \param pResViewDesc - Resource view descriptor + * \param texObject - Texture object + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexObjectCreate, + * ::cudaGetTextureObjectResourceViewDesc + */ +CUresult CUDAAPI cuTexObjectGetResourceViewDesc(CUDA_RESOURCE_VIEW_DESC *pResViewDesc, CUtexObject texObject); + +/** @} */ /* END CUDA_TEXOBJECT */ + +/** + * \defgroup CUDA_SURFOBJECT Surface Object Management + * + * ___MANBRIEF___ surface object management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the surface object management functions of the + * low-level CUDA driver application programming interface. The surface + * object API is only supported on devices of compute capability 3.0 or higher. + * + * @{ + */ + +/** + * \brief Creates a surface object + * + * Creates a surface object and returns it in \p pSurfObject. \p pResDesc describes + * the data to perform surface load/stores on. ::CUDA_RESOURCE_DESC::resType must be + * ::CU_RESOURCE_TYPE_ARRAY and ::CUDA_RESOURCE_DESC::res::array::hArray + * must be set to a valid CUDA array handle. ::CUDA_RESOURCE_DESC::flags must be set to zero. + * + * Surface objects are only supported on devices of compute capability 3.0 or higher. + * Additionally, a surface object is an opaque value, and, as such, should only be + * accessed through CUDA API calls. + * + * \param pSurfObject - Surface object to create + * \param pResDesc - Resource descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuSurfObjectDestroy, + * ::cudaCreateSurfaceObject + */ +CUresult CUDAAPI cuSurfObjectCreate(CUsurfObject *pSurfObject, const CUDA_RESOURCE_DESC *pResDesc); + +/** + * \brief Destroys a surface object + * + * Destroys the surface object specified by \p surfObject. + * + * \param surfObject - Surface object to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuSurfObjectCreate, + * ::cudaDestroySurfaceObject + */ +CUresult CUDAAPI cuSurfObjectDestroy(CUsurfObject surfObject); + +/** + * \brief Returns a surface object's resource descriptor + * + * Returns the resource descriptor for the surface object specified by \p surfObject. + * + * \param pResDesc - Resource descriptor + * \param surfObject - Surface object + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuSurfObjectCreate, + * ::cudaGetSurfaceObjectResourceDesc + */ +CUresult CUDAAPI cuSurfObjectGetResourceDesc(CUDA_RESOURCE_DESC *pResDesc, CUsurfObject surfObject); + +/** @} */ /* END CUDA_SURFOBJECT */ + +/** + * \defgroup CUDA_TENSOR_MEMORY Tensor Map Object Managment + * + * ___MANBRIEF___ tensor map object management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the tensor map object management functions of the + * low-level CUDA driver application programming interface. The tensor + * core API is only supported on devices of compute capability 9.0 or higher. + * + * @{ + */ + +/** + * \brief Create a tensor map descriptor object representing tiled memory region + * + * Creates a descriptor for Tensor Memory Access (TMA) object specified + * by the parameters describing a tiled region and returns it in \p tensorMap. + * + * Tensor map objects are only supported on devices of compute capability 9.0 or higher. + * Additionally, a tensor map object is an opaque value, and, as such, should only be + * accessed through CUDA API calls. + * + * The parameters passed are bound to the following requirements: + * + * - \p tensorMap address must be aligned to 64 bytes. + * + * - \p tensorDataType has to be an enum from ::CUtensorMapDataType which is defined as: + * \code + typedef enum CUtensorMapDataType_enum { + CU_TENSOR_MAP_DATA_TYPE_UINT8 = 0, // 1 byte + CU_TENSOR_MAP_DATA_TYPE_UINT16, // 2 bytes + CU_TENSOR_MAP_DATA_TYPE_UINT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_INT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_UINT64, // 8 bytes + CU_TENSOR_MAP_DATA_TYPE_INT64, // 8 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT16, // 2 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT64, // 8 bytes + CU_TENSOR_MAP_DATA_TYPE_BFLOAT16, // 2 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT32_FTZ, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_TFLOAT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_TFLOAT32_FTZ // 4 bytes + } CUtensorMapDataType; + * \endcode + * + * - \p tensorRank must be non-zero and less than or equal to the maximum supported dimensionality of 5. If \p interleave is not + * ::CU_TENSOR_MAP_INTERLEAVE_NONE, then \p tensorRank must additionally be greater than or equal to 3. + * + * - \p globalAddress, which specifies the starting address of the memory region described, must be 32 byte aligned when \p interleave is + * ::CU_TENSOR_MAP_INTERLEAVE_32B and 16 byte aligned otherwise. + * + * - \p globalDim array, which specifies tensor size of each of the \p tensorRank dimensions, must be non-zero and less than or + * equal to 2^32. + * + * - \p globalStrides array, which specifies tensor stride of each of the lower \p tensorRank - 1 dimensions in bytes, must be a + * multiple of 16 and less than 2^40. Additionally, the stride must be a multiple of 32 when \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_32B. + * Each following dimension specified includes previous dimension stride: + * \code + globalStrides[0] = globalDim[0] * elementSizeInBytes(tensorDataType) + padding[0]; + for (i = 1; i < tensorRank - 1; i++) + globalStrides[i] = globalStrides[i – 1] * (globalDim[i] + padding[i]); + assert(globalStrides[i] >= globalDim[i]); + * \endcode + * + * - \p boxDim array, which specifies number of elements to be traversed along each of the \p tensorRank dimensions, must be non-zero + * and less than or equal to 256. + * When \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_NONE, { \p boxDim[0] * elementSizeInBytes( \p tensorDataType ) } must be a multiple + * of 16 bytes. + * + * - \p elementStrides array, which specifies the iteration step along each of the \p tensorRank dimensions, must be non-zero and less + * than or equal to 8. Note that when \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_NONE, the first element of this array is ignored since + * TMA doesn’t support the stride for dimension zero. + * When all elements of \p elementStrides array is one, \p boxDim specifies the number of elements to load. However, if the \p elementStrides[i] + * is not equal to one, then TMA loads ceil( \p boxDim[i] / \p elementStrides[i]) number of elements along i-th dimension. To load N elements along + * i-th dimension, \p boxDim[i] must be set to N * \p elementStrides[i]. + * + * - \p interleave specifies the interleaved layout of type ::CUtensorMapInterleave, which is defined as: + * \code + typedef enum CUtensorMapInterleave_enum { + CU_TENSOR_MAP_INTERLEAVE_NONE = 0, + CU_TENSOR_MAP_INTERLEAVE_16B, + CU_TENSOR_MAP_INTERLEAVE_32B + } CUtensorMapInterleave; + * \endcode + * TMA supports interleaved layouts like NC/8HWC8 where C8 utilizes 16 bytes in memory assuming 2 byte per channel or NC/16HWC16 where C16 + * uses 32 bytes. + * When \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_NONE and \p swizzle is not ::CU_TENSOR_MAP_SWIZZLE_NONE, the bounding box inner dimension + * (computed as \p boxDim[0] multiplied by element size derived from \p tensorDataType) must be less than or equal to the swizzle size. + * - CU_TENSOR_MAP_SWIZZLE_32B implies the bounding box inner dimension will be <= 32. + * - CU_TENSOR_MAP_SWIZZLE_64B implies the bounding box inner dimension will be <= 64. + * - CU_TENSOR_MAP_SWIZZLE_128B implies the bounding box inner dimension will be <= 128. + * + * - \p swizzle, which specifies the shared memory bank swizzling pattern, has to be of type ::CUtensorMapSwizzle which is defined as: + * \code + typedef enum CUtensorMapSwizzle_enum { + CU_TENSOR_MAP_SWIZZLE_NONE = 0, + CU_TENSOR_MAP_SWIZZLE_32B, + CU_TENSOR_MAP_SWIZZLE_64B, + CU_TENSOR_MAP_SWIZZLE_128B + } CUtensorMapSwizzle; + * \endcode + * Data are organized in a specific order in global memory; however, this may not match the order in which the application accesses data + * in shared memory. This difference in data organization may cause bank conflicts when shared memory is accessed. In order to avoid this + * problem, data can be loaded to shared memory with shuffling across shared memory banks. + * When \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_32B, \p swizzle must be ::CU_TENSOR_MAP_SWIZZLE_32B. + * Other interleave modes can have any swizzling pattern. + * + * - \p l2Promotion specifies L2 fetch size which indicates the byte granurality at which L2 requests is filled from DRAM. It must be of + * type ::CUtensorMapL2promotion, which is defined as: + * \code + typedef enum CUtensorMapL2promotion_enum { + CU_TENSOR_MAP_L2_PROMOTION_NONE = 0, + CU_TENSOR_MAP_L2_PROMOTION_L2_64B, + CU_TENSOR_MAP_L2_PROMOTION_L2_128B, + CU_TENSOR_MAP_L2_PROMOTION_L2_256B + } CUtensorMapL2promotion; + * \endcode + * + * - \p oobFill, which indicates whether zero or a special NaN constant should be used to fill out-of-bound elements, must be of type + * ::CUtensorMapFloatOOBfill which is defined as: + * \code + typedef enum CUtensorMapFloatOOBfill_enum { + CU_TENSOR_MAP_FLOAT_OOB_FILL_NONE = 0, + CU_TENSOR_MAP_FLOAT_OOB_FILL_NAN_REQUEST_ZERO_FMA + } CUtensorMapFloatOOBfill; + * \endcode + * Note that ::CU_TENSOR_MAP_FLOAT_OOB_FILL_NAN_REQUEST_ZERO_FMA can only be used when \p tensorDataType represents a floating-point data type. + * + * \param tensorMap - Tensor map object to create + * \param tensorDataType - Tensor data type + * \param tensorRank - Dimensionality of tensor + * \param globalAddress - Starting address of memory region described by tensor + * \param globalDim - Array containing tensor size (number of elements) along each of the \p tensorRank dimensions + * \param globalStrides - Array containing stride size (in bytes) along each of the \p tensorRank - 1 dimensions + * \param boxDim - Array containing traversal box size (number of elments) along each of the \p tensorRank dimensions. Specifies how many elements to be traversed along each tensor dimension. + * \param elementStrides - Array containing traversal stride in each of the \p tensorRank dimensions + * \param interleave - Type of interleaved layout the tensor addresses + * \param swizzle - Bank swizzling pattern inside shared memory + * \param l2Promotion - L2 promotion size + * \param oobFill - Indicate whether zero or special NaN constant must be used to fill out-of-bound elements + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTensorMapEncodeIm2col, + * ::cuTensorMapReplaceAddress + */ +CUresult CUDAAPI cuTensorMapEncodeTiled(CUtensorMap *tensorMap, CUtensorMapDataType tensorDataType, cuuint32_t tensorRank, void *globalAddress, const cuuint64_t *globalDim, const cuuint64_t *globalStrides, const cuuint32_t *boxDim, const cuuint32_t *elementStrides, CUtensorMapInterleave interleave, CUtensorMapSwizzle swizzle, CUtensorMapL2promotion l2Promotion, CUtensorMapFloatOOBfill oobFill); + + +/** + * \brief Create a tensor map descriptor object representing im2col memory region + * + * Creates a descriptor for Tensor Memory Access (TMA) object specified + * by the parameters describing a im2col memory layout and returns it in \p tensorMap. + * + * Tensor map objects are only supported on devices of compute capability 9.0 or higher. + * Additionally, a tensor map object is an opaque value, and, as such, should only be + * accessed through CUDA API calls. + * + * The parameters passed are bound to the following requirements: + * + * - \p tensorMap address must be aligned to 64 bytes. + * + * - \p tensorDataType has to be an enum from ::CUtensorMapDataType which is defined as: + * \code + typedef enum CUtensorMapDataType_enum { + CU_TENSOR_MAP_DATA_TYPE_UINT8 = 0, // 1 byte + CU_TENSOR_MAP_DATA_TYPE_UINT16, // 2 bytes + CU_TENSOR_MAP_DATA_TYPE_UINT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_INT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_UINT64, // 8 bytes + CU_TENSOR_MAP_DATA_TYPE_INT64, // 8 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT16, // 2 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT64, // 8 bytes + CU_TENSOR_MAP_DATA_TYPE_BFLOAT16, // 2 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT32_FTZ, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_TFLOAT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_TFLOAT32_FTZ // 4 bytes + } CUtensorMapDataType; + * \endcode + * + * - \p tensorRank, which specifies the number of tensor dimensions, must be 3, 4, or 5. + * + * - \p globalAddress, which specifies the starting address of the memory region described, must be 32 byte aligned when \p interleave is + * ::CU_TENSOR_MAP_INTERLEAVE_32B and 16 byte aligned otherwise. + * + * - \p globalDim array, which specifies tensor size of each of the \p tensorRank dimensions, must be non-zero and less than or + * equal to 2^32. + * + * - \p globalStrides array, which specifies tensor stride of each of the lower \p tensorRank - 1 dimensions in bytes, must be a + * multiple of 16 and less than 2^40. Additionally, the stride must be a multiple of 32 when \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_32B. + * Each following dimension specified includes previous dimension stride: + * \code + globalStrides[0] = globalDim[0] * elementSizeInBytes(tensorDataType) + padding[0]; + for (i = 1; i < tensorRank - 1; i++) + globalStrides[i] = globalStrides[i – 1] * (globalDim[i] + padding[i]); + assert(globalStrides[i] >= globalDim[i]); + * \endcode + * + * - \p pixelBoxLowerCorner array specifies the coordinate offsets {D, H, W} of the bounding box from top/left/front corner. The number of + * offsets and their precision depend on the tensor dimensionality: + * - When \p tensorRank is 3, one signed offset within range [-32768, 32767] is supported. + * - When \p tensorRank is 4, two signed offsets each within range [-128, 127] are supported. + * - When \p tensorRank is 5, three offsets each within range [-16, 15] are supported. + * + * - \p pixelBoxUpperCorner array specifies the coordinate offsets {D, H, W} of the bounding box from bottom/right/back corner. The number of + * offsets and their precision depend on the tensor dimensionality: + * - When \p tensorRank is 3, one signed offset within range [-32768, 32767] is supported. + * - When \p tensorRank is 4, two signed offsets each within range [-128, 127] are supported. + * - When \p tensorRank is 5, three offsets each within range [-16, 15] are supported. + * The bounding box specified by \p pixelBoxLowerCorner and \p pixelBoxUpperCorner must have non-zero area. + * + * - \p channelsPerPixel, which specifies the number of elements which must be accessed along C dimension, must be less than or equal to 256. + * + * - \p pixelsPerColumn, which specifies the number of elements that must be accessed along the {N, D, H, W} dimensions, must be less than or + * equal to 1024. + * + * - \p elementStrides array, which specifies the iteration step along each of the \p tensorRank dimensions, must be non-zero and less + * than or equal to 8. Note that when \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_NONE, the first element of this array is ignored since + * TMA doesn’t support the stride for dimension zero. + * When all elements of the \p elementStrides array are one, \p boxDim specifies the number of elements to load. However, if \p elementStrides[i] + * is not equal to one for some \p i, then TMA loads ceil( \p boxDim[i] / \p elementStrides[i]) number of elements along i-th dimension. + * To load N elements along i-th dimension, \p boxDim[i] must be set to N * \p elementStrides[i]. + * + * - \p interleave specifies the interleaved layout of type ::CUtensorMapInterleave, which is defined as: + * \code + typedef enum CUtensorMapInterleave_enum { + CU_TENSOR_MAP_INTERLEAVE_NONE = 0, + CU_TENSOR_MAP_INTERLEAVE_16B, + CU_TENSOR_MAP_INTERLEAVE_32B + } CUtensorMapInterleave; + * \endcode + * TMA supports interleaved layouts like NC/8HWC8 where C8 utilizes 16 bytes in memory assuming 2 byte per channel or NC/16HWC16 where C16 + * uses 32 bytes. + * When \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_NONE and \p swizzle is not ::CU_TENSOR_MAP_SWIZZLE_NONE, the bounding box inner dimension + * (computed as \p boxDim[0] multiplied by element size derived from \p tensorDataType) must be less than or equal to the swizzle size. + * - CU_TENSOR_MAP_SWIZZLE_32B implies the bounding box inner dimension will be <= 32. + * - CU_TENSOR_MAP_SWIZZLE_64B implies the bounding box inner dimension will be <= 64. + * - CU_TENSOR_MAP_SWIZZLE_128B implies the bounding box inner dimension will be <= 128. + * + * - \p swizzle, which specifies the shared memory bank swizzling pattern, has to be of type ::CUtensorMapSwizzle which is defined as: + * \code + typedef enum CUtensorMapSwizzle_enum { + CU_TENSOR_MAP_SWIZZLE_NONE = 0, + CU_TENSOR_MAP_SWIZZLE_32B, + CU_TENSOR_MAP_SWIZZLE_64B, + CU_TENSOR_MAP_SWIZZLE_128B + } CUtensorMapSwizzle; + * \endcode + * Data are organized in a specific order in global memory; however, this may not match the order in which the application accesses data + * in shared memory. This difference in data organization may cause bank conflicts when shared memory is accessed. In order to avoid this + * problem, data can be loaded to shared memory with shuffling across shared memory banks. + * When \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_32B, \p swizzle must be ::CU_TENSOR_MAP_SWIZZLE_32B. + * Other interleave modes can have any swizzling pattern. + * + * - \p l2Promotion specifies L2 fetch size which indicates the byte granularity at which L2 requests are filled from DRAM. It must be of + * type ::CUtensorMapL2promotion, which is defined as: + * \code + typedef enum CUtensorMapL2promotion_enum { + CU_TENSOR_MAP_L2_PROMOTION_NONE = 0, + CU_TENSOR_MAP_L2_PROMOTION_L2_64B, + CU_TENSOR_MAP_L2_PROMOTION_L2_128B, + CU_TENSOR_MAP_L2_PROMOTION_L2_256B + } CUtensorMapL2promotion; + * \endcode + * + * - \p oobFill, which indicates whether zero or a special NaN constant should be used to fill out-of-bound elements, must be of type + * ::CUtensorMapFloatOOBfill which is defined as: + * \code + typedef enum CUtensorMapFloatOOBfill_enum { + CU_TENSOR_MAP_FLOAT_OOB_FILL_NONE = 0, + CU_TENSOR_MAP_FLOAT_OOB_FILL_NAN_REQUEST_ZERO_FMA + } CUtensorMapFloatOOBfill; + * \endcode + * Note that ::CU_TENSOR_MAP_FLOAT_OOB_FILL_NAN_REQUEST_ZERO_FMA can only be used when \p tensorDataType represents a floating-point data type. + * + * \param tensorMap - Tensor map object to create + * \param tensorDataType - Tensor data type + * \param tensorRank - Dimensionality of tensor; must be at least 3 + * \param globalAddress - Starting address of memory region described by tensor + * \param globalDim - Array containing tensor size (number of elements) along each of the \p tensorRank dimensions + * \param globalStrides - Array containing stride size (in bytes) along each of the \p tensorRank - 1 dimensions + * \param pixelBoxLowerCorner - Array containing DHW dimensions of lower box corner + * \param pixelBoxUpperCorner - Array containing DHW dimensions of upper box corner + * \param channelsPerPixel - Number of channels per pixel + * \param pixelsPerColumn - Number of pixels per column + * \param elementStrides - Array containing traversal stride in each of the \p tensorRank dimensions + * \param interleave - Type of interleaved layout the tensor addresses + * \param swizzle - Bank swizzling pattern inside shared memory + * \param l2Promotion - L2 promotion size + * \param oobFill - Indicate whether zero or special NaN constant will be used to fill out-of-bound elements + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTensorMapEncodeTiled, + * ::cuTensorMapReplaceAddress + */ +CUresult CUDAAPI cuTensorMapEncodeIm2col(CUtensorMap *tensorMap, CUtensorMapDataType tensorDataType, cuuint32_t tensorRank, void *globalAddress, const cuuint64_t *globalDim, const cuuint64_t *globalStrides, const int *pixelBoxLowerCorner, const int *pixelBoxUpperCorner, cuuint32_t channelsPerPixel, cuuint32_t pixelsPerColumn, const cuuint32_t *elementStrides, CUtensorMapInterleave interleave, CUtensorMapSwizzle swizzle, CUtensorMapL2promotion l2Promotion, CUtensorMapFloatOOBfill oobFill); + +/** + * \brief Modify an existing tensor map descriptor with an updated global address + * + * Modifies the descriptor for Tensor Memory Access (TMA) object passed in \p tensorMap with + * an updated \p globalAddress. + * + * Tensor map objects are only supported on devices of compute capability 9.0 or higher. + * Additionally, a tensor map object is an opaque value, and, as such, should only be + * accessed through CUDA API calls. + * + * \param tensorMap - Tensor map object to modify + * \param globalAddress - Starting address of memory region described by tensor, must follow previous alignment requirements + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTensorMapEncodeTiled, + * ::cuTensorMapEncodeIm2col + */ +CUresult CUDAAPI cuTensorMapReplaceAddress(CUtensorMap *tensorMap, void *globalAddress); + +/** @} */ +/* END CUDA_TENSOR_MEMORY */ + +/** + * \defgroup CUDA_PEER_ACCESS Peer Context Memory Access + * + * ___MANBRIEF___ direct peer context memory access functions of the low-level + * CUDA driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the direct peer context memory access functions + * of the low-level CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Queries if a device may directly access a peer device's memory. + * + * Returns in \p *canAccessPeer a value of 1 if contexts on \p dev are capable of + * directly accessing memory from contexts on \p peerDev and 0 otherwise. + * If direct access of \p peerDev from \p dev is possible, then access may be + * enabled on two specific contexts by calling ::cuCtxEnablePeerAccess(). + * + * \param canAccessPeer - Returned access capability + * \param dev - Device from which allocations on \p peerDev are to + * be directly accessed. + * \param peerDev - Device on which the allocations to be directly accessed + * by \p dev reside. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuCtxEnablePeerAccess, + * ::cuCtxDisablePeerAccess, + * ::cudaDeviceCanAccessPeer + */ +CUresult CUDAAPI cuDeviceCanAccessPeer(int *canAccessPeer, CUdevice dev, CUdevice peerDev); + +/** + * \brief Enables direct access to memory allocations in a peer context. + * + * If both the current context and \p peerContext are on devices which support unified + * addressing (as may be queried using ::CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING) and same + * major compute capability, then on success all allocations from \p peerContext will + * immediately be accessible by the current context. See \ref CUDA_UNIFIED for additional + * details. + * + * Note that access granted by this call is unidirectional and that in order to access + * memory from the current context in \p peerContext, a separate symmetric call + * to ::cuCtxEnablePeerAccess() is required. + * + * Note that there are both device-wide and system-wide limitations per system + * configuration, as noted in the CUDA Programming Guide under the section + * "Peer-to-Peer Memory Access". + * + * Returns ::CUDA_ERROR_PEER_ACCESS_UNSUPPORTED if ::cuDeviceCanAccessPeer() indicates + * that the ::CUdevice of the current context cannot directly access memory + * from the ::CUdevice of \p peerContext. + * + * Returns ::CUDA_ERROR_PEER_ACCESS_ALREADY_ENABLED if direct access of + * \p peerContext from the current context has already been enabled. + * + * Returns ::CUDA_ERROR_TOO_MANY_PEERS if direct peer access is not possible + * because hardware resources required for peer access have been exhausted. + * + * Returns ::CUDA_ERROR_INVALID_CONTEXT if there is no current context, \p peerContext + * is not a valid context, or if the current context is \p peerContext. + * + * Returns ::CUDA_ERROR_INVALID_VALUE if \p Flags is not 0. + * + * \param peerContext - Peer context to enable direct access to from the current context + * \param Flags - Reserved for future use and must be set to 0 + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_PEER_ACCESS_ALREADY_ENABLED, + * ::CUDA_ERROR_TOO_MANY_PEERS, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_PEER_ACCESS_UNSUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuDeviceCanAccessPeer, + * ::cuCtxDisablePeerAccess, + * ::cudaDeviceEnablePeerAccess + */ +CUresult CUDAAPI cuCtxEnablePeerAccess(CUcontext peerContext, unsigned int Flags); + +/** + * \brief Disables direct access to memory allocations in a peer context and + * unregisters any registered allocations. + * + Returns ::CUDA_ERROR_PEER_ACCESS_NOT_ENABLED if direct peer access has + * not yet been enabled from \p peerContext to the current context. + * + * Returns ::CUDA_ERROR_INVALID_CONTEXT if there is no current context, or if + * \p peerContext is not a valid context. + * + * \param peerContext - Peer context to disable direct access to + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_PEER_ACCESS_NOT_ENABLED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * \notefnerr + * + * \sa + * ::cuDeviceCanAccessPeer, + * ::cuCtxEnablePeerAccess, + * ::cudaDeviceDisablePeerAccess + */ +CUresult CUDAAPI cuCtxDisablePeerAccess(CUcontext peerContext); + +/** + * \brief Queries attributes of the link between two devices. + * + * Returns in \p *value the value of the requested attribute \p attrib of the + * link between \p srcDevice and \p dstDevice. The supported attributes are: + * - ::CU_DEVICE_P2P_ATTRIBUTE_PERFORMANCE_RANK: A relative value indicating the + * performance of the link between two devices. + * - ::CU_DEVICE_P2P_ATTRIBUTE_ACCESS_SUPPORTED P2P: 1 if P2P Access is enable. + * - ::CU_DEVICE_P2P_ATTRIBUTE_NATIVE_ATOMIC_SUPPORTED: 1 if Atomic operations over + * the link are supported. + * - ::CU_DEVICE_P2P_ATTRIBUTE_CUDA_ARRAY_ACCESS_SUPPORTED: 1 if cudaArray can + * be accessed over the link. + * + * Returns ::CUDA_ERROR_INVALID_DEVICE if \p srcDevice or \p dstDevice are not valid + * or if they represent the same device. + * + * Returns ::CUDA_ERROR_INVALID_VALUE if \p attrib is not valid or if \p value is + * a null pointer. + * + * \param value - Returned value of the requested attribute + * \param attrib - The requested attribute of the link between \p srcDevice and \p dstDevice. + * \param srcDevice - The source device of the target link. + * \param dstDevice - The destination device of the target link. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuCtxEnablePeerAccess, + * ::cuCtxDisablePeerAccess, + * ::cuDeviceCanAccessPeer, + * ::cudaDeviceGetP2PAttribute + */ +CUresult CUDAAPI cuDeviceGetP2PAttribute(int* value, CUdevice_P2PAttribute attrib, CUdevice srcDevice, CUdevice dstDevice); + +/** @} */ /* END CUDA_PEER_ACCESS */ + +/** + * \defgroup CUDA_GRAPHICS Graphics Interoperability + * + * ___MANBRIEF___ graphics interoperability functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the graphics interoperability functions of the + * low-level CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Unregisters a graphics resource for access by CUDA + * + * Unregisters the graphics resource \p resource so it is not accessible by + * CUDA unless registered again. + * + * If \p resource is invalid then ::CUDA_ERROR_INVALID_HANDLE is + * returned. + * + * \param resource - Resource to unregister + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cuGraphicsD3D9RegisterResource, + * ::cuGraphicsD3D10RegisterResource, + * ::cuGraphicsD3D11RegisterResource, + * ::cuGraphicsGLRegisterBuffer, + * ::cuGraphicsGLRegisterImage, + * ::cudaGraphicsUnregisterResource + */ +CUresult CUDAAPI cuGraphicsUnregisterResource(CUgraphicsResource resource); + +/** + * \brief Get an array through which to access a subresource of a mapped graphics resource. + * + * Returns in \p *pArray an array through which the subresource of the mapped + * graphics resource \p resource which corresponds to array index \p arrayIndex + * and mipmap level \p mipLevel may be accessed. The value set in \p *pArray may + * change every time that \p resource is mapped. + * + * If \p resource is not a texture then it cannot be accessed via an array and + * ::CUDA_ERROR_NOT_MAPPED_AS_ARRAY is returned. + * If \p arrayIndex is not a valid array index for \p resource then + * ::CUDA_ERROR_INVALID_VALUE is returned. + * If \p mipLevel is not a valid mipmap level for \p resource then + * ::CUDA_ERROR_INVALID_VALUE is returned. + * If \p resource is not mapped then ::CUDA_ERROR_NOT_MAPPED is returned. + * + * \param pArray - Returned array through which a subresource of \p resource may be accessed + * \param resource - Mapped resource to access + * \param arrayIndex - Array index for array textures or cubemap face + * index as defined by ::CUarray_cubemap_face for + * cubemap textures for the subresource to access + * \param mipLevel - Mipmap level for the subresource to access + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_MAPPED, + * ::CUDA_ERROR_NOT_MAPPED_AS_ARRAY + * \notefnerr + * + * \sa + * ::cuGraphicsResourceGetMappedPointer, + * ::cudaGraphicsSubResourceGetMappedArray + */ +CUresult CUDAAPI cuGraphicsSubResourceGetMappedArray(CUarray *pArray, CUgraphicsResource resource, unsigned int arrayIndex, unsigned int mipLevel); + +/** + * \brief Get a mipmapped array through which to access a mapped graphics resource. + * + * Returns in \p *pMipmappedArray a mipmapped array through which the mapped graphics + * resource \p resource. The value set in \p *pMipmappedArray may change every time + * that \p resource is mapped. + * + * If \p resource is not a texture then it cannot be accessed via a mipmapped array and + * ::CUDA_ERROR_NOT_MAPPED_AS_ARRAY is returned. + * If \p resource is not mapped then ::CUDA_ERROR_NOT_MAPPED is returned. + * + * \param pMipmappedArray - Returned mipmapped array through which \p resource may be accessed + * \param resource - Mapped resource to access + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_MAPPED, + * ::CUDA_ERROR_NOT_MAPPED_AS_ARRAY + * \notefnerr + * + * \sa + * ::cuGraphicsResourceGetMappedPointer, + * ::cudaGraphicsResourceGetMappedMipmappedArray + */ +CUresult CUDAAPI cuGraphicsResourceGetMappedMipmappedArray(CUmipmappedArray *pMipmappedArray, CUgraphicsResource resource); + +/** + * \brief Get a device pointer through which to access a mapped graphics resource. + * + * Returns in \p *pDevPtr a pointer through which the mapped graphics resource + * \p resource may be accessed. + * Returns in \p pSize the size of the memory in bytes which may be accessed from that pointer. + * The value set in \p pPointer may change every time that \p resource is mapped. + * + * If \p resource is not a buffer then it cannot be accessed via a pointer and + * ::CUDA_ERROR_NOT_MAPPED_AS_POINTER is returned. + * If \p resource is not mapped then ::CUDA_ERROR_NOT_MAPPED is returned. + * * + * \param pDevPtr - Returned pointer through which \p resource may be accessed + * \param pSize - Returned size of the buffer accessible starting at \p *pPointer + * \param resource - Mapped resource to access + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_MAPPED, + * ::CUDA_ERROR_NOT_MAPPED_AS_POINTER + * \notefnerr + * + * \sa + * ::cuGraphicsMapResources, + * ::cuGraphicsSubResourceGetMappedArray, + * ::cudaGraphicsResourceGetMappedPointer + */ +CUresult CUDAAPI cuGraphicsResourceGetMappedPointer(CUdeviceptr *pDevPtr, size_t *pSize, CUgraphicsResource resource); + +/** + * \brief Set usage flags for mapping a graphics resource + * + * Set \p flags for mapping the graphics resource \p resource. + * + * Changes to \p flags will take effect the next time \p resource is mapped. + * The \p flags argument may be any of the following: + + * - ::CU_GRAPHICS_MAP_RESOURCE_FLAGS_NONE: Specifies no hints about how this + * resource will be used. It is therefore assumed that this resource will be + * read from and written to by CUDA kernels. This is the default value. + * - ::CU_GRAPHICS_MAP_RESOURCE_FLAGS_READONLY: Specifies that CUDA kernels which + * access this resource will not write to this resource. + * - ::CU_GRAPHICS_MAP_RESOURCE_FLAGS_WRITEDISCARD: Specifies that CUDA kernels + * which access this resource will not read from this resource and will + * write over the entire contents of the resource, so none of the data + * previously stored in the resource will be preserved. + * + * If \p resource is presently mapped for access by CUDA then + * ::CUDA_ERROR_ALREADY_MAPPED is returned. + * If \p flags is not one of the above values then ::CUDA_ERROR_INVALID_VALUE is returned. + * + * \param resource - Registered resource to set flags for + * \param flags - Parameters for resource mapping + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_ALREADY_MAPPED + * \notefnerr + * + * \sa + * ::cuGraphicsMapResources, + * ::cudaGraphicsResourceSetMapFlags + */ +CUresult CUDAAPI cuGraphicsResourceSetMapFlags(CUgraphicsResource resource, unsigned int flags); + +/** + * \brief Map graphics resources for access by CUDA + * + * Maps the \p count graphics resources in \p resources for access by CUDA. + * + * The resources in \p resources may be accessed by CUDA until they + * are unmapped. The graphics API from which \p resources were registered + * should not access any resources while they are mapped by CUDA. If an + * application does so, the results are undefined. + * + * This function provides the synchronization guarantee that any graphics calls + * issued before ::cuGraphicsMapResources() will complete before any subsequent CUDA + * work issued in \p stream begins. + * + * If \p resources includes any duplicate entries then ::CUDA_ERROR_INVALID_HANDLE is returned. + * If any of \p resources are presently mapped for access by CUDA then ::CUDA_ERROR_ALREADY_MAPPED is returned. + * + * \param count - Number of resources to map + * \param resources - Resources to map for CUDA usage + * \param hStream - Stream with which to synchronize + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_ALREADY_MAPPED, + * ::CUDA_ERROR_UNKNOWN + * \note_null_stream + * \notefnerr + * + * \sa + * ::cuGraphicsResourceGetMappedPointer, + * ::cuGraphicsSubResourceGetMappedArray, + * ::cuGraphicsUnmapResources, + * ::cudaGraphicsMapResources + */ +CUresult CUDAAPI cuGraphicsMapResources(unsigned int count, CUgraphicsResource *resources, CUstream hStream); + +/** + * \brief Unmap graphics resources. + * + * Unmaps the \p count graphics resources in \p resources. + * + * Once unmapped, the resources in \p resources may not be accessed by CUDA + * until they are mapped again. + * + * This function provides the synchronization guarantee that any CUDA work issued + * in \p stream before ::cuGraphicsUnmapResources() will complete before any + * subsequently issued graphics work begins. + * + * + * If \p resources includes any duplicate entries then ::CUDA_ERROR_INVALID_HANDLE is returned. + * If any of \p resources are not presently mapped for access by CUDA then ::CUDA_ERROR_NOT_MAPPED is returned. + * + * \param count - Number of resources to unmap + * \param resources - Resources to unmap + * \param hStream - Stream with which to synchronize + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_MAPPED, + * ::CUDA_ERROR_UNKNOWN + * \note_null_stream + * \notefnerr + * + * \sa + * ::cuGraphicsMapResources, + * ::cudaGraphicsUnmapResources + */ +CUresult CUDAAPI cuGraphicsUnmapResources(unsigned int count, CUgraphicsResource *resources, CUstream hStream); + +/** @} */ /* END CUDA_GRAPHICS */ + +/** + * \defgroup CUDA_DRIVER_ENTRY_POINT Driver Entry Point Access + * + * ___MANBRIEF___ driver entry point access functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the driver entry point access functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns the requested driver API function pointer + * + * Returns in \p **pfn the address of the CUDA driver function for the requested + * CUDA version and flags. + * + * The CUDA version is specified as (1000 * major + 10 * minor), so CUDA 11.2 + * should be specified as 11020. For a requested driver symbol, if the specified + * CUDA version is greater than or equal to the CUDA version in which the driver symbol + * was introduced, this API will return the function pointer to the corresponding + * versioned function. + * + * The pointer returned by the API should be cast to a function pointer matching the + * requested driver function's definition in the API header file. The function pointer + * typedef can be picked up from the corresponding typedefs header file. For example, + * cudaTypedefs.h consists of function pointer typedefs for driver APIs defined in cuda.h. + * + * The API will return ::CUDA_SUCCESS and set the returned \p pfn to NULL if the + * requested driver function is not supported on the platform, no ABI + * compatible driver function exists for the specified \p cudaVersion or if the + * driver symbol is invalid. + * + * It will also set the optional \p symbolStatus to one of the values in + * ::CUdriverProcAddressQueryResult with the following meanings: + * - ::CU_GET_PROC_ADDRESS_SUCCESS - The requested symbol was succesfully found based + * on input arguments and \p pfn is valid + * - ::CU_GET_PROC_ADDRESS_SYMBOL_NOT_FOUND - The requested symbol was not found + * - ::CU_GET_PROC_ADDRESS_VERSION_NOT_SUFFICIENT - The requested symbol was found but is + * not supported by cudaVersion specified + * + * The requested flags can be: + * - ::CU_GET_PROC_ADDRESS_DEFAULT: This is the default mode. This is equivalent to + * ::CU_GET_PROC_ADDRESS_PER_THREAD_DEFAULT_STREAM if the code is compiled with + * --default-stream per-thread compilation flag or the macro CUDA_API_PER_THREAD_DEFAULT_STREAM + * is defined; ::CU_GET_PROC_ADDRESS_LEGACY_STREAM otherwise. + * - ::CU_GET_PROC_ADDRESS_LEGACY_STREAM: This will enable the search for all driver symbols + * that match the requested driver symbol name except the corresponding per-thread versions. + * - ::CU_GET_PROC_ADDRESS_PER_THREAD_DEFAULT_STREAM: This will enable the search for all + * driver symbols that match the requested driver symbol name including the per-thread + * versions. If a per-thread version is not found, the API will return the legacy version + * of the driver function. + * + * \param symbol - The base name of the driver API function to look for. As an example, + * for the driver API ::cuMemAlloc_v2, \p symbol would be cuMemAlloc and + * \p cudaVersion would be the ABI compatible CUDA version for the _v2 variant. + * \param pfn - Location to return the function pointer to the requested driver function + * \param cudaVersion - The CUDA version to look for the requested driver symbol + * \param flags - Flags to specify search options. + * \param symbolStatus - Optional location to store the status of the search for + * \p symbol based on \p cudaVersion. See ::CUdriverProcAddressQueryResult + * for possible values. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_version_mixing + * + * \sa + * ::cudaGetDriverEntryPoint + */ +CUresult CUDAAPI cuGetProcAddress(const char *symbol, void **pfn, int cudaVersion, cuuint64_t flags, CUdriverProcAddressQueryResult *symbolStatus); + +/** @} */ /* END CUDA_DRIVER_ENTRY_POINT */ + +/** + * \defgroup CUDA_COREDUMP Coredump Attributes Control API + * + * ___MANBRIEF___ coredump attribute control functions for the low-level CUDA API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the coredump attribute control functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * Flags for choosing a coredump attribute to get/set + */ +typedef enum CUcoredumpSettings_enum { + CU_COREDUMP_ENABLE_ON_EXCEPTION = 1, + CU_COREDUMP_TRIGGER_HOST, + CU_COREDUMP_LIGHTWEIGHT, + CU_COREDUMP_ENABLE_USER_TRIGGER, + CU_COREDUMP_FILE, + CU_COREDUMP_PIPE, + CU_COREDUMP_GENERATION_FLAGS, + CU_COREDUMP_MAX +} CUcoredumpSettings; + +/** + * Flags for controlling coredump contents + */ +typedef enum CUCoredumpGenerationFlags { + CU_COREDUMP_DEFAULT_FLAGS = 0, + CU_COREDUMP_SKIP_NONRELOCATED_ELF_IMAGES = (1 << 0), + CU_COREDUMP_SKIP_GLOBAL_MEMORY = (1 << 1), + CU_COREDUMP_SKIP_SHARED_MEMORY = (1 << 2), + CU_COREDUMP_SKIP_LOCAL_MEMORY = (1 << 3), + CU_COREDUMP_SKIP_ABORT = (1 << 4), + CU_COREDUMP_SKIP_CONSTBANK_MEMORY = (1 << 5), + + CU_COREDUMP_LIGHTWEIGHT_FLAGS = CU_COREDUMP_SKIP_NONRELOCATED_ELF_IMAGES + | CU_COREDUMP_SKIP_GLOBAL_MEMORY + | CU_COREDUMP_SKIP_SHARED_MEMORY + | CU_COREDUMP_SKIP_LOCAL_MEMORY + | CU_COREDUMP_SKIP_CONSTBANK_MEMORY +} CUCoredumpGenerationFlags; + +/** + * \brief Allows caller to fetch a coredump attribute value for the current context + * + * Returns in \p *value the requested value specified by \p attrib. It is up to the caller + * to ensure that the data type and size of \p *value matches the request. + * + * If the caller calls this function with \p *value equal to NULL, the size of the memory + * region (in bytes) expected for \p attrib will be placed in \p size. + * + * The supported attributes are: + * - ::CU_COREDUMP_ENABLE_ON_EXCEPTION: Bool where ::true means that GPU exceptions from + * this context will create a coredump at the location specified by ::CU_COREDUMP_FILE. + * The default value is ::false unless set to ::true globally or locally, or the + * CU_CTX_USER_COREDUMP_ENABLE flag was set during context creation. + * - ::CU_COREDUMP_TRIGGER_HOST: Bool where ::true means that the host CPU will + * also create a coredump. The default value is ::true unless set to ::false globally or + * or locally. This value is deprecated as of CUDA 12.5 - raise the ::CU_COREDUMP_SKIP_ABORT + * flag to disable host device abort() if needed. + * - ::CU_COREDUMP_LIGHTWEIGHT: Bool where ::true means that any resulting coredumps + * will not have a dump of GPU memory or non-reloc ELF images. The default value is + * ::false unless set to ::true globally or locally. This attribute is deprecated as + * of CUDA 12.5, please use ::CU_COREDUMP_GENERATION_FLAGS instead. + * - ::CU_COREDUMP_ENABLE_USER_TRIGGER: Bool where ::true means that a coredump can be + * created by writing to the system pipe specified by ::CU_COREDUMP_PIPE. The default + * value is ::false unless set to ::true globally or locally. + * - ::CU_COREDUMP_FILE: String of up to 1023 characters that defines the location where + * any coredumps generated by this context will be written. The default value is + * ::core.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine running + * the CUDA applications and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_PIPE: String of up to 1023 characters that defines the name of the pipe + * that will be monitored if user-triggered coredumps are enabled. The default value is + * ::corepipe.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine running + * the CUDA application and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_GENERATION_FLAGS: An integer with values to allow granular control the data + * contained in a coredump specified as a bitwise OR combination of the following values: + * + ::CU_COREDUMP_DEFAULT_FLAGS - if set by itself, coredump generation returns to its + * default settings of including all memory regions that it is able to access + * + ::CU_COREDUMP_SKIP_NONRELOCATED_ELF_IMAGES - Coredump will not include the data from + * CUDA source modules that are not relocated at runtime. + * + ::CU_COREDUMP_SKIP_GLOBAL_MEMORY - Coredump will not include device-side global data + * that does not belong to any context. + * + ::CU_COREDUMP_SKIP_SHARED_MEMORY - Coredump will not include grid-scale shared memory + * for the warp that the dumped kernel belonged to. + * + ::CU_COREDUMP_SKIP_LOCAL_MEMORY - Coredump will not include local memory from the kernel. + * + ::CU_COREDUMP_LIGHTWEIGHT_FLAGS - Enables all of the above options. Equiavlent to setting + * the ::CU_COREDUMP_LIGHTWEIGHT attribute to ::true. + * + ::CU_COREDUMP_SKIP_ABORT - If set, GPU exceptions will not raise an abort() in the host CPU + * process. Same functional goal as ::CU_COREDUMP_TRIGGER_HOST but better reflects the default + * behavior. + * + * \param attrib - The enum defining which value to fetch. + * \param value - void* containing the requested data. + * \param size - The size of the memory region \p value points to. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * + * \sa + * ::cuCoredumpGetAttributeGlobal, + * ::cuCoredumpSetAttribute, + * ::cuCoredumpSetAttributeGlobal + */ +CUresult CUDAAPI cuCoredumpGetAttribute(CUcoredumpSettings attrib, void* value, size_t *size); + +/** + * \brief Allows caller to fetch a coredump attribute value for the entire application + * + * Returns in \p *value the requested value specified by \p attrib. It is up to the caller + * to ensure that the data type and size of \p *value matches the request. + * + * If the caller calls this function with \p *value equal to NULL, the size of the memory + * region (in bytes) expected for \p attrib will be placed in \p size. + * + * The supported attributes are: + * - ::CU_COREDUMP_ENABLE_ON_EXCEPTION: Bool where ::true means that GPU exceptions from + * this context will create a coredump at the location specified by ::CU_COREDUMP_FILE. + * The default value is ::false. + * - ::CU_COREDUMP_TRIGGER_HOST: Bool where ::true means that the host CPU will + * also create a coredump. The default value is ::true unless set to ::false globally or + * or locally. This value is deprecated as of CUDA 12.5 - raise the ::CU_COREDUMP_SKIP_ABORT + * flag to disable host device abort() if needed. + * - ::CU_COREDUMP_LIGHTWEIGHT: Bool where ::true means that any resulting coredumps + * will not have a dump of GPU memory or non-reloc ELF images. The default value is + * ::false. This attribute is deprecated as of CUDA 12.5, please use ::CU_COREDUMP_GENERATION_FLAGS + * instead. + * - ::CU_COREDUMP_ENABLE_USER_TRIGGER: Bool where ::true means that a coredump can be + * created by writing to the system pipe specified by ::CU_COREDUMP_PIPE. The default + * value is ::false. + * - ::CU_COREDUMP_FILE: String of up to 1023 characters that defines the location where + * any coredumps generated by this context will be written. The default value is + * ::core.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine running + * the CUDA applications and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_PIPE: String of up to 1023 characters that defines the name of the pipe + * that will be monitored if user-triggered coredumps are enabled. The default value is + * ::corepipe.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine running + * the CUDA application and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_GENERATION_FLAGS: An integer with values to allow granular control the data + * contained in a coredump specified as a bitwise OR combination of the following values: + * + ::CU_COREDUMP_DEFAULT_FLAGS - if set by itself, coredump generation returns to its + * default settings of including all memory regions that it is able to access + * + ::CU_COREDUMP_SKIP_NONRELOCATED_ELF_IMAGES - Coredump will not include the data from + * CUDA source modules that are not relocated at runtime. + * + ::CU_COREDUMP_SKIP_GLOBAL_MEMORY - Coredump will not include device-side global data + * that does not belong to any context. + * + ::CU_COREDUMP_SKIP_SHARED_MEMORY - Coredump will not include grid-scale shared memory + * for the warp that the dumped kernel belonged to. + * + ::CU_COREDUMP_SKIP_LOCAL_MEMORY - Coredump will not include local memory from the kernel. + * + ::CU_COREDUMP_LIGHTWEIGHT_FLAGS - Enables all of the above options. Equiavlent to setting + * the ::CU_COREDUMP_LIGHTWEIGHT attribute to ::true. + * + ::CU_COREDUMP_SKIP_ABORT - If set, GPU exceptions will not raise an abort() in the host CPU + * process. Same functional goal as ::CU_COREDUMP_TRIGGER_HOST but better reflects the default + * behavior. + * + * \param attrib - The enum defining which value to fetch. + * \param value - void* containing the requested data. + * \param size - The size of the memory region \p value points to. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuCoredumpGetAttribute, + * ::cuCoredumpSetAttribute, + * ::cuCoredumpSetAttributeGlobal + */ +CUresult CUDAAPI cuCoredumpGetAttributeGlobal(CUcoredumpSettings attrib, void *value, size_t *size); + +/** + * \brief Allows caller to set a coredump attribute value for the current context + * + * This function should be considered an alternate interface to the CUDA-GDB environment + * variables defined in this document: https://docs.nvidia.com/cuda/cuda-gdb/index.html#gpu-coredump + * + * An important design decision to note is that any coredump environment variable values + * set before CUDA initializes will take permanent precedence over any values set with this + * function. This decision was made to ensure no change in behavior for any users that + * may be currently using these variables to get coredumps. + * + * \p *value shall contain the requested value specified by \p set. It is up to the caller + * to ensure that the data type and size of \p *value matches the request. + * + * If the caller calls this function with \p *value equal to NULL, the size of the memory + * region (in bytes) expected for \p set will be placed in \p size. + * + * /note This function will return ::CUDA_ERROR_NOT_SUPPORTED if the caller attempts to set + * ::CU_COREDUMP_ENABLE_ON_EXCEPTION on a GPU of with Compute Capability < 6.0. ::cuCoredumpSetAttributeGlobal + * works on those platforms as an alternative. + * + * /note ::CU_COREDUMP_ENABLE_USER_TRIGGER and ::CU_COREDUMP_PIPE cannot be set on a per-context basis. + * + * The supported attributes are: + * - ::CU_COREDUMP_ENABLE_ON_EXCEPTION: Bool where ::true means that GPU exceptions from + * this context will create a coredump at the location specified by ::CU_COREDUMP_FILE. + * The default value is ::false. + * - ::CU_COREDUMP_TRIGGER_HOST: Bool where ::true means that the host CPU will + * also create a coredump. The default value is ::true unless set to ::false globally or + * or locally. This value is deprecated as of CUDA 12.5 - raise the ::CU_COREDUMP_SKIP_ABORT + * flag to disable host device abort() if needed. + * - ::CU_COREDUMP_LIGHTWEIGHT: Bool where ::true means that any resulting coredumps + * will not have a dump of GPU memory or non-reloc ELF images. The default value is + * ::false. This attribute is deprecated as of CUDA 12.5, please use ::CU_COREDUMP_GENERATION_FLAGS + * instead. + * - ::CU_COREDUMP_FILE: String of up to 1023 characters that defines the location where + * any coredumps generated by this context will be written. The default value is + * ::core.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine running + * the CUDA applications and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_GENERATION_FLAGS: An integer with values to allow granular control the data + * contained in a coredump specified as a bitwise OR combination of the following values: + * + ::CU_COREDUMP_DEFAULT_FLAGS - if set by itself, coredump generation returns to its + * default settings of including all memory regions that it is able to access + * + ::CU_COREDUMP_SKIP_NONRELOCATED_ELF_IMAGES - Coredump will not include the data from + * CUDA source modules that are not relocated at runtime. + * + ::CU_COREDUMP_SKIP_GLOBAL_MEMORY - Coredump will not include device-side global data + * that does not belong to any context. + * + ::CU_COREDUMP_SKIP_SHARED_MEMORY - Coredump will not include grid-scale shared memory + * for the warp that the dumped kernel belonged to. + * + ::CU_COREDUMP_SKIP_LOCAL_MEMORY - Coredump will not include local memory from the kernel. + * + ::CU_COREDUMP_LIGHTWEIGHT_FLAGS - Enables all of the above options. Equiavlent to setting + * the ::CU_COREDUMP_LIGHTWEIGHT attribute to ::true. + * + ::CU_COREDUMP_SKIP_ABORT - If set, GPU exceptions will not raise an abort() in the host CPU + * process. Same functional goal as ::CU_COREDUMP_TRIGGER_HOST but better reflects the default + * behavior. + * + * \param attrib - The enum defining which value to set. + * \param value - void* containing the requested data. + * \param size - The size of the memory region \p value points to. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED, + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa + * ::cuCoredumpGetAttributeGlobal, + * ::cuCoredumpGetAttribute, + * ::cuCoredumpSetAttributeGlobal + */ +CUresult CUDAAPI cuCoredumpSetAttribute(CUcoredumpSettings attrib, void* value, size_t *size); + +/** + * \brief Allows caller to set a coredump attribute value globally + * + * This function should be considered an alternate interface to the CUDA-GDB environment + * variables defined in this document: https://docs.nvidia.com/cuda/cuda-gdb/index.html#gpu-coredump + * + * An important design decision to note is that any coredump environment variable values + * set before CUDA initializes will take permanent precedence over any values set with this + * function. This decision was made to ensure no change in behavior for any users that + * may be currently using these variables to get coredumps. + * + * \p *value shall contain the requested value specified by \p set. It is up to the caller + * to ensure that the data type and size of \p *value matches the request. + * + * If the caller calls this function with \p *value equal to NULL, the size of the memory + * region (in bytes) expected for \p set will be placed in \p size. + * + * The supported attributes are: + * - ::CU_COREDUMP_ENABLE_ON_EXCEPTION: Bool where ::true means that GPU exceptions from + * this context will create a coredump at the location specified by ::CU_COREDUMP_FILE. + * The default value is ::false. + * - ::CU_COREDUMP_TRIGGER_HOST: Bool where ::true means that the host CPU will + * also create a coredump. The default value is ::true unless set to ::false globally or + * or locally. This value is deprecated as of CUDA 12.5 - raise the ::CU_COREDUMP_SKIP_ABORT + * flag to disable host device abort() if needed. + * - ::CU_COREDUMP_LIGHTWEIGHT: Bool where ::true means that any resulting coredumps + * will not have a dump of GPU memory or non-reloc ELF images. The default value is + * ::false. This attribute is deprecated as of CUDA 12.5, please use ::CU_COREDUMP_GENERATION_FLAGS + * instead. + * - ::CU_COREDUMP_ENABLE_USER_TRIGGER: Bool where ::true means that a coredump can be + * created by writing to the system pipe specified by ::CU_COREDUMP_PIPE. The default + * value is ::false. + * - ::CU_COREDUMP_FILE: String of up to 1023 characters that defines the location where + * any coredumps generated by this context will be written. The default value is + * ::core.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine running + * the CUDA applications and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_PIPE: String of up to 1023 characters that defines the name of the pipe + * that will be monitored if user-triggered coredumps are enabled. This value may not be + * changed after ::CU_COREDUMP_ENABLE_USER_TRIGGER is set to ::true. The default + * value is ::corepipe.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine + * running the CUDA application and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_GENERATION_FLAGS: An integer with values to allow granular control the data + * contained in a coredump specified as a bitwise OR combination of the following values: + * + ::CU_COREDUMP_DEFAULT_FLAGS - if set by itself, coredump generation returns to its + * default settings of including all memory regions that it is able to access + * + ::CU_COREDUMP_SKIP_NONRELOCATED_ELF_IMAGES - Coredump will not include the data from + * CUDA source modules that are not relocated at runtime. + * + ::CU_COREDUMP_SKIP_GLOBAL_MEMORY - Coredump will not include device-side global data + * that does not belong to any context. + * + ::CU_COREDUMP_SKIP_SHARED_MEMORY - Coredump will not include grid-scale shared memory + * for the warp that the dumped kernel belonged to. + * + ::CU_COREDUMP_SKIP_LOCAL_MEMORY - Coredump will not include local memory from the kernel. + * + ::CU_COREDUMP_LIGHTWEIGHT_FLAGS - Enables all of the above options. Equiavlent to setting + * the ::CU_COREDUMP_LIGHTWEIGHT attribute to ::true. + * + ::CU_COREDUMP_SKIP_ABORT - If set, GPU exceptions will not raise an abort() in the host CPU + * process. Same functional goal as ::CU_COREDUMP_TRIGGER_HOST but better reflects the default + * behavior. + * + * \param attrib - The enum defining which value to set. + * \param value - void* containing the requested data. + * \param size - The size of the memory region \p value points to. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_PERMITTED + * + * \sa + * ::cuCoredumpGetAttribute, + * ::cuCoredumpGetAttributeGlobal, + * ::cuCoredumpSetAttribute + */ +CUresult CUDAAPI cuCoredumpSetAttributeGlobal(CUcoredumpSettings attrib, void *value, size_t *size); + +/** @} */ /* END CUDA_COREDUMP */ + +CUresult CUDAAPI cuGetExportTable(const void **ppExportTable, const CUuuid *pExportTableId); + +/* +** ******************* GREEN CONTEXTS ********************** +*/ + +/** + * \defgroup CUDA_GREEN_CONTEXTS Green Contexts + * + * ___MANBRIEF___ Driver level API for creation and manipulation of green contexts + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the APIs for creation and manipulation of green contexts in the CUDA + * driver. Green contexts are a lightweight alternative to traditional contexts, with the ability + * to pass in a set of resources that they should be initialized with. This allows the developer to + * represent distinct spatial partitions of the GPU, provision resources for them, and target them + * via the same programming model that CUDA exposes (streams, kernel launches, etc.). + * + * There are 4 main steps to using these new set of APIs. + * - (1) Start with an initial set of resources, for example via ::cuDeviceGetDevResource. Only SM type is supported today. + * - (2) Partition this set of resources by providing them as input to a partition API, for example: ::cuDevSmResourceSplitByCount. + * - (3) Finalize the specification of resources by creating a descriptor via ::cuDevResourceGenerateDesc. + * - (4) Provision the resources and create a green context via ::cuGreenCtxCreate. + * + * For \p CU_DEV_RESOURCE_TYPE_SM, the partitions created have minimum SM count requirements, often rounding up and aligning the + * minCount provided to ::cuDevSmResourceSplitByCount. The following is a guideline for each architecture + * and may be subject to change: + * - On Compute Architecture 6.X: The minimum count is 1 SM. + * - On Compute Architecture 7.X: The minimum count is 2 SMs and must be a multiple of 2. + * - On Compute Architecture 8.X: The minimum count is 4 SMs and must be a multiple of 2. + * - On Compute Architecture 9.0+: The minimum count is 8 SMs and must be a multiple of 8. + * + * In the future, flags can be provided to tradeoff functional and performance characteristics versus finer grained SM partitions. + * + * Even if the green contexts have disjoint SM partitions, it is not guaranteed that the kernels launched + * in them will run concurrently or have forward progress guarantees. This is due to other resources (like HW connections, + * see ::CUDA_DEVICE_MAX_CONNECTIONS) that could cause a dependency. Additionally, in certain scenarios, + * it is possible for the workload to run on more SMs than was provisioned (but never less). + * The following are two scenarios which can exhibit this behavior: + * - On Volta+ MPS: When \p CUDA_MPS_ACTIVE_THREAD_PERCENTAGE is used, + * the set of SMs that are used for running kernels can be scaled up to the value of SMs used for the MPS client. + * - On Compute Architecture 9.x: When a module with dynamic parallelism (CDP) is loaded, all future + * kernels running under green contexts may use and share an additional set of 2 SMs. + * + * @{ + */ + +/*! + * \typedef struct CUdevResourceDesc_st* CUdevResourceDesc; + * An opaque descriptor handle. The descriptor encapsulates multiple created and configured resources. + * Created via ::cuDevResourceGenerateDesc + */ +typedef struct CUdevResourceDesc_st *CUdevResourceDesc; + +typedef enum { + CU_GREEN_CTX_DEFAULT_STREAM = 0x1, /**< Required. Creates a default stream to use inside the green context */ +} CUgreenCtxCreate_flags; + +typedef enum { + CU_DEV_SM_RESOURCE_SPLIT_IGNORE_SM_COSCHEDULING = 0x1, + CU_DEV_SM_RESOURCE_SPLIT_MAX_POTENTIAL_CLUSTER_SIZE = 0x2, +} CUdevSmResourceSplit_flags; + +#define RESOURCE_ABI_VERSION 1 +#define RESOURCE_ABI_EXTERNAL_BYTES 48 + +#define _CONCAT_INNER(x, y) x ## y +#define _CONCAT_OUTER(x, y) _CONCAT_INNER(x, y) + +/*! + * \typedef enum CUdevResourceType + * Type of resource + */ +typedef enum { + CU_DEV_RESOURCE_TYPE_INVALID = 0, + CU_DEV_RESOURCE_TYPE_SM = 1, /**< Streaming multiprocessors related information */ +#if defined(__CUDA_API_VERSION_INTERNAL) && !defined(__CUDA_API_VERSION_INTERNAL_ODR) + CU_DEV_RESOURCE_TYPE_MAX, +#endif +} CUdevResourceType; + +/*! + * \struct CUdevSmResource + * Data for SM-related resources + */ +typedef struct CUdevSmResource_st { + unsigned int smCount; /**< The amount of streaming multiprocessors available in this resource. This is an output parameter only, do not write to this field. */ +} CUdevSmResource; + +/*! + * \struct CUdevResource + * A tagged union describing different resources identified by the type field. This structure should not be directly modified outside of the API that created it. + * \code + * struct { + * CUdevResourceType type; + * union { + * CUdevSmResource sm; + * }; + * }; + * \endcode + * - If \p type is \p CU_DEV_RESOURCE_TYPE_INVALID, this resoure is not valid and cannot be further accessed. + * - If \p type is \p CU_DEV_RESOURCE_TYPE_SM, the ::CUdevSmResource structure \p sm is filled in. For example, + * \p sm.smCount will reflect the amount of streaming multiprocessors available in this resource. + */ +typedef struct CUdevResource_st { + CUdevResourceType type; /**< Type of resource, dictates which union field was last set */ + unsigned char _internal_padding[92]; + union { + CUdevSmResource sm; /**< Resource corresponding to CU_DEV_RESOURCE_TYPE_SM \p. type. */ + unsigned char _oversize[RESOURCE_ABI_EXTERNAL_BYTES]; + }; +} _CONCAT_OUTER(CUdevResource_v, RESOURCE_ABI_VERSION); +typedef _CONCAT_OUTER(CUdevResource_v, RESOURCE_ABI_VERSION) CUdevResource; + +#undef _CONCAT_INNER +#undef _CONCAT_OUTER + +#undef ABI_PER_RESOURCE_EXTERNAL_BYTES +#undef ABI_RESOURCE_VERSION + +/** + * \brief Creates a green context with a specified set of resources. + * + * This API creates a green context with the resources specified in the descriptor \p desc and + * returns it in the handle represented by \p phCtx. This API will retain the primary context on device \p dev, + * which will is released when the green context is destroyed. It is advised to have the primary context active + * before calling this API to avoid the heavy cost of triggering primary context initialization and + * deinitialization multiple times. + * + * The API does not set the green context current. In order to set it current, you need to explicitly set it current + * by first converting the green context to a CUcontext using ::cuCtxFromGreenCtx and subsequently calling + * ::cuCtxSetCurrent / ::cuCtxPushCurrent. It should be noted that a green context can be current to only one + * thread at a time. There is no internal synchronization to make API calls accessing the same green context + * from multiple threads work. + * + * Note: The API is not supported on 32-bit platforms. + * + * \param phCtx - Pointer for the output handle to the green context + * \param desc - Descriptor generated via ::cuDevResourceGenerateDesc which contains the set of resources to be used + * \param dev - Device on which to create the green context. + * \param flags - One of the supported green context creation flags. \p CU_GREEN_CTX_DEFAULT_STREAM is required. + * + * The supported flags are: + * - \p CU_GREEN_CTX_DEFAULT_STREAM : Creates a default stream to use inside the green context. Required. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa + * ::cuGreenCtxDestroy, + * ::cuCtxFromGreenCtx, + * ::cuCtxSetCurrent, + * ::cuCtxPushCurrent, + * ::cuDevResourceGenerateDesc, + * ::cuDevicePrimaryCtxRetain, + * ::cuCtxCreate, + * ::cuCtxCreate_v3 + */ +CUresult CUDAAPI cuGreenCtxCreate(CUgreenCtx* phCtx, CUdevResourceDesc desc, CUdevice dev, unsigned int flags); + +/** + * \brief Destroys a green context + * + * Destroys the green context, releasing the primary context of the device that this green context was created for. + * Any resources provisioned for this green context (that were initially available via the resource descriptor) + * are released as well. + * \param hCtx - Green context to be destroyed + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * + * \sa + * ::cuGreenCtxCreate, + * ::cuCtxDestroy + */ +CUresult CUDAAPI cuGreenCtxDestroy(CUgreenCtx hCtx); + +/** + * \brief Converts a green context into the primary context + * + * The API converts a green context into the primary context returned in \p pContext. It is important + * to note that the converted context \p pContext is a normal primary context but with + * the resources of the specified green context \p hCtx. Once converted, it can then + * be used to set the context current with ::cuCtxSetCurrent or with any of the CUDA APIs + * that accept a CUcontext parameter. + * + * Users are expected to call this API before calling any CUDA APIs that accept a + * CUcontext. Failing to do so will result in the APIs returning ::CUDA_ERROR_INVALID_CONTEXT. + * + * \param pContext Returned primary context with green context resources + * \param hCtx Green context to convert + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuGreenCtxCreate + */ +CUresult CUDAAPI cuCtxFromGreenCtx(CUcontext *pContext, CUgreenCtx hCtx); + +/** + * \brief Get device resources + * + * Get the \p type resources available to the \p device. + * This may often be the starting point for further partitioning or configuring of resources. + * + * Note: The API is not supported on 32-bit platforms. + * + * \param device - Device to get resource for + * \param resource - Output pointer to a CUdevResource structure + * \param type - Type of resource to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_RESOURCE_TYPE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * + * \sa + * ::cuDevResourceGenerateDesc + */ +CUresult CUDAAPI cuDeviceGetDevResource(CUdevice device, CUdevResource* resource, CUdevResourceType type); + +/** + * \brief Get context resources + * + * Get the \p type resources available to the context represented by \p hCtx + * \param hCtx - Context to get resource for + * + * Note: The API is not supported on 32-bit platforms. + * + * \param resource - Output pointer to a CUdevResource structure + * \param type - Type of resource to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_RESOURCE_TYPE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_CONTEXT + * + * \sa + * ::cuDevResourceGenerateDesc + */ +CUresult CUDAAPI cuCtxGetDevResource(CUcontext hCtx, CUdevResource* resource, CUdevResourceType type); + +/** + * \brief Get green context resources + * + * Get the \p type resources available to the green context represented by \p hCtx + * \param hCtx - Green context to get resource for + * \param resource - Output pointer to a CUdevResource structure + * \param type - Type of resource to retrieve + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_RESOURCE_TYPE, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuDevResourceGenerateDesc + */ +CUresult CUDAAPI cuGreenCtxGetDevResource(CUgreenCtx hCtx, CUdevResource* resource, CUdevResourceType type); + +/** + * \brief Splits \p CU_DEV_RESOURCE_TYPE_SM resources. + * + * Splits \p CU_DEV_RESOURCE_TYPE_SM resources into \p nbGroups, adhering to the minimum SM count specified in \p minCount + * and the usage flags in \p useFlags. If \p result is NULL, the API simulates a split and provides the amount of groups that + * would be created in \p nbGroups. Otherwise, \p nbGroups must point to the amount of elements in \p result and on return, + * the API will overwrite \p nbGroups with the amount actually created. The groups are written to the array in \p result. + * \p nbGroups can be less than the total amount if a smaller number of groups is needed. + * + * This API is used to spatially partition the input resource. The input resource needs to come from one of + * ::cuDeviceGetDevResource, ::cuCtxGetDevResource, or ::cuGreenCtxGetDevResource. + * A limitation of the API is that the output results cannot be split again without + * first creating a descriptor and a green context with that descriptor. + * + * When creating the groups, the API will take into account the performance and functional characteristics of the + * input resource, and guarantee a split that will create a disjoint set of symmetrical partitions. This may lead to fewer groups created + * than purely dividing the total SM count by the \p minCount due to cluster requirements or + * alignment and granularity requirements for the minCount. + * + * The \p remainder set does not have the same functional or performance guarantees as the groups in \p result. + * Its use should be carefully planned and future partitions of the \p remainder set are discouraged. + * + * The following flags are supported: + * - \p CU_DEV_SM_RESOURCE_SPLIT_IGNORE_SM_COSCHEDULING : Lower the minimum SM count and alignment, and treat each SM independent of its hierarchy. + * This allows more fine grained partitions but at the cost of advanced features (such as large clusters on compute capability 9.0+). + * - \p CU_DEV_SM_RESOURCE_SPLIT_MAX_POTENTIAL_CLUSTER_SIZE : Compute Capability 9.0+ only. Attempt to create groups that may allow + * for maximally sized thread clusters. This can be queried post green context creation using ::cuOccupancyMaxPotentialClusterSize. + * + * A successful API call must either have: + * - A valid array of \p result pointers of size passed in \p nbGroups, with \p input of type \p CU_DEV_RESOURCE_TYPE_SM. + * Value of \p minCount must be between 0 and the SM count specified in \p input. \p remaining may be NULL. + * - NULL passed in for \p result, with a valid integer pointer in \p nbGroups and \p input of type \p CU_DEV_RESOURCE_TYPE_SM. + * Value of \p minCount must be between 0 and the SM count specified in \p input. \p remaining may be NULL. + * This queries the number of groups that would be created by the API. + * + * Note: The API is not supported on 32-bit platforms. + * + * \param result - Output array of \p CUdevResource resources. Can be NULL to query the number of groups. + * \param nbGroups - This is a pointer, specifying the number of groups that would be or should be created as described below. + * \param input - Input SM resource to be split. Must be a valid \p CU_DEV_RESOURCE_TYPE_SM resource. + * \param remaining - If the input resource cannot be cleanly split among \p nbGroups, the remaining is placed in here. + * Can be ommitted (NULL) if the user does not need the remaining set. + * \param useFlags - Flags specifying how these partitions are used or which constraints to abide by when splitting the input. Zero is valid for default behavior. + * \param minCount - Minimum number of SMs required + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_RESOURCE_TYPE, + * ::CUDA_ERROR_INVALID_RESOURCE_CONFIGURATION + * + * \sa + * ::cuGreenCtxGetDevResource, + * ::cuCtxGetDevResource, + * ::cuDeviceGetDevResource + */ +CUresult CUDAAPI cuDevSmResourceSplitByCount( + CUdevResource* result, unsigned int* nbGroups, const CUdevResource* input, CUdevResource* remaining, unsigned int useFlags, unsigned int minCount); + +/** + * \brief Generate a resource descriptor + * + * Generates a single resource descriptor with the set of resources specified in \p resources. + * The generated resource descriptor is necessary for the creation of green contexts via the ::cuGreenCtxCreate API. + * Resources of the same type can be passed in, provided they meet the requirements as noted below. + * + * A successful API call must have: + * - A valid output pointer for the \p phDesc descriptor as well as a valid array of \p resources pointers, + * with the array size passed in \p nbResources. + * If multiple resources are provided in \p resources, the device they came from must be the same, + * otherwise CUDA_ERROR_INVALID_RESOURCE_CONFIGURATION is returned. + * If multiple resources are provided in \p resources and they are of type ::CU_DEV_RESOURCE_TYPE_SM, + * they must be outputs (whether \p result or \p remaining) from the same split API instance, + * otherwise CUDA_ERROR_INVALID_RESOURCE_CONFIGURATION is returned. + * + * Note: The API is not supported on 32-bit platforms. + * + * \param phDesc - Output descriptor + * \param resources - Array of resources to be included in the descriptor + * \param nbResources - Number of resources passed in \p resources + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_RESOURCE_TYPE, + * ::CUDA_ERROR_INVALID_RESOURCE_CONFIGURATION + * + * \sa + * ::cuDevSmResourceSplitByCount + */ +CUresult CUDAAPI cuDevResourceGenerateDesc(CUdevResourceDesc *phDesc, CUdevResource *resources, unsigned int nbResources); + +/** + * \brief Records an event. + * + * Captures in \p hEvent all the activities of the green context of \p hCtx + * at the time of this call. \p hEvent and \p hCtx must be from the same + * primary context otherwise ::CUDA_ERROR_INVALID_HANDLE is returned. + * Calls such as ::cuEventQuery() or ::cuGreenCtxWaitEvent() will + * then examine or wait for completion of the work that was captured. Uses of + * \p hCtx after this call do not modify \p hEvent. + * + * \note The API will return ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED if the + * specified green context \p hCtx has a stream in the capture mode. In such + * a case, the call will invalidate all the conflicting captures. + * + * \param hCtx - Green context to record event for + * \param hEvent - Event to record + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED + * + * \sa + * ::cuGreenCtxWaitEvent, + * ::cuEventRecord, + * ::cuCtxRecordEvent, + * ::cuCtxWaitEvent + */ +CUresult CUDAAPI cuGreenCtxRecordEvent(CUgreenCtx hCtx, CUevent hEvent); + +/** + * \brief Make a green context wait on an event + * + * Makes all future work submitted to green context \p hCtx wait for all work + * captured in \p hEvent. The synchronization will be performed on the device + * and will not block the calling CPU thread. See ::cuGreenCtxRecordEvent() + * or ::cuEventRecord(), for details on what is captured by an event. + * + * \note \p hEvent may be from a different context or device than \p hCtx. + * + * \note The API will return ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED and + * invalidate the capture if the specified event \p hEvent is part of an + * ongoing capture sequence or if the specified green context \p hCtx has + * a stream in the capture mode. + * + * \param hCtx - Green context to wait + * \param hEvent - Event to wait on + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED + * + * \sa + * ::cuGreenCtxRecordEvent, + * ::cuStreamWaitEvent + * ::cuCtxRecordEvent, + * ::cuCtxWaitEvent +*/ +CUresult CUDAAPI cuGreenCtxWaitEvent(CUgreenCtx hCtx, CUevent hEvent); + +/** + * \brief Query the green context associated with a stream + * + * Returns the CUDA green context that the stream is associated with, or NULL if the stream + * is not associated with any green context. + * + * The stream handle \p hStream can refer to any of the following: + *
    + *
  • + * a stream created via any of the CUDA driver APIs such as ::cuStreamCreate, ::cuStreamCreateWithPriority + * and ::cuGreenCtxStreamCreate, or their runtime API equivalents such as + * ::cudaStreamCreate, ::cudaStreamCreateWithFlags and ::cudaStreamCreateWithPriority. + * If during stream creation the context that was active in the calling thread was obtained + * with cuCtxFromGreenCtx, that green context is returned in \p phCtx. + * Otherwise, \p *phCtx is set to NULL instead. + *
  • + *
  • + * special stream such as the NULL stream or ::CU_STREAM_LEGACY. + * In that case if context that is active in the calling thread was obtained + * with cuCtxFromGreenCtx, that green context is returned. + * Otherwise, \p *phCtx is set to NULL instead. + *
  • + *
+ * Passing an invalid handle will result in undefined behavior. + * + * \param hStream - Handle to the stream to be queried + * \param phCtx - Returned green context associated with the stream + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreate, + * ::cuStreamCreateWithPriority, + * ::cuStreamGetCtx_v2, + * ::cuGreenCtxStreamCreate, + * ::cuStreamGetPriority, + * ::cuStreamGetFlags, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamCreate, + * ::cudaStreamCreateWithFlags + */ +CUresult CUDAAPI cuStreamGetGreenCtx(CUstream hStream, CUgreenCtx *phCtx); + +/** + * \brief Create a stream for use in the green context + * + * Creates a stream for use in the specified green context \p greenCtx and returns a handle in \p phStream. + * The stream can be destroyed by calling ::cuStreamDestroy(). Note that the API ignores the context that + * is current to the calling thread and creates a stream in the specified green context \p greenCtx. + * + * The supported values for \p flags are: + * - ::CU_STREAM_NON_BLOCKING: This must be specified. It indicates that work running in the created + * stream may run concurrently with work in the default stream, and that + * the created stream should perform no implicit synchronization with the default stream. + * + * Specifying \p priority affects the scheduling priority of work in the stream. Priorities provide a + * hint to preferentially run work with higher priority when possible, but do not preempt + * already-running work or provide any other functional guarantee on execution order. + * \p priority follows a convention where lower numbers represent higher priorities. + * '0' represents default priority. The range of meaningful numerical priorities can + * be queried using ::cuCtxGetStreamPriorityRange. If the specified priority is + * outside the numerical range returned by ::cuCtxGetStreamPriorityRange, + * it will automatically be clamped to the lowest or the highest number in the range. + * + * \param phStream - Returned newly created stream + * \param greenCtx - Green context for which to create the stream for + * \param flags - Flags for stream creation. \p CU_STREAM_NON_BLOCKING must be specified. + * \param priority - Stream priority. Lower numbers represent higher priorities. + * See ::cuCtxGetStreamPriorityRange for more information about + * meaningful stream priorities that can be passed. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \note In the current implementation, only compute kernels launched in + * priority streams are affected by the stream's priority. Stream priorities have + * no effect on host-to-device and device-to-host memory operations. + * + * \sa ::cuStreamDestroy, + * ::cuGreenCtxCreate + * ::cuStreamCreate, + * ::cuStreamGetPriority, + * ::cuCtxGetStreamPriorityRange, + * ::cuStreamGetFlags, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamCreateWithPriority + */ +CUresult CUDAAPI cuGreenCtxStreamCreate(CUstream* phStream, CUgreenCtx greenCtx, unsigned int flags, int priority); + +/** @} */ + +/* +** *************** END CUDA_GREEN_CONTEXTS ***************** +*/ + +/** + * CUDA API versioning support + */ +#if defined(__CUDA_API_VERSION_INTERNAL) + #undef cuMemHostRegister + #undef cuGraphicsResourceSetMapFlags + #undef cuLinkCreate + #undef cuLinkAddData + #undef cuLinkAddFile + #undef cuDeviceTotalMem + #undef cuCtxCreate + #undef cuModuleGetGlobal + #undef cuMemGetInfo + #undef cuMemAlloc + #undef cuMemAllocPitch + #undef cuMemFree + #undef cuMemGetAddressRange + #undef cuMemAllocHost + #undef cuMemHostGetDevicePointer + #undef cuMemcpyHtoD + #undef cuMemcpyDtoH + #undef cuMemcpyDtoD + #undef cuMemcpyDtoA + #undef cuMemcpyAtoD + #undef cuMemcpyHtoA + #undef cuMemcpyAtoH + #undef cuMemcpyAtoA + #undef cuMemcpyHtoAAsync + #undef cuMemcpyAtoHAsync + #undef cuMemcpy2D + #undef cuMemcpy2DUnaligned + #undef cuMemcpy3D + #undef cuMemcpyHtoDAsync + #undef cuMemcpyDtoHAsync + #undef cuMemcpyDtoDAsync + #undef cuMemcpy2DAsync + #undef cuMemcpy3DAsync + #undef cuMemsetD8 + #undef cuMemsetD16 + #undef cuMemsetD32 + #undef cuMemsetD2D8 + #undef cuMemsetD2D16 + #undef cuMemsetD2D32 + #undef cuArrayCreate + #undef cuArrayGetDescriptor + #undef cuArray3DCreate + #undef cuArray3DGetDescriptor + #undef cuTexRefSetAddress + #undef cuTexRefSetAddress2D + #undef cuTexRefGetAddress + #undef cuGraphicsResourceGetMappedPointer + #undef cuCtxDestroy + #undef cuCtxPopCurrent + #undef cuCtxPushCurrent + #undef cuStreamDestroy + #undef cuEventDestroy + #undef cuMemcpy + #undef cuMemcpyAsync + #undef cuMemcpyPeer + #undef cuMemcpyPeerAsync + #undef cuMemcpy3DPeer + #undef cuMemcpy3DPeerAsync + #undef cuMemsetD8Async + #undef cuMemsetD16Async + #undef cuMemsetD32Async + #undef cuMemsetD2D8Async + #undef cuMemsetD2D16Async + #undef cuMemsetD2D32Async + #undef cuStreamGetPriority + #undef cuStreamGetId + #undef cuStreamGetFlags + #undef cuStreamGetCtx + #undef cuStreamWaitEvent + #undef cuStreamAddCallback + #undef cuStreamAttachMemAsync + #undef cuStreamQuery + #undef cuStreamSynchronize + #undef cuEventRecord + #undef cuEventRecordWithFlags + #undef cuLaunchKernel + #undef cuLaunchKernelEx + #undef cuLaunchHostFunc + #undef cuGraphicsMapResources + #undef cuGraphicsUnmapResources + #undef cuStreamWriteValue32 + #undef cuStreamWaitValue32 + #undef cuStreamWriteValue64 + #undef cuStreamWaitValue64 + #undef cuStreamBatchMemOp + #undef cuStreamWriteValue32_v2 + #undef cuStreamWaitValue32_v2 + #undef cuStreamWriteValue64_v2 + #undef cuStreamWaitValue64_v2 + #undef cuStreamBatchMemOp_v2 + #undef cuMemPrefetchAsync + #undef cuMemPrefetchAsync_v2 + #undef cuLaunchCooperativeKernel + #undef cuSignalExternalSemaphoresAsync + #undef cuWaitExternalSemaphoresAsync + #undef cuStreamBeginCapture + #undef cuStreamBeginCaptureToGraph + #undef cuStreamEndCapture + #undef cuStreamIsCapturing + #undef cuStreamGetCaptureInfo + #undef cuStreamGetCaptureInfo_v2 + #undef cuStreamGetCaptureInfo_v3 + #undef cuGraphInstantiateWithParams + #undef cuGraphExecUpdate + #undef cuGraphUpload + #undef cuGraphLaunch + #undef cuDevicePrimaryCtxRelease + #undef cuDevicePrimaryCtxReset + #undef cuDevicePrimaryCtxSetFlags + #undef cuIpcOpenMemHandle + #undef cuStreamCopyAttributes + #undef cuStreamSetAttribute + #undef cuStreamGetAttribute + #undef cuGraphInstantiate + #undef cuGraphAddKernelNode + #undef cuGraphKernelNodeGetParams + #undef cuGraphKernelNodeSetParams + #undef cuGraphExecKernelNodeSetParams + #undef cuMemMapArrayAsync + #undef cuMemFreeAsync + #undef cuMemAllocAsync + #undef cuMemAllocFromPoolAsync + #undef cuStreamUpdateCaptureDependencies + #undef cuStreamUpdateCaptureDependencies_v2 + #undef cuGetProcAddress + #undef cuStreamGetCtx_v2 + + CUresult CUDAAPI cuMemHostRegister(void *p, size_t bytesize, unsigned int Flags); + CUresult CUDAAPI cuGraphicsResourceSetMapFlags(CUgraphicsResource resource, unsigned int flags); + CUresult CUDAAPI cuLinkCreate(unsigned int numOptions, CUjit_option *options, void **optionValues, CUlinkState *stateOut); + CUresult CUDAAPI cuLinkAddData(CUlinkState state, CUjitInputType type, void *data, size_t size, const char *name, + unsigned int numOptions, CUjit_option *options, void **optionValues); + CUresult CUDAAPI cuLinkAddFile(CUlinkState state, CUjitInputType type, const char *path, + unsigned int numOptions, CUjit_option *options, void **optionValues); + CUresult CUDAAPI cuTexRefSetAddress2D_v2(CUtexref hTexRef, const CUDA_ARRAY_DESCRIPTOR *desc, CUdeviceptr dptr, size_t Pitch); + + typedef unsigned int CUdeviceptr_v1; + + typedef struct CUDA_MEMCPY2D_v1_st + { + unsigned int srcXInBytes; /**< Source X in bytes */ + unsigned int srcY; /**< Source Y */ + CUmemorytype srcMemoryType; /**< Source memory type (host, device, array) */ + const void *srcHost; /**< Source host pointer */ + CUdeviceptr_v1 srcDevice; /**< Source device pointer */ + CUarray srcArray; /**< Source array reference */ + unsigned int srcPitch; /**< Source pitch (ignored when src is array) */ + + unsigned int dstXInBytes; /**< Destination X in bytes */ + unsigned int dstY; /**< Destination Y */ + CUmemorytype dstMemoryType; /**< Destination memory type (host, device, array) */ + void *dstHost; /**< Destination host pointer */ + CUdeviceptr_v1 dstDevice; /**< Destination device pointer */ + CUarray dstArray; /**< Destination array reference */ + unsigned int dstPitch; /**< Destination pitch (ignored when dst is array) */ + + unsigned int WidthInBytes; /**< Width of 2D memory copy in bytes */ + unsigned int Height; /**< Height of 2D memory copy */ + } CUDA_MEMCPY2D_v1; + + typedef struct CUDA_MEMCPY3D_v1_st + { + unsigned int srcXInBytes; /**< Source X in bytes */ + unsigned int srcY; /**< Source Y */ + unsigned int srcZ; /**< Source Z */ + unsigned int srcLOD; /**< Source LOD */ + CUmemorytype srcMemoryType; /**< Source memory type (host, device, array) */ + const void *srcHost; /**< Source host pointer */ + CUdeviceptr_v1 srcDevice; /**< Source device pointer */ + CUarray srcArray; /**< Source array reference */ + void *reserved0; /**< Must be NULL */ + unsigned int srcPitch; /**< Source pitch (ignored when src is array) */ + unsigned int srcHeight; /**< Source height (ignored when src is array; may be 0 if Depth==1) */ + + unsigned int dstXInBytes; /**< Destination X in bytes */ + unsigned int dstY; /**< Destination Y */ + unsigned int dstZ; /**< Destination Z */ + unsigned int dstLOD; /**< Destination LOD */ + CUmemorytype dstMemoryType; /**< Destination memory type (host, device, array) */ + void *dstHost; /**< Destination host pointer */ + CUdeviceptr_v1 dstDevice; /**< Destination device pointer */ + CUarray dstArray; /**< Destination array reference */ + void *reserved1; /**< Must be NULL */ + unsigned int dstPitch; /**< Destination pitch (ignored when dst is array) */ + unsigned int dstHeight; /**< Destination height (ignored when dst is array; may be 0 if Depth==1) */ + + unsigned int WidthInBytes; /**< Width of 3D memory copy in bytes */ + unsigned int Height; /**< Height of 3D memory copy */ + unsigned int Depth; /**< Depth of 3D memory copy */ + } CUDA_MEMCPY3D_v1; + + typedef struct CUDA_ARRAY_DESCRIPTOR_v1_st + { + unsigned int Width; /**< Width of array */ + unsigned int Height; /**< Height of array */ + + CUarray_format Format; /**< Array format */ + unsigned int NumChannels; /**< Channels per array element */ + } CUDA_ARRAY_DESCRIPTOR_v1; + + typedef struct CUDA_ARRAY3D_DESCRIPTOR_v1_st + { + unsigned int Width; /**< Width of 3D array */ + unsigned int Height; /**< Height of 3D array */ + unsigned int Depth; /**< Depth of 3D array */ + + CUarray_format Format; /**< Array format */ + unsigned int NumChannels; /**< Channels per array element */ + unsigned int Flags; /**< Flags */ + } CUDA_ARRAY3D_DESCRIPTOR_v1; + + CUresult CUDAAPI cuDeviceTotalMem(unsigned int *bytes, CUdevice dev); + CUresult CUDAAPI cuCtxCreate(CUcontext *pctx, unsigned int flags, CUdevice dev); + CUresult CUDAAPI cuModuleGetGlobal(CUdeviceptr_v1 *dptr, unsigned int *bytes, CUmodule hmod, const char *name); + CUresult CUDAAPI cuMemGetInfo(unsigned int *free, unsigned int *total); + CUresult CUDAAPI cuMemAlloc(CUdeviceptr_v1 *dptr, unsigned int bytesize); + CUresult CUDAAPI cuMemAllocPitch(CUdeviceptr_v1 *dptr, unsigned int *pPitch, unsigned int WidthInBytes, unsigned int Height, unsigned int ElementSizeBytes); + CUresult CUDAAPI cuMemFree(CUdeviceptr_v1 dptr); + CUresult CUDAAPI cuMemGetAddressRange(CUdeviceptr_v1 *pbase, unsigned int *psize, CUdeviceptr_v1 dptr); + CUresult CUDAAPI cuMemAllocHost(void **pp, unsigned int bytesize); + CUresult CUDAAPI cuMemHostGetDevicePointer(CUdeviceptr_v1 *pdptr, void *p, unsigned int Flags); + CUresult CUDAAPI cuMemcpyHtoD(CUdeviceptr_v1 dstDevice, const void *srcHost, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyDtoH(void *dstHost, CUdeviceptr_v1 srcDevice, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyDtoD(CUdeviceptr_v1 dstDevice, CUdeviceptr_v1 srcDevice, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyDtoA(CUarray dstArray, unsigned int dstOffset, CUdeviceptr_v1 srcDevice, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyAtoD(CUdeviceptr_v1 dstDevice, CUarray srcArray, unsigned int srcOffset, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyHtoA(CUarray dstArray, unsigned int dstOffset, const void *srcHost, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyAtoH(void *dstHost, CUarray srcArray, unsigned int srcOffset, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyAtoA(CUarray dstArray, unsigned int dstOffset, CUarray srcArray, unsigned int srcOffset, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyHtoAAsync(CUarray dstArray, unsigned int dstOffset, const void *srcHost, unsigned int ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyAtoHAsync(void *dstHost, CUarray srcArray, unsigned int srcOffset, unsigned int ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpy2D(const CUDA_MEMCPY2D_v1 *pCopy); + CUresult CUDAAPI cuMemcpy2DUnaligned(const CUDA_MEMCPY2D_v1 *pCopy); + CUresult CUDAAPI cuMemcpy3D(const CUDA_MEMCPY3D_v1 *pCopy); + CUresult CUDAAPI cuMemcpyHtoDAsync(CUdeviceptr_v1 dstDevice, const void *srcHost, unsigned int ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyDtoHAsync(void *dstHost, CUdeviceptr_v1 srcDevice, unsigned int ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyDtoDAsync(CUdeviceptr_v1 dstDevice, CUdeviceptr_v1 srcDevice, unsigned int ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpy2DAsync(const CUDA_MEMCPY2D_v1 *pCopy, CUstream hStream); + CUresult CUDAAPI cuMemcpy3DAsync(const CUDA_MEMCPY3D_v1 *pCopy, CUstream hStream); + CUresult CUDAAPI cuMemsetD8(CUdeviceptr_v1 dstDevice, unsigned char uc, unsigned int N); + CUresult CUDAAPI cuMemsetD16(CUdeviceptr_v1 dstDevice, unsigned short us, unsigned int N); + CUresult CUDAAPI cuMemsetD32(CUdeviceptr_v1 dstDevice, unsigned int ui, unsigned int N); + CUresult CUDAAPI cuMemsetD2D8(CUdeviceptr_v1 dstDevice, unsigned int dstPitch, unsigned char uc, unsigned int Width, unsigned int Height); + CUresult CUDAAPI cuMemsetD2D16(CUdeviceptr_v1 dstDevice, unsigned int dstPitch, unsigned short us, unsigned int Width, unsigned int Height); + CUresult CUDAAPI cuMemsetD2D32(CUdeviceptr_v1 dstDevice, unsigned int dstPitch, unsigned int ui, unsigned int Width, unsigned int Height); + CUresult CUDAAPI cuArrayCreate(CUarray *pHandle, const CUDA_ARRAY_DESCRIPTOR_v1 *pAllocateArray); + CUresult CUDAAPI cuArrayGetDescriptor(CUDA_ARRAY_DESCRIPTOR_v1 *pArrayDescriptor, CUarray hArray); + CUresult CUDAAPI cuArray3DCreate(CUarray *pHandle, const CUDA_ARRAY3D_DESCRIPTOR_v1 *pAllocateArray); + CUresult CUDAAPI cuArray3DGetDescriptor(CUDA_ARRAY3D_DESCRIPTOR_v1 *pArrayDescriptor, CUarray hArray); + CUresult CUDAAPI cuTexRefSetAddress(unsigned int *ByteOffset, CUtexref hTexRef, CUdeviceptr_v1 dptr, unsigned int bytes); + CUresult CUDAAPI cuTexRefSetAddress2D(CUtexref hTexRef, const CUDA_ARRAY_DESCRIPTOR_v1 *desc, CUdeviceptr_v1 dptr, unsigned int Pitch); + CUresult CUDAAPI cuTexRefGetAddress(CUdeviceptr_v1 *pdptr, CUtexref hTexRef); + CUresult CUDAAPI cuGraphicsResourceGetMappedPointer(CUdeviceptr_v1 *pDevPtr, unsigned int *pSize, CUgraphicsResource resource); + + CUresult CUDAAPI cuCtxDestroy(CUcontext ctx); + CUresult CUDAAPI cuCtxPopCurrent(CUcontext *pctx); + CUresult CUDAAPI cuCtxPushCurrent(CUcontext ctx); + CUresult CUDAAPI cuStreamDestroy(CUstream hStream); + CUresult CUDAAPI cuEventDestroy(CUevent hEvent); + CUresult CUDAAPI cuDevicePrimaryCtxRelease(CUdevice dev); + CUresult CUDAAPI cuDevicePrimaryCtxReset(CUdevice dev); + CUresult CUDAAPI cuDevicePrimaryCtxSetFlags(CUdevice dev, unsigned int flags); + + CUresult CUDAAPI cuMemcpyHtoD_v2(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount); + CUresult CUDAAPI cuMemcpyDtoH_v2(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount); + CUresult CUDAAPI cuMemcpyDtoD_v2(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount); + CUresult CUDAAPI cuMemcpyDtoA_v2(CUarray dstArray, size_t dstOffset, CUdeviceptr srcDevice, size_t ByteCount); + CUresult CUDAAPI cuMemcpyAtoD_v2(CUdeviceptr dstDevice, CUarray srcArray, size_t srcOffset, size_t ByteCount); + CUresult CUDAAPI cuMemcpyHtoA_v2(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount); + CUresult CUDAAPI cuMemcpyAtoH_v2(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount); + CUresult CUDAAPI cuMemcpyAtoA_v2(CUarray dstArray, size_t dstOffset, CUarray srcArray, size_t srcOffset, size_t ByteCount); + CUresult CUDAAPI cuMemcpyHtoAAsync_v2(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyAtoHAsync_v2(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpy2D_v2(const CUDA_MEMCPY2D *pCopy); + CUresult CUDAAPI cuMemcpy2DUnaligned_v2(const CUDA_MEMCPY2D *pCopy); + CUresult CUDAAPI cuMemcpy3D_v2(const CUDA_MEMCPY3D *pCopy); + CUresult CUDAAPI cuMemcpyHtoDAsync_v2(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyDtoHAsync_v2(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyDtoDAsync_v2(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpy2DAsync_v2(const CUDA_MEMCPY2D *pCopy, CUstream hStream); + CUresult CUDAAPI cuMemcpy3DAsync_v2(const CUDA_MEMCPY3D *pCopy, CUstream hStream); + CUresult CUDAAPI cuMemsetD8_v2(CUdeviceptr dstDevice, unsigned char uc, size_t N); + CUresult CUDAAPI cuMemsetD16_v2(CUdeviceptr dstDevice, unsigned short us, size_t N); + CUresult CUDAAPI cuMemsetD32_v2(CUdeviceptr dstDevice, unsigned int ui, size_t N); + CUresult CUDAAPI cuMemsetD2D8_v2(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height); + CUresult CUDAAPI cuMemsetD2D16_v2(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height); + CUresult CUDAAPI cuMemsetD2D32_v2(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height); + CUresult CUDAAPI cuMemcpy(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount); + CUresult CUDAAPI cuMemcpyAsync(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyPeer(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount); + CUresult CUDAAPI cuMemcpyPeerAsync(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpy3DPeer(const CUDA_MEMCPY3D_PEER *pCopy); + CUresult CUDAAPI cuMemcpy3DPeerAsync(const CUDA_MEMCPY3D_PEER *pCopy, CUstream hStream); + + CUresult CUDAAPI cuMemsetD8Async(CUdeviceptr dstDevice, unsigned char uc, size_t N, CUstream hStream); + CUresult CUDAAPI cuMemsetD16Async(CUdeviceptr dstDevice, unsigned short us, size_t N, CUstream hStream); + CUresult CUDAAPI cuMemsetD32Async(CUdeviceptr dstDevice, unsigned int ui, size_t N, CUstream hStream); + CUresult CUDAAPI cuMemsetD2D8Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height, CUstream hStream); + CUresult CUDAAPI cuMemsetD2D16Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height, CUstream hStream); + CUresult CUDAAPI cuMemsetD2D32Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height, CUstream hStream); + + CUresult CUDAAPI cuStreamGetPriority(CUstream hStream, int *priority); + CUresult CUDAAPI cuStreamGetId(CUstream hStream, unsigned long long *streamId); + CUresult CUDAAPI cuStreamGetFlags(CUstream hStream, unsigned int *flags); + CUresult CUDAAPI cuStreamGetCtx(CUstream hStream, CUcontext *pctx); + CUresult CUDAAPI cuStreamGetCtx_v2(CUstream hStream, CUcontext *pCtx, CUgreenCtx *pGreenCtx); + CUresult CUDAAPI cuStreamWaitEvent(CUstream hStream, CUevent hEvent, unsigned int Flags); + CUresult CUDAAPI cuStreamAddCallback(CUstream hStream, CUstreamCallback callback, void *userData, unsigned int flags); + CUresult CUDAAPI cuStreamAttachMemAsync(CUstream hStream, CUdeviceptr dptr, size_t length, unsigned int flags); + CUresult CUDAAPI cuStreamQuery(CUstream hStream); + CUresult CUDAAPI cuStreamSynchronize(CUstream hStream); + CUresult CUDAAPI cuEventRecord(CUevent hEvent, CUstream hStream); + CUresult CUDAAPI cuEventRecordWithFlags(CUevent hEvent, CUstream hStream, unsigned int flags); + CUresult CUDAAPI cuLaunchKernel(CUfunction f, unsigned int gridDimX, unsigned int gridDimY, unsigned int gridDimZ, unsigned int blockDimX, unsigned int blockDimY, unsigned int blockDimZ, unsigned int sharedMemBytes, CUstream hStream, void **kernelParams, void **extra); + CUresult CUDAAPI cuLaunchKernelEx(const CUlaunchConfig *config, CUfunction f, void **kernelParams, void **extra); + CUresult CUDAAPI cuLaunchHostFunc(CUstream hStream, CUhostFn fn, void *userData); + CUresult CUDAAPI cuGraphicsMapResources(unsigned int count, CUgraphicsResource *resources, CUstream hStream); + CUresult CUDAAPI cuGraphicsUnmapResources(unsigned int count, CUgraphicsResource *resources, CUstream hStream); + CUresult CUDAAPI cuStreamWriteValue32(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWaitValue32(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWriteValue64(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWaitValue64(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + CUresult CUDAAPI cuStreamBatchMemOp(CUstream stream, unsigned int count, CUstreamBatchMemOpParams *paramArray, unsigned int flags); + + CUresult CUDAAPI cuStreamWriteValue32_ptsz(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWaitValue32_ptsz(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWriteValue64_ptsz(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWaitValue64_ptsz(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + CUresult CUDAAPI cuStreamBatchMemOp_ptsz(CUstream stream, unsigned int count, CUstreamBatchMemOpParams *paramArray, unsigned int flags); + + CUresult CUDAAPI cuStreamWriteValue32_v2(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWaitValue32_v2(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWriteValue64_v2(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWaitValue64_v2(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + CUresult CUDAAPI cuStreamBatchMemOp_v2(CUstream stream, unsigned int count, CUstreamBatchMemOpParams *paramArray, unsigned int flags); + CUresult CUDAAPI cuMemPrefetchAsync(CUdeviceptr devPtr, size_t count, CUdevice dstDevice, CUstream hStream); + CUresult CUDAAPI cuMemPrefetchAsync_v2(CUdeviceptr devPtr, size_t count, CUmemLocation location, unsigned int flags, CUstream hStream); + CUresult CUDAAPI cuLaunchCooperativeKernel(CUfunction f, unsigned int gridDimX, unsigned int gridDimY, unsigned int gridDimZ, unsigned int blockDimX, unsigned int blockDimY, unsigned int blockDimZ, unsigned int sharedMemBytes, CUstream hStream, void **kernelParams); + CUresult CUDAAPI cuSignalExternalSemaphoresAsync(const CUexternalSemaphore *extSemArray, const CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS *paramsArray, unsigned int numExtSems, CUstream stream); + CUresult CUDAAPI cuWaitExternalSemaphoresAsync(const CUexternalSemaphore *extSemArray, const CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS *paramsArray, unsigned int numExtSems, CUstream stream); + CUresult CUDAAPI cuStreamBeginCapture(CUstream hStream); + CUresult CUDAAPI cuStreamBeginCapture_ptsz(CUstream hStream); + CUresult CUDAAPI cuStreamBeginCapture_v2(CUstream hStream, CUstreamCaptureMode mode); + CUresult CUDAAPI cuStreamBeginCaptureToGraph(CUstream hStream, CUgraph hGraph, const CUgraphNode *dependencies, const CUgraphEdgeData *dependencyData, size_t numDependencies, CUstreamCaptureMode mode); + CUresult CUDAAPI cuStreamEndCapture(CUstream hStream, CUgraph *phGraph); + CUresult CUDAAPI cuStreamIsCapturing(CUstream hStream, CUstreamCaptureStatus *captureStatus); + CUresult CUDAAPI cuStreamGetCaptureInfo(CUstream hStream, CUstreamCaptureStatus *captureStatus_out, cuuint64_t *id_out); + CUresult CUDAAPI cuStreamGetCaptureInfo_ptsz(CUstream hStream, CUstreamCaptureStatus *captureStatus_out, cuuint64_t *id_out); + CUresult CUDAAPI cuStreamGetCaptureInfo_v2(CUstream hStream, CUstreamCaptureStatus *captureStatus_out, cuuint64_t *id_out, CUgraph *graph_out, const CUgraphNode **dependencies_out, size_t *numDependencies_out); + CUresult CUDAAPI cuStreamGetCaptureInfo_v3(CUstream hStream, CUstreamCaptureStatus *captureStatus_out, cuuint64_t *id_out, CUgraph *graph_out, const CUgraphNode **dependencies_out, const CUgraphEdgeData **edgeData_out, size_t *numDependencies_out); + CUresult CUDAAPI cuGraphAddKernelNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_KERNEL_NODE_PARAMS_v1 *nodeParams); + CUresult CUDAAPI cuGraphKernelNodeGetParams(CUgraphNode hNode, CUDA_KERNEL_NODE_PARAMS_v1 *nodeParams); + CUresult CUDAAPI cuGraphKernelNodeSetParams(CUgraphNode hNode, const CUDA_KERNEL_NODE_PARAMS_v1 *nodeParams); + CUresult CUDAAPI cuGraphExecKernelNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_KERNEL_NODE_PARAMS_v1 *nodeParams); + CUresult CUDAAPI cuGraphInstantiateWithParams(CUgraphExec *phGraphExec, CUgraph hGraph, CUDA_GRAPH_INSTANTIATE_PARAMS *instantiateParams); + CUresult CUDAAPI cuGraphExecUpdate(CUgraphExec hGraphExec, CUgraph hGraph, CUgraphNode *hErrorNode_out, CUgraphExecUpdateResult *updateResult_out); + CUresult CUDAAPI cuGraphUpload(CUgraphExec hGraph, CUstream hStream); + CUresult CUDAAPI cuGraphLaunch(CUgraphExec hGraph, CUstream hStream); + CUresult CUDAAPI cuStreamCopyAttributes(CUstream dstStream, CUstream srcStream); + CUresult CUDAAPI cuStreamGetAttribute(CUstream hStream, CUstreamAttrID attr, CUstreamAttrValue *value); + CUresult CUDAAPI cuStreamSetAttribute(CUstream hStream, CUstreamAttrID attr, const CUstreamAttrValue *param); + + CUresult CUDAAPI cuIpcOpenMemHandle(CUdeviceptr *pdptr, CUipcMemHandle handle, unsigned int Flags); + CUresult CUDAAPI cuGraphInstantiate(CUgraphExec *phGraphExec, CUgraph hGraph, CUgraphNode *phErrorNode, char *logBuffer, size_t bufferSize); + CUresult CUDAAPI cuGraphInstantiate_v2(CUgraphExec *phGraphExec, CUgraph hGraph, CUgraphNode *phErrorNode, char *logBuffer, size_t bufferSize); + + CUresult CUDAAPI cuMemMapArrayAsync(CUarrayMapInfo *mapInfoList, unsigned int count, CUstream hStream); + + CUresult CUDAAPI cuMemFreeAsync(CUdeviceptr dptr, CUstream hStream); + CUresult CUDAAPI cuMemAllocAsync(CUdeviceptr *dptr, size_t bytesize, CUstream hStream); + CUresult CUDAAPI cuMemAllocFromPoolAsync(CUdeviceptr *dptr, size_t bytesize, CUmemoryPool pool, CUstream hStream); + + CUresult CUDAAPI cuStreamUpdateCaptureDependencies(CUstream hStream, CUgraphNode *dependencies, size_t numDependencies, unsigned int flags); + CUresult CUDAAPI cuStreamUpdateCaptureDependencies_v2(CUstream hStream, CUgraphNode *dependencies, const CUgraphEdgeData *dependencyData, size_t numDependencies, unsigned int flags); + + CUresult CUDAAPI cuGetProcAddress(const char *symbol, void **pfn, int cudaVersion, cuuint64_t flags); + +#elif defined(__CUDA_API_PER_THREAD_DEFAULT_STREAM) +static inline CUresult cuGetProcAddress_v2_ptsz(const char *symbol, void **funcPtr, int driverVersion, cuuint64_t flags, CUdriverProcAddressQueryResult *symbolStatus) { + const int procAddressMask = (CU_GET_PROC_ADDRESS_LEGACY_STREAM| + CU_GET_PROC_ADDRESS_PER_THREAD_DEFAULT_STREAM); + if ((flags & procAddressMask) == 0) { + flags |= CU_GET_PROC_ADDRESS_PER_THREAD_DEFAULT_STREAM; + } + return cuGetProcAddress_v2(symbol, funcPtr, driverVersion, flags, symbolStatus); +} +#define cuGetProcAddress_v2 cuGetProcAddress_v2_ptsz +#endif + +#ifdef __cplusplus +} +#endif + +#if defined(__GNUC__) + #if defined(__CUDA_API_PUSH_VISIBILITY_DEFAULT) + #pragma GCC visibility pop + #endif +#endif + +#undef __CUDA_DEPRECATED + +#endif /* __cuda_cuda_h__ */ diff --git a/include/miniocpp/cufile.h b/include/miniocpp/cufile.h new file mode 100644 index 00000000..f98b8bf3 --- /dev/null +++ b/include/miniocpp/cufile.h @@ -0,0 +1,740 @@ +/* + * Copyright 1993-2023 NVIDIA Corporation. All rights reserved. + * + * NOTICE TO LICENSEE: + * + * This source code and/or documentation ("Licensed Deliverables") are + * subject to NVIDIA intellectual property rights under U.S. and + * international Copyright laws. + * + * These Licensed Deliverables contained herein is PROPRIETARY and + * CONFIDENTIAL to NVIDIA and is being provided under the terms and + * conditions of a form of NVIDIA software license agreement by and + * between NVIDIA and Licensee ("License Agreement") or electronically + * accepted by Licensee. Notwithstanding any terms or conditions to + * the contrary in the License Agreement, reproduction or disclosure + * of the Licensed Deliverables to any third party without the express + * written consent of NVIDIA is prohibited. + * + * NOTWITHSTANDING ANY TERMS OR CONDITIONS TO THE CONTRARY IN THE + * LICENSE AGREEMENT, NVIDIA MAKES NO REPRESENTATION ABOUT THE + * SUITABILITY OF THESE LICENSED DELIVERABLES FOR ANY PURPOSE. IT IS + * PROVIDED "AS IS" WITHOUT EXPRESS OR IMPLIED WARRANTY OF ANY KIND. + * NVIDIA DISCLAIMS ALL WARRANTIES WITH REGARD TO THESE LICENSED + * DELIVERABLES, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY, + * NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE. + * NOTWITHSTANDING ANY TERMS OR CONDITIONS TO THE CONTRARY IN THE + * LICENSE AGREEMENT, IN NO EVENT SHALL NVIDIA BE LIABLE FOR ANY + * SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, OR ANY + * DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, + * WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS + * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE + * OF THESE LICENSED DELIVERABLES. + * + * U.S. Government End Users. These Licensed Deliverables are a + * "commercial item" as that term is defined at 48 C.F.R. 2.101 (OCT + * 1995), consisting of "commercial computer software" and "commercial + * computer software documentation" as such terms are used in 48 + * C.F.R. 12.212 (SEPT 1995) and is provided to the U.S. Government + * only as a commercial end item. Consistent with 48 C.F.R.12.212 and + * 48 C.F.R. 227.7202-1 through 227.7202-4 (JUNE 1995), all + * U.S. Government End Users acquire the Licensed Deliverables with + * only those rights set forth herein. + * + * Any use of the Licensed Deliverables in individual and commercial + * software must include, in the user documentation and internal + * comments to the code, the above Disclaimer and U.S. Government End + * Users Notice. + */ + +/** + * @file cufile.h + * @brief cuFile C APIs + * + * This file contains all the C APIs to perform GPUDirect Storage supported IO operations + */ + +#if __cplusplus +extern "C" +{ +#endif + +/// @cond DOXYGEN_SKIP_MACRO +#ifndef __CUFILE_H_ +#define __CUFILE_H_ + +#include +#include + +#include +#include +#include + +#define CUFILEOP_BASE_ERR 5000 + +//Note :Data path errors are captured via standard error codes +#define CUFILEOP_STATUS_ENTRIES \ + CUFILE_OP(0, CU_FILE_SUCCESS, cufile success) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 1, CU_FILE_DRIVER_NOT_INITIALIZED, nvidia-fs driver is not loaded. Set allow_compat_mode to true in cufile.json file to enable compatible mode) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 2, CU_FILE_DRIVER_INVALID_PROPS, invalid property) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 3, CU_FILE_DRIVER_UNSUPPORTED_LIMIT, property range error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 4, CU_FILE_DRIVER_VERSION_MISMATCH, nvidia-fs driver version mismatch) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 5, CU_FILE_DRIVER_VERSION_READ_ERROR, nvidia-fs driver version read error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 6, CU_FILE_DRIVER_CLOSING, driver shutdown in progress) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 7, CU_FILE_PLATFORM_NOT_SUPPORTED, GPUDirect Storage not supported on current platform) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 8, CU_FILE_IO_NOT_SUPPORTED, GPUDirect Storage not supported on current file) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 9, CU_FILE_DEVICE_NOT_SUPPORTED, GPUDirect Storage not supported on current GPU) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 10, CU_FILE_NVFS_DRIVER_ERROR, nvidia-fs driver ioctl error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 11, CU_FILE_CUDA_DRIVER_ERROR, CUDA Driver API error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 12, CU_FILE_CUDA_POINTER_INVALID, invalid device pointer) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 13, CU_FILE_CUDA_MEMORY_TYPE_INVALID, invalid pointer memory type) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 14, CU_FILE_CUDA_POINTER_RANGE_ERROR, pointer range exceeds allocated address range) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 15, CU_FILE_CUDA_CONTEXT_MISMATCH, cuda context mismatch) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 16, CU_FILE_INVALID_MAPPING_SIZE, access beyond maximum pinned size) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 17, CU_FILE_INVALID_MAPPING_RANGE, access beyond mapped size) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 18, CU_FILE_INVALID_FILE_TYPE, unsupported file type) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 19, CU_FILE_INVALID_FILE_OPEN_FLAG, unsupported file open flags) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 20, CU_FILE_DIO_NOT_SET, fd direct IO not set) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 22, CU_FILE_INVALID_VALUE, invalid arguments) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 23, CU_FILE_MEMORY_ALREADY_REGISTERED, device pointer already registered) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 24, CU_FILE_MEMORY_NOT_REGISTERED, device pointer lookup failure) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 25, CU_FILE_PERMISSION_DENIED, driver or file access error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 26, CU_FILE_DRIVER_ALREADY_OPEN, driver is already open) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 27, CU_FILE_HANDLE_NOT_REGISTERED, file descriptor is not registered) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 28, CU_FILE_HANDLE_ALREADY_REGISTERED, file descriptor is already registered) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 29, CU_FILE_DEVICE_NOT_FOUND, GPU device not found) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 30, CU_FILE_INTERNAL_ERROR, internal error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 31, CU_FILE_GETNEWFD_FAILED, failed to obtain new file descriptor) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 33, CU_FILE_NVFS_SETUP_ERROR, NVFS driver initialization error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 34, CU_FILE_IO_DISABLED, GPUDirect Storage disabled by config on current file)\ + CUFILE_OP(CUFILEOP_BASE_ERR + 35, CU_FILE_BATCH_SUBMIT_FAILED, failed to submit batch operation)\ + CUFILE_OP(CUFILEOP_BASE_ERR + 36, CU_FILE_GPU_MEMORY_PINNING_FAILED, failed to allocate pinned GPU Memory) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 37, CU_FILE_BATCH_FULL, queue full for batch operation) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 38, CU_FILE_ASYNC_NOT_SUPPORTED, cuFile stream operation not supported) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 39, CU_FILE_IO_MAX_ERROR, GPUDirect Storage Max Error) + + +/** + * @brief cufileop status enum + * + * @note on success the error code is set to @ref CU_FILE_SUCCESS. + * @note The error code can be inspected using @ref IS_CUFILE_ERR and @ref CUFILE_ERRSTR. + * @note The error code if set to @ref CU_FILE_CUDA_DRIVER_ERROR, then cuda error can be inspected using @ref IS_CUDA_ERR and @ref CU_FILE_CUDA_ERR. + * @note Data path errors are captured via standard error codes + */ +typedef enum CUfileOpError { + /// @cond DOXYGEN_SKIP_MACRO + #define CUFILE_OP(code, name, string) name = code, + CUFILEOP_STATUS_ENTRIES + #undef CUFILE_OP + ///@endcond +} CUfileOpError; + +/// @endcond + +/** + * @brief cufileop status string + */ +static inline const char *cufileop_status_error(CUfileOpError status) +{ + switch (status) { + /// @cond DOXYGEN_SKIP_MACRO + #define CUFILE_OP(code, name, string) \ + case name: return #string; + CUFILEOP_STATUS_ENTRIES + #undef CUFILE_OP + ///@endcond + default:return "unknown cufile error"; + } +} + +/** + * @brief cufileop status string + */ +typedef struct CUfileError { + + CUfileOpError err; // cufile error + + CUresult cu_err; // cuda driver error + +}CUfileError_t; + +/** + * @brief error macros to inspect error status of type @ref CUfileOpError + */ + +#define IS_CUFILE_ERR(err) \ + (abs((err)) > CUFILEOP_BASE_ERR) + +#define CUFILE_ERRSTR(err) \ + cufileop_status_error((CUfileOpError)abs((err))) + +#define IS_CUDA_ERR(status) \ + ((status).err == CU_FILE_CUDA_DRIVER_ERROR) + +#define CU_FILE_CUDA_ERR(status) ((status).cu_err) + +/* driver properties */ +typedef enum CUfileDriverStatusFlags { + CU_FILE_LUSTRE_SUPPORTED = 0, /*!< Support for DDN LUSTRE */ + + CU_FILE_WEKAFS_SUPPORTED = 1, /*!< Support for WEKAFS */ + + CU_FILE_NFS_SUPPORTED = 2, /*!< Support for NFS */ + + CU_FILE_GPFS_SUPPORTED = 3, /*! < Support for GPFS */ + + CU_FILE_NVME_SUPPORTED = 4, /*!< Support for NVMe */ + + CU_FILE_NVMEOF_SUPPORTED = 5, /*!< Support for NVMeOF */ + + CU_FILE_SCSI_SUPPORTED = 6, /*!< Support for SCSI */ + + CU_FILE_SCALEFLUX_CSD_SUPPORTED = 7, /*!< Support for Scaleflux CSD*/ + + CU_FILE_NVMESH_SUPPORTED = 8, /*!< Support for NVMesh Block Dev*/ + CU_FILE_BEEGFS_SUPPORTED = 9, /*!< Support for BeeGFS */ + CU_FILE_YRCLOUDFILE_SUPPORTED = 10, /*!< Support for YRCloudFile */ + CU_FILE_NVME_P2P_SUPPORTED = 11, /*!< Support for NVMe using PCI P2PDMA */ + +}CUfileDriverStatusFlags_t; + +typedef enum CUfileDriverControlFlags { + CU_FILE_USE_POLL_MODE = 0 , /*!< use POLL mode. properties.use_poll_mode*/ + + CU_FILE_ALLOW_COMPAT_MODE = 1/*!< allow COMPATIBILITY mode. properties.allow_compat_mode*/ + +}CUfileDriverControlFlags_t; + +typedef enum CUfileFeatureFlags { + CU_FILE_DYN_ROUTING_SUPPORTED = 0, /*!< Support for Dynamic routing to handle devices across the PCIe bridges */ + + CU_FILE_BATCH_IO_SUPPORTED = 1, /*!< Unsupported */ + + CU_FILE_STREAMS_SUPPORTED = 2, /*!< Unsupported */ + + CU_FILE_PARALLEL_IO_SUPPORTED = 3 /*!< Unsupported */ +}CUfileFeatureFlags_t; + +typedef struct CUfileDrvProps { + struct { + unsigned int major_version; + + unsigned int minor_version; + + size_t poll_thresh_size; + + size_t max_direct_io_size; + + unsigned int dstatusflags; + + unsigned int dcontrolflags; + + } nvfs; + + unsigned int fflags; + + unsigned int max_device_cache_size; + + unsigned int per_buffer_cache_size; + + unsigned int max_device_pinned_mem_size; + + unsigned int max_batch_io_size; + unsigned int max_batch_io_timeout_msecs; +}CUfileDrvProps_t; + +typedef struct sockaddr sockaddr_t; + +typedef struct cufileRDMAInfo +{ + int version; + int desc_len; + const char *desc_str; +}cufileRDMAInfo_t; + +#define CU_FILE_RDMA_REGISTER 1 +#define CU_FILE_RDMA_RELAXED_ORDERING (1<<1) + + + +typedef struct CUfileFSOps { + /* NULL means discover using fstat */ + const char* (*fs_type) (const void *handle); + + /* list of host addresses to use, NULL means no restriction */ + int (*getRDMADeviceList)(const void *handle, sockaddr_t **hostaddrs); + + /* -1 no pref */ + int (*getRDMADevicePriority)(const void *handle, char*, size_t, + loff_t, const sockaddr_t* hostaddr); + + /* NULL means try VFS */ + ssize_t (*read) (const void *handle, char*, size_t, loff_t, const cufileRDMAInfo_t*); + ssize_t (*write) (const void *handle, const char *, size_t, loff_t , const cufileRDMAInfo_t*); +}CUfileFSOps_t; + +/* File Handle */ +enum CUfileFileHandleType { + CU_FILE_HANDLE_TYPE_OPAQUE_FD = 1, /*!< Linux based fd */ + + CU_FILE_HANDLE_TYPE_OPAQUE_WIN32 = 2, /*!< Windows based handle (unsupported) */ + + CU_FILE_HANDLE_TYPE_USERSPACE_FS = 3, /* Userspace based FS */ +}; + +typedef struct CUfileDescr_t { + enum CUfileFileHandleType type; /* type of file being registered */ + union { + int fd; /* Linux */ + void *handle; /* Windows */ + } handle; + const CUfileFSOps_t *fs_ops; /* file system operation table */ +}CUfileDescr_t; + +/** + * @brief File handle type + * + */ +typedef void* CUfileHandle_t; + + +#pragma GCC visibility push(default) + +/** + * @brief cuFileHandleRegister is required, and performs extra checking that is memoized to provide increased performance on later cuFile operations. + * + * @param fh @ref CUfileHandle_t opaque file handle for IO operations + * @param descr @ref CUfileDescr_t file descriptor (OS agnostic) + * + * @return CU_FILE_SUCCESS on successful completion. fh will be updated for use in @ref cuFileRead, @ref cuFileWrite, @ref cuFileHandleDeregister + * @return CU_FILE_DRIVER_NOT_INITIALIZED on failure to load driver + * @return CU_FILE_IO_NOT_SUPPORTED - if filesystem is not supported + * @return CU_FILE_INVALID_VALUE if null or bad api arguments + * @return CU_FILE_INVALID_FILE_OPEN_FLAG if file is opened with unsupported modes like no O_DIRECT + * @return CU_FILE_INVALID_FILE_TYPE if filepath is not valid or is not a regular file + * @return CU_FILE_HANDLE_ALREADY_REGISTERED if file handle/descriptor is already registered + * + * Description + * cuFileHandleRegister registers the open file descriptor for use with cuFile IO operations. + * + * This API will ensure that the file’s descriptor is checked for GPUDirect Storage support and returns a valid file handle on CU_FILE_SUCCESS. + * + * @note the file needs to be opened in O_DIRECT mode to support GPUDirect Storage. + * + * @see cuFileRead + * @see cuFileWrite + * @see cuFileHandleDeregister + * + */ +CUfileError_t cuFileHandleRegister(CUfileHandle_t *fh, CUfileDescr_t *descr); + +/** + * @brief releases a registered filehandle from cuFile + * + * @param fh @ref CUfileHandle_t file handle + * + * @return void + * + * @see cuFileHandleRegister + */ +void cuFileHandleDeregister(CUfileHandle_t fh); + +/** + * @brief register an existing cudaMalloced memory with cuFile to pin for GPUDirect Storage access or + * register host allocated memory with cuFile. + * + * @param bufPtr_base buffer pointer allocated + * @param length size of memory region from the above specified bufPtr + * @param flags CU_FILE_RDMA_REGISTER + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_NVFS_DRIVER_ERROR + * @return CU_FILE_INVALID_VALUE + * @return CU_FILE_CUDA_ERROR for unsuported memory type + * @return CU_FILE_MEMORY_ALREADY_REGISTERED on error + * @return CU_FILE_GPU_MEMORY_PINNING_FAILED if not enough pinned memory is available + * @note This memory will be use to perform GPU direct DMA from the supported storage. + * @warning This API is intended for usecases where the memory is used as streaming buffer that is reused across multiple cuFile IO operations before calling @ref cuFileBufDeregister + * + * @see cuFileBufDeregister + * @see cuFileRead + * @see cuFileWrite + */ +CUfileError_t cuFileBufRegister(const void *bufPtr_base, size_t length, int flags); + +/** + * @brief deregister an already registered device or host memory from cuFile + * + * @param bufPtr_base buffer pointer to deregister + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_INVALID_VALUE on invalid memory pointer or unregistered memory pointer + * + * @see cuFileBufRegister + * @see cuFileRead + * @see cuFileWrite + */ + +CUfileError_t cuFileBufDeregister(const void *bufPtr_base); + +/** + * @brief read data from a registered file handle to a specified device or host memory + * + * @param fh @ref CUfileHandle_t opaque file handle + * @param bufPtr_base base address of buffer in device or host memory + * @param size size bytes to read + * @param file_offset file-offset from begining of the file + * @param bufPtr_offset offset relative to the bufPtr_base pointer to read into. + * + * @return size of bytes successfully read + * @return -1 on error, in which case errno is set to indicate filesystem errors. + * @return all other errors will return a negative integer value of @ref CUfileOpError enum value. + * + * @note If the bufPtr is not registered with @ref cuFileBufRegister, the data will be buffered through preallocated pinned buffers if needed. + * @note This is useful for applications that need to perform IO to unaligned file offsets and/or size. This is also recommended + * for cases where the BAR1 memory size is smaller than the size of the allocated memory. + * + * @see cuFileBufRegister + * @see cuFileHandleRegister + * @see cuFileWrite + */ + +ssize_t cuFileRead(CUfileHandle_t fh, void *bufPtr_base, size_t size, off_t file_offset, off_t bufPtr_offset); + +/** + * @brief write data from a specified device or host memory to a registered file handle + * + * @param fh @ref CUfileHandle_t opaque file handle + * @param bufPtr_base base address of buffer in device or host memory + * @param size size bytes to write + * @param file_offset file-offset from begining of the file + * @param bufPtr_offset offset relative to the bufPtr_base pointer to write from. + * + * @return size of bytes successfully written + * @return -1 on error, in which case errno is set to indicate filesystem errors. + * @return all other errors will return a negative integer value of @ref CUfileOpError enum value. + * + * @note If the bufPtr is not registered with @ref cuFileBufRegister, the data will be buffered through preallocated pinned buffers if needed. + * @note This is useful for applications that need to perform IO to unaligned file offsets and/or size. This is also recommended + * for cases where the BAR1 memory size is smaller than the size of the allocated memory. + * + * @see cuFileBufRegister + * @see cuFileHandleRegister + * @see cuFileRead + */ + +ssize_t cuFileWrite(CUfileHandle_t fh, const void *bufPtr_base, size_t size, off_t file_offset, off_t bufPtr_offset); + +// CUFile Driver APIs + +/** + * @brief + * Initialize the cuFile library and open the nvidia-fs driver + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_NOT_INITIALIZED + * @return CU_FILE_DRIVER_VERSION_MISMATCH on driver version mismatch error + * + * @see cuFileDriverClose + */ +CUfileError_t cuFileDriverOpen(void); + +CUfileError_t cuFileDriverClose(void); +#define cuFileDriverClose cuFileDriverClose_v2 +/** + * @brief + * reset the cuFile library and release the nvidia-fs driver + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_CLOSING if there are any active IO operations using @ref cuFileRead or @ref cuFileWrite + * + * @see cuFileDriverOpen + */ +CUfileError_t cuFileDriverClose(void); + +/** + * @brief + * returns use count of cufile drivers at that moment by the process. + */ +long cuFileUseCount(void); + +/** + * @brief + * Gets the Driver session properties + * + * @return CU_FILE_SUCCESS on success + * + * @see cuFileDriverSetPollMode + * @see cuFileDriverSetMaxDirectIOSize + * @see cuFileDriverSetMaxCacheSize + * @see cuFileDriverSetMaxPinnedMemSize + */ +CUfileError_t cuFileDriverGetProperties(CUfileDrvProps_t *props); + +/** + * @brief + * Sets whether the Read/Write APIs use polling to do IO operations + * + * @param poll boolean to indicate whether to use poll mode or not + * @param poll_threshold_size max IO size to use for POLLING mode in KB + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized + * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on error + * + * @warning This is an advanced command and should be tuned based on available system memory + * + * @see cuFileDriverGetProperties + */ +CUfileError_t cuFileDriverSetPollMode(bool poll, size_t poll_threshold_size); + +/** + * @brief + * Control parameter to set max IO size(KB) used by the library to talk to nvidia-fs driver + * + * @param max_direct_io_size maximum allowed direct io size in KB + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized + * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on error + * + * @warning This is an advanced command and should be tuned based on available system memory + * + * @see cuFileDriverGetProperties + * + */ +CUfileError_t cuFileDriverSetMaxDirectIOSize(size_t max_direct_io_size); + +/** + * @brief + * Control parameter to set maximum GPU memory reserved per device by the library for internal buffering + * + * @param max_cache_size The maximum GPU buffer space per device used for internal use in KB + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized + * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on error + * + * @warning This is an advanced command and should be tuned based on supported GPU memory + * + * @see cuFileDriverGetProperties + */ +CUfileError_t cuFileDriverSetMaxCacheSize(size_t max_cache_size); + +/** + * @brief + * Sets maximum buffer space that is pinned in KB for use by @ref cuFileBufRegister + * + * @param max_pinned_size maximum buffer space that is pinned in KB + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized + * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on error + * + * @warning This is an advanced command and should be tuned based on supported GPU memory + * + * @see cuFileDriverGetProperties + * + */ +CUfileError_t cuFileDriverSetMaxPinnedMemSize(size_t max_pinned_size); + +//Experimental Batch API's + + +typedef enum CUfileOpcode { + CUFILE_READ = 0, + CUFILE_WRITE +}CUfileOpcode_t; + +typedef enum CUFILEStatus_enum { + CUFILE_WAITING = 0x000001, /* required value prior to submission */ + CUFILE_PENDING = 0x000002, /* once enqueued */ + CUFILE_INVALID = 0x000004, /* request was ill-formed or could not be enqueued */ + CUFILE_CANCELED = 0x000008, /* request successfully canceled */ + CUFILE_COMPLETE = 0x0000010, /* request successfully completed */ + CUFILE_TIMEOUT = 0x0000020, /* request timed out */ + CUFILE_FAILED = 0x0000040 /* unable to complete */ +}CUfileStatus_t; +typedef enum cufileBatchMode { + CUFILE_BATCH = 1, +} CUfileBatchMode_t; +typedef struct CUfileIOParams { + CUfileBatchMode_t mode; // Must be the very first field. + union { + struct { + void *devPtr_base; //This can be a device memory or a host memory pointer. + off_t file_offset; + off_t devPtr_offset; + size_t size; + }batch; + }u; + CUfileHandle_t fh; + CUfileOpcode_t opcode; + void *cookie; +}CUfileIOParams_t; +typedef struct CUfileIOEvents { + void *cookie; + CUfileStatus_t status; /* status of the operation */ + size_t ret; /* -ve error or amount of I/O done. */ +}CUfileIOEvents_t; + +typedef void* CUfileBatchHandle_t; + +CUfileError_t cuFileBatchIOSetUp(CUfileBatchHandle_t *batch_idp, unsigned nr); +CUfileError_t cuFileBatchIOSubmit(CUfileBatchHandle_t batch_idp, unsigned nr, CUfileIOParams_t *iocbp, unsigned int flags); +CUfileError_t cuFileBatchIOGetStatus(CUfileBatchHandle_t batch_idp, unsigned min_nr, unsigned* nr, + CUfileIOEvents_t *iocbp, struct timespec* timeout); +CUfileError_t cuFileBatchIOCancel(CUfileBatchHandle_t batch_idp); +void cuFileBatchIODestroy(CUfileBatchHandle_t batch_idp); + +//Async API's with cuda streams + +// cuFile stream API registration flags +// buffer pointer offset is set at submission time +#define CU_FILE_STREAM_FIXED_BUF_OFFSET 1 +// file offset is set at submission time +#define CU_FILE_STREAM_FIXED_FILE_OFFSET 2 +// file size is set at submission time +#define CU_FILE_STREAM_FIXED_FILE_SIZE 4 +// size, offset and buffer offset are 4k aligned +#define CU_FILE_STREAM_PAGE_ALIGNED_INPUTS 8 + +/** + *@brief + + * @param fh The cuFile handle for the file. + * @param bufPtr_base base address of buffer in device or host memory + * @param size_p pointer to size bytes to read + * @note *size_p if the size is not known at the time of submission, then must provide the max possible size for I/O request. + * @param file_offset_p pointer to file-offset from begining of the file + * @param bufPtr_offset_p pointer to offset relative to the bufPtr_base pointer to read into. + * @param bytes_read_p pointer to the number of bytes that were successfully read. + * @param CUstream stream cuda stream for the operation. + * + * @return size of bytes successfully read in *bytes_read_p + * @return -1 on error, in which case errno is set to indicate filesystem errors. + * @return all other errors will return a negative integer value of @ref CUfileOpError enum value. + * + * @note If the bufPtr_base is not registered with @ref cuFileBufRegister, the data will be buffered through preallocated pinned buffers. + * @note This is useful for applications that need to perform IO to unaligned file offsets and/or size. This is also recommended + * for cases where the BAR1 memory size is smaller than the size of the allocated memory. + * @note If the stream is registered with cuFileStreamRegister, the IO setup and teardown overhead will be reduced. + * @note on cuda stream errors, the user must call cuFileStreamDeregister to release any outstanding cuFile resources for the stream. + * + * + * @see cuFileBufRegister + * @see cuFileHandleRegister + * @see cuFileRead + * @see cuFileStreamRegister + * @see cuFileStreamDeregister + */ + +CUfileError_t cuFileReadAsync(CUfileHandle_t fh, void *bufPtr_base, + size_t *size_p, off_t *file_offset_p, off_t *bufPtr_offset_p, ssize_t *bytes_read_p, CUstream stream); + +/** + *@brief + +* @param fh The cuFile handle for the file. + * @param bufPtr_base base address of buffer in device or host memory + * @param size_p pointer to size bytes to write. + * @note *size_p if the size is not known at the time of submission, then must provide the max possible size for I/O request. + * @param file_offset_p pointer to file-offset from begining of the file + * @param bufPtr_offset_p pointer to offset relative to the bufPtr_base pointer to write from. + * @param bytes_written_p pointer to the number of bytes that were successfully written. + * @param CUstream cuda stream for the operation. + * + * @return size of bytes successfully written in *bytes_written_p + * @return -1 on error, in which case errno is set to indicate filesystem errors. + * @return all other errors will return a negative integer value of @ref CUfileOpError enum value. + * + * @note If the bufPtr_base is not registered with @ref cuFileBufRegister, the data will be buffered through preallocated pinned buffers. + * @note This is useful for applications that need to perform IO to unaligned file offsets and/or size. This is also recommended + * for cases where the BAR1 memory size is smaller than the size of the allocated memory. + * @note If the stream is registered with cuFileStreamRegister prior to this call, the IO setup and teardown overhead will be reduced. + * @note on cuda stream errors, the user must call cuFileStreamDeregister to release any outstanding cuFile resources for the stream. + * + * @see cuFileBufRegister + * @see cuFileHandleRegister + * @see cuFileWrite + * @see cuFileStreamRegister + * @see cuFileStreamDeregister + */ + +CUfileError_t cuFileWriteAsync(CUfileHandle_t fh, void *bufPtr_base, + size_t *size_p, off_t *file_offset_p, off_t *bufPtr_offset_p, ssize_t *bytes_written_p, CUstream stream); + +/** + *@brief + + * @param CUstream cuda stream for the operation. + * @param flags for the stream to improve the stream execution of IO based on input parameters. + * @note supported FLAGS are + * @note CU_FILE_STREAM_FIXED_BUF_OFFSET - buffer pointer offset is set at submission time + * @note CU_FILE_STREAM_FIXED_FILE_OFFSET - file offset is set at submission time + * @note CU_FILE_STREAM_FIXED_FILE_SIZE - file size is set at submission time + * @note CU_FILE_STREAM_PAGE_ALIGNED_INPUTS - size, offset and buffer offset are 4k aligned + * + * @note allocates resources needed to support cuFile operations asynchronously for the cuda stream + * @note This is useful for applications that need to perform IO to unaligned file offsets and/or size. This is also recommended + * for cases where the BAR1 memory size is smaller than the size of the allocated memory. + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized + * @return CU_FILE_INVALID_VALUE if the stream is invalid + * + * @see cuFileReadAsync + * @see cuFileWriteAsync + * @see cuFileStreamDeregister + */ + +CUfileError_t cuFileStreamRegister(CUstream stream, unsigned flags); + +/** + *@brief + + * @param CUstream cuda stream for the operation. + * + * @note deallocates resources used by previous cuFile asynchronous operations for the cuda stream + * @note highly recommend to call after cuda stream errors to release any outstanding cuFile resources for this stream + * @note must be called before cuStreamDestroy call for the specified stream. + * @note This is useful for applications that need to perform IO to unaligned file offsets and/or size. This is also recommended + * for cases where the BAR1 memory size is smaller than the size of the allocated memory. + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized + * @return CU_FILE_INVALID_VALUE if the stream is invalid + * + * @see cuFileReadAsync + * @see cuFileWriteAsync + * @see cuFileStreamRegister + */ + +CUfileError_t cuFileStreamDeregister(CUstream stream); + +/** + *@brief + + * @returns cufile library version. + * + * @The version is returned as (1000 major + 10 minor). + * @For example, CUFILE 1.7.0 would be represented by 1070. + * @note This is useful for applications that need to inquire the library. + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_INVALID_VALUE if the input parameter is null. + * @return CU_FILE_DRIVER_VERSION_READ_ERROR if the version is not available. + * + */ + +CUfileError_t cuFileGetVersion(int *version); + +#pragma GCC visibility pop + +/// @cond DOXYGEN_SKIP_MACRO +#endif // CUFILE_H +/// @endcond +#ifdef __cplusplus +} +#endif diff --git a/include/miniocpp/cufile_info.h b/include/miniocpp/cufile_info.h new file mode 100644 index 00000000..e5d1df31 --- /dev/null +++ b/include/miniocpp/cufile_info.h @@ -0,0 +1,22 @@ +/* Copyright (c) 2024, NVIDIA CORPORATION. All rights reserved. + + NVIDIA CORPORATION and its licensors retain all intellectual property + and proprietary rights in and to this software, related documentation + and any modifications thereto. Any use, reproduction, disclosure or + distribution of this software and related documentation without an express + license agreement from NVIDIA CORPORATION is strictly prohibited. + */ + +#ifndef __CUFILE_INFO_H_ +#define __CUFILE_INFO_H_ + +#define CUFILE_DLL_PUBLIC __attribute__ ((visibility ("default"))) + +#include + +namespace cuFileInfo { + ssize_t cuFileGetBufferSize(void *ptr); + CUmemorytype cuFileGetMemoryType(const void *ptr); +} + +#endif diff --git a/include/miniocpp/http.h b/include/miniocpp/http.h index a3754a3d..c23c5537 100644 --- a/include/miniocpp/http.h +++ b/include/miniocpp/http.h @@ -53,7 +53,12 @@ struct Url { host(std::move(host)), port(port), path(std::move(path)), - query_string(std::move(query_string)) {} + query_string(std::move(query_string)) {}; + explicit Url(bool https, std::string host, unsigned int port) + : https(https), + host(std::move(host)), + port(port) {}; + ~Url() = default; explicit operator bool() const { return !host.empty(); } diff --git a/include/miniocpp/nvidia-cufile.h b/include/miniocpp/nvidia-cufile.h new file mode 100644 index 00000000..ec5693ad --- /dev/null +++ b/include/miniocpp/nvidia-cufile.h @@ -0,0 +1,593 @@ +/* + * Copyright 1993-2020 NVIDIA Corporation. All rights reserved. + * + * NOTICE TO LICENSEE: + * + * This source code and/or documentation ("Licensed Deliverables") are + * subject to NVIDIA intellectual property rights under U.S. and + * international Copyright laws. + * + * These Licensed Deliverables contained herein is PROPRIETARY and + * CONFIDENTIAL to NVIDIA and is being provided under the terms and + * conditions of a form of NVIDIA software license agreement by and + * between NVIDIA and Licensee ("License Agreement") or electronically + * accepted by Licensee. Notwithstanding any terms or conditions to + * the contrary in the License Agreement, reproduction or disclosure + * of the Licensed Deliverables to any third party without the express + * written consent of NVIDIA is prohibited. + * + * NOTWITHSTANDING ANY TERMS OR CONDITIONS TO THE CONTRARY IN THE + * LICENSE AGREEMENT, NVIDIA MAKES NO REPRESENTATION ABOUT THE + * SUITABILITY OF THESE LICENSED DELIVERABLES FOR ANY PURPOSE. IT IS + * PROVIDED "AS IS" WITHOUT EXPRESS OR IMPLIED WARRANTY OF ANY KIND. + * NVIDIA DISCLAIMS ALL WARRANTIES WITH REGARD TO THESE LICENSED + * DELIVERABLES, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY, + * NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE. + * NOTWITHSTANDING ANY TERMS OR CONDITIONS TO THE CONTRARY IN THE + * LICENSE AGREEMENT, IN NO EVENT SHALL NVIDIA BE LIABLE FOR ANY + * SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, OR ANY + * DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, + * WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS + * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE + * OF THESE LICENSED DELIVERABLES. + * + * U.S. Government End Users. These Licensed Deliverables are a + * "commercial item" as that term is defined at 48 C.F.R. 2.101 (OCT + * 1995), consisting of "commercial computer software" and "commercial + * computer software documentation" as such terms are used in 48 + * C.F.R. 12.212 (SEPT 1995) and is provided to the U.S. Government + * only as a commercial end item. Consistent with 48 C.F.R.12.212 and + * 48 C.F.R. 227.7202-1 through 227.7202-4 (JUNE 1995), all + * U.S. Government End Users acquire the Licensed Deliverables with + * only those rights set forth herein. + * + * Any use of the Licensed Deliverables in individual and commercial + * software must include, in the user documentation and internal + * comments to the code, the above Disclaimer and U.S. Government End + * Users Notice. + */ + +/** + * @file cufile.h + * @brief cuFile C APIs + * + * This file contains all the C APIs to perform GPUDirect Storage supported IO operations + */ + +#if __cplusplus +extern "C" +{ +#endif + +/// @cond DOXYGEN_SKIP_MACRO +#ifndef __CUFILE_H_ +#define __CUFILE_H_ + +#include +#include +#include "cuda.h" +#include +#include + +#define CUFILEOP_BASE_ERR 5000 + +//Note :Data path errors are captured via standard error codes +#define CUFILEOP_STATUS_ENTRIES \ + CUFILE_OP(0, CU_FILE_SUCCESS, cufile success) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 1, CU_FILE_DRIVER_NOT_INITIALIZED, nvidia-fs driver is not loaded) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 2, CU_FILE_DRIVER_INVALID_PROPS, invalid property) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 3, CU_FILE_DRIVER_UNSUPPORTED_LIMIT, property range error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 4, CU_FILE_DRIVER_VERSION_MISMATCH, nvidia-fs driver version mismatch) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 5, CU_FILE_DRIVER_VERSION_READ_ERROR, nvidia-fs driver version read error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 6, CU_FILE_DRIVER_CLOSING, driver shutdown in progress) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 7, CU_FILE_PLATFORM_NOT_SUPPORTED, GPUDirect Storage not supported on current platform) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 8, CU_FILE_IO_NOT_SUPPORTED, GPUDirect Storage not supported on current file) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 9, CU_FILE_DEVICE_NOT_SUPPORTED, GPUDirect Storage not supported on current GPU) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 10, CU_FILE_NVFS_DRIVER_ERROR, nvidia-fs driver ioctl error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 11, CU_FILE_CUDA_DRIVER_ERROR, CUDA Driver API error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 12, CU_FILE_CUDA_POINTER_INVALID, invalid device pointer) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 13, CU_FILE_CUDA_MEMORY_TYPE_INVALID, invalid pointer memory type) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 14, CU_FILE_CUDA_POINTER_RANGE_ERROR, pointer range exceeds allocated address range) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 15, CU_FILE_CUDA_CONTEXT_MISMATCH, cuda context mismatch) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 16, CU_FILE_INVALID_MAPPING_SIZE, access beyond maximum pinned size) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 17, CU_FILE_INVALID_MAPPING_RANGE, access beyond mapped size) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 18, CU_FILE_INVALID_FILE_TYPE, unsupported file type) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 19, CU_FILE_INVALID_FILE_OPEN_FLAG, unsupported file open flags) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 20, CU_FILE_DIO_NOT_SET, fd direct IO not set) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 22, CU_FILE_INVALID_VALUE, invalid arguments) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 23, CU_FILE_MEMORY_ALREADY_REGISTERED, device pointer already registered) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 24, CU_FILE_MEMORY_NOT_REGISTERED, device pointer lookup failure) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 25, CU_FILE_PERMISSION_DENIED, driver or file access error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 26, CU_FILE_DRIVER_ALREADY_OPEN, driver is already open) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 27, CU_FILE_HANDLE_NOT_REGISTERED, file descriptor is not registered) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 28, CU_FILE_HANDLE_ALREADY_REGISTERED, file descriptor is already registered) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 29, CU_FILE_DEVICE_NOT_FOUND, GPU device not found) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 30, CU_FILE_INTERNAL_ERROR, internal error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 31, CU_FILE_GETNEWFD_FAILED, failed to obtain new file descriptor) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 33, CU_FILE_NVFS_SETUP_ERROR, NVFS driver initialization error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 34, CU_FILE_IO_DISABLED, GPUDirect Storage disabled by config on current file)\ + CUFILE_OP(CUFILEOP_BASE_ERR + 35, CU_FILE_BATCH_SUBMIT_FAILED, failes to submit batch operation)\ + CUFILE_OP(CUFILEOP_BASE_ERR + 36, CU_FILE_GPU_MEMORY_PINNING_FAILED, Failed to allocate pinned GPU Memory) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 37, CU_FILE_IO_MAX_ERROR, GPUDirect Storage Max Error) + + +/** + * @brief cufileop status enum + * + * @note on success the error code is set to @ref CU_FILE_SUCCESS. + * @note The error code can be inspected using @ref IS_CUFILE_ERR and @ref CUFILE_ERRSTR. + * @note The error code if set to @ref CU_FILE_CUDA_DRIVER_ERROR, then cuda error can be inspected using @ref IS_CUDA_ERR and @ref CU_FILE_CUDA_ERR. + * @note Data path errors are captured via standard error codes + */ +typedef enum CUfileOpError { + /// @cond DOXYGEN_SKIP_MACRO + #define CUFILE_OP(code, name, string) name = code, + CUFILEOP_STATUS_ENTRIES + #undef CUFILE_OP + ///@endcond +} CUfileOpError; + +/// @endcond + +/** + * @brief cufileop status string + */ +static inline const char *cufileop_status_error(CUfileOpError status) +{ + switch (status) { + /// @cond DOXYGEN_SKIP_MACRO + #define CUFILE_OP(code, name, string) \ + case name: return #string; + CUFILEOP_STATUS_ENTRIES + #undef CUFILE_OP + ///@endcond + default:return "unknown cufile error"; + } +} + +/** + * @brief cufileop status string + */ +typedef struct CUfileError { + + CUfileOpError err; // cufile error + + CUresult cu_err; // cuda driver error + +}CUfileError_t; + +/** + * @brief error macros to inspect error status of type @ref CUfileOpError + */ + +#define IS_CUFILE_ERR(err) \ + (abs((err)) > CUFILEOP_BASE_ERR) + +#define CUFILE_ERRSTR(err) \ + cufileop_status_error((CUfileOpError)abs((err))) + +#define IS_CUDA_ERR(status) \ + ((status).err == CU_FILE_CUDA_DRIVER_ERROR) + +#define CU_FILE_CUDA_ERR(status) ((status).cu_err) + +/* driver properties */ +typedef enum CUfileDriverStatusFlags { + CU_FILE_LUSTRE_SUPPORTED = 0, /*!< Support for DDN LUSTRE */ + + CU_FILE_WEKAFS_SUPPORTED = 1, /*!< Support for WEKAFS */ + + CU_FILE_NFS_SUPPORTED = 2, /*!< Support for NFS */ + + CU_FILE_GPFS_SUPPORTED = 3, /*! < Support for GPFS */ + + CU_FILE_NVME_SUPPORTED = 4, /*!< Support for NVMe */ + + CU_FILE_NVMEOF_SUPPORTED = 5, /*!< Support for NVMeOF */ + + CU_FILE_SCSI_SUPPORTED = 6, /*!< Support for SCSI */ + + CU_FILE_SCALEFLUX_CSD_SUPPORTED = 7, /*!< Support for Scaleflux CSD*/ + + CU_FILE_NVMESH_SUPPORTED = 8, /*!< Support for NVMesh Block Dev*/ + CU_FILE_BEEGFS_SUPPORTED = 9, /*!< Support for BeeGFS */ + +}CUfileDriverStatusFlags_t; + +typedef enum CUfileDriverControlFlags { + CU_FILE_USE_POLL_MODE = 0 , /*!< use POLL mode. properties.use_poll_mode*/ + + CU_FILE_ALLOW_COMPAT_MODE = 1/*!< allow COMPATIBILITY mode. properties.allow_compat_mode*/ + +}CUfileDriverControlFlags_t; + +typedef enum CUfileFeatureFlags { + CU_FILE_DYN_ROUTING_SUPPORTED = 0, /*!< Support for Dynamic routing to handle devices across the PCIe bridges */ + + CU_FILE_BATCH_IO_SUPPORTED = 1, /*!< Unsupported */ + + CU_FILE_STREAMS_SUPPORTED = 2 /*!< Unsupported */ + +}CUfileFeatureFlags_t; + +typedef struct CUfileDrvProps { + struct { + unsigned int major_version; + + unsigned int minor_version; + + size_t poll_thresh_size; + + size_t max_direct_io_size; + + unsigned int dstatusflags; + + unsigned int dcontrolflags; + + } nvfs; + + unsigned int fflags; + + unsigned int max_device_cache_size; + + unsigned int per_buffer_cache_size; + + unsigned int max_device_pinned_mem_size; + + unsigned int max_batch_io_size; + unsigned int max_batch_io_timeout_msecs; +}CUfileDrvProps_t; + +typedef struct sockaddr sockaddr_t; + +typedef struct cufileRDMAInfo +{ + int version; + int desc_len; + const char *desc_str; +} cufileRDMAInfo_t; + +#define CU_FILE_RDMA_REGISTER 1 +#define CU_FILE_RDMA_RELAXED_ORDERING (1<<1) + +typedef struct CUfileFSOps { + /* NULL means discover using fstat */ + const char* (*fs_type) (const void *handle); + + /* list of host addresses to use, NULL means no restriction */ + int (*getRDMADeviceList)(const void *handle, sockaddr_t **hostaddrs); + + /* -1 no pref */ + int (*getRDMADevicePriority)(const void *handle, char*, size_t, + loff_t, const sockaddr_t* hostaddr); + + /* NULL means try VFS */ + ssize_t (*read) (const void *handle, char*, size_t, loff_t, const cufileRDMAInfo_t*); + ssize_t (*write) (const void *handle, const char *, size_t, loff_t , const cufileRDMAInfo_t*); +}CUfileFSOps_t; + +/* File Handle */ +enum CUfileFileHandleType { + CU_FILE_HANDLE_TYPE_OPAQUE_FD = 1, /*!< Linux based fd */ + + CU_FILE_HANDLE_TYPE_OPAQUE_WIN32 = 2, /*!< Windows based handle (unsupported) */ + + CU_FILE_HANDLE_TYPE_USERSPACE_FS = 3, /* Userspace based FS */ +}; + +typedef struct CUfileDescr_t { + enum CUfileFileHandleType type; /* type of file being registered */ + union { + int fd; /* Linux */ + void *handle; /* Windows */ + } handle; + const CUfileFSOps_t *fs_ops; /* file system operation table */ +}CUfileDescr_t; + +/** + * @brief File handle type + * + */ +typedef void* CUfileHandle_t; + + +#pragma GCC visibility push(default) + +/** + * @brief cuFileHandleRegister is required, and performs extra checking that is memoized to provide increased performance on later cuFile operations. + * + * @param fh @ref CUfileHandle_t opaque file handle for IO operations + * @param descr @ref CUfileDescr_t file descriptor (OS agnostic) + * + * @return CU_FILE_SUCCESS on successful completion. fh will be updated for use in @ref cuFileRead, @ref cuFileWrite, @ref cuFileHandleDeregister + * @return CU_FILE_DRIVER_NOT_INITIALIZED on failure to load driver + * @return CU_FILE_IO_NOT_SUPPORTED - if filesystem is not supported + * @return CU_FILE_INVALID_VALUE if null or bad api arguments + * @return CU_FILE_INVALID_FILE_OPEN_FLAG if file is opened with unsupported modes like no O_DIRECT + * @return CU_FILE_INVALID_FILE_TYPE if filepath is not valid or is not a regular file + * @return CU_FILE_HANDLE_ALREADY_REGISTERED if file handle/descriptor is already registered + * + * Description + * cuFileHandleRegister registers the open file descriptor for use with cuFile IO operations. + * + * This API will ensure that the file’s descriptor is checked for GPUDirect Storage support and returns a valid file handle on CU_FILE_SUCCESS. + * + * @note the file needs to be opened in O_DIRECT mode to support GPUDirect Storage. + * + * @see cuFileRead + * @see cuFileWrite + * @see cuFileHandleDeregister + * + */ +CUfileError_t cuFileHandleRegister(CUfileHandle_t *fh, CUfileDescr_t *descr); + +/** + * @brief releases a registered filehandle from cuFile + * + * @param fh @ref CUfileHandle_t file handle + * + * @return void + * + * @see cuFileHandleRegister + */ +void cuFileHandleDeregister(CUfileHandle_t fh); + +/** + * @brief register an existing cudaMalloced memory with cuFile to pin for GPUDirect Storage access. + * + * @param devPtr_base device pointer to allocated + * @param length size of memory region from the above specified devPtr + * @param flags CU_FILE_RDMA_REGISTER + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_NVFS_DRIVER_ERROR + * @return CU_FILE_INVALID_VALUE + * @return CU_FILE_CUDA_ERROR for unsuported memory type + * @return CU_FILE_MEMORY_ALREADY_REGISTERED on error + * @return CU_FILE_GPU_MEMORY_PINNING_FAILED if not enough pinned memory is available + * @note This memory will be use to perform GPU direct DMA from the supported storage. + * @warning This API is intended for usecases where the memory is used as streaming buffer that is reused across multiple cuFile IO operations before calling @ref cuFileBufDeregister + * + * @see cuFileBufDeregister + * @see cuFileRead + * @see cuFileWrite + */ +CUfileError_t cuFileBufRegister(const void *devPtr_base, size_t length, int flags); + +/** + * @brief deregister an already registered device memory from cuFile + * + * @param devPtr_base device pointer to deregister + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_INVALID_VALUE on invalid memory pointer or unregistered memory pointer + * + * @see cuFileBufRegister + * @see cuFileRead + * @see cuFileWrite + */ + +CUfileError_t cuFileBufDeregister(const void *devPtr_base); + +/** + * @brief read data from a registered file handle to a specified device memory + * + * @param fh @ref CUfileHandle_t opaque file handle + * @param devPtr_base base address of buffer in device memory + * @param size size bytes to read + * @param file_offset file-offset from begining of the file + * @param devPtr_offset offset relative to the devPtr_base pointer to read into. + * + * @return size of bytes successfully read + * @return -1 on error, in which case errno is set to indicate filesystem errors. + * @return all other errors will return a negative integer value of @ref CUfileOpError enum value. + * + * @note If the devPtr is not registered with @ref cuFileBufRegister, the data will be buffered through preallocated pinned buffers. + * @note This is useful for applications that need to perform IO to unaligned file offsets and/or size. This is also recommended + * for cases where the BAR1 memory size is smaller than the size of the allocated memory. + * + * @see cuFileBufRegister + * @see cuFileHandleRegister + * @see cuFileWrite + */ + +ssize_t cuFileRead(CUfileHandle_t fh, void *devPtr_base, size_t size, off_t file_offset, off_t devPtr_offset); + +/** + * @brief write data from a specified device memory to a registered file handle + * + * @param fh @ref CUfileHandle_t opaque file handle + * @param devPtr_base base address of buffer in device memory + * @param size size bytes to write + * @param file_offset file-offset from begining of the file + * @param devPtr_offset offset relative to the devPtr_base pointer to read into. + * + * @return size of bytes successfully written + * @return -1 on error, in which case errno is set to indicate filesystem errors. + * @return all other errors will return a negative integer value of @ref CUfileOpError enum value. + * + * @note If the devPtr is not registered with @ref cuFileBufRegister, the data will be buffered through preallocated pinned buffers. + * @note This is useful for applications that need to perform IO to unaligned file offsets and/or size. This is also recommended + * for cases where the BAR1 memory size is smaller than the size of the allocated memory. + * + * @see cuFileBufRegister + * @see cuFileHandleRegister + * @see cuFileRead + */ + +ssize_t cuFileWrite(CUfileHandle_t fh, const void *devPtr_base, size_t size, off_t file_offset, off_t devPtr_offset); + +// CUFile Driver APIs + +/** + * @brief + * Initialize the cuFile library and open the nvidia-fs driver + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_NOT_INITIALIZED + * @return CU_FILE_DRIVER_VERSION_MISMATCH on driver version mismatch error + * + * @see cuFileDriverClose + */ +CUfileError_t cuFileDriverOpen(void); + +CUfileError_t cuFileDriverClose(void); +#define cuFileDriverClose cuFileDriverClose_v2 +/** + * @brief + * reset the cuFile library and release the nvidia-fs driver + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_CLOSING if there are any active IO operations using @ref cuFileRead or @ref cuFileWrite + * + * @see cuFileDriverOpen + */ +CUfileError_t cuFileDriverClose(void); + +/** + * @brief + * returns use count of cufile drivers at that moment by the process. + */ +long cuFileUseCount(void); + +/** + * @brief + * Gets the Driver session properties + * + * @return CU_FILE_SUCCESS on success + * + * @see cuFileDriverSetPollMode + * @see cuFileDriverSetMaxDirectIOSize + * @see cuFileDriverSetMaxCacheSize + * @see cuFileDriverSetMaxPinnedMemSize + */ +CUfileError_t cuFileDriverGetProperties(CUfileDrvProps_t *props); + +/** + * @brief + * Sets whether the Read/Write APIs use polling to do IO operations + * + * @param poll boolean to indicate whether to use poll mode or not + * @param poll_threshold_size max IO size to use for POLLING mode in KB + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized + * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on error + * + * @warning This is an advanced command and should be tuned based on available system memory + * + * @see cuFileDriverGetProperties + */ +CUfileError_t cuFileDriverSetPollMode(bool poll, size_t poll_threshold_size); + +/** + * @brief + * Control parameter to set max IO size(KB) used by the library to talk to nvidia-fs driver + * + * @param max_direct_io_size maximum allowed direct io size in KB + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized + * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on error + * + * @warning This is an advanced command and should be tuned based on available system memory + * + * @see cuFileDriverGetProperties + * + */ +CUfileError_t cuFileDriverSetMaxDirectIOSize(size_t max_direct_io_size); + +/** + * @brief + * Control parameter to set maximum GPU memory reserved per device by the library for internal buffering + * + * @param max_cache_size The maximum GPU buffer space per device used for internal use in KB + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized + * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on error + * + * @warning This is an advanced command and should be tuned based on supported GPU memory + * + * @see cuFileDriverGetProperties + */ +CUfileError_t cuFileDriverSetMaxCacheSize(size_t max_cache_size); + +/** + * @brief + * Sets maximum buffer space that is pinned in KB for use by @ref cuFileBufRegister + * + * @param max_pinned_size maximum buffer space that is pinned in KB + * + * @return CU_FILE_SUCCESS on success + * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized + * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on error + * + * @warning This is an advanced command and should be tuned based on supported GPU memory + * + * @see cuFileDriverGetProperties + * + */ +CUfileError_t cuFileDriverSetMaxPinnedMemSize(size_t max_pinned_size); + + +//Experimental Batch API's + + +typedef enum CUfileOpcode { + CUFILE_READ = 0, + CUFILE_WRITE +}CUfileOpcode_t; + +typedef enum CUFILEStatus_enum { + CUFILE_WAITING = 0x000001, /* required value prior to submission */ + CUFILE_PENDING = 0x000002, /* once enqueued */ + CUFILE_INVALID = 0x000004, /* request was ill-formed or could not be enqueued */ + CUFILE_CANCELED = 0x000008, /* request successfully canceled */ + CUFILE_COMPLETE = 0x0000010, /* request successfully completed */ + CUFILE_TIMEOUT = 0x0000020, /* request timed out */ + CUFILE_FAILED = 0x0000040 /* unable to complete */ +}CUfileStatus_t; + +typedef enum cufileBatchMode { + CUFILE_BATCH = 1, +} CUfileBatchMode_t; + +typedef struct CUfileIOParams { + CUfileBatchMode_t mode; // Must be the very first field. + union { + struct { + void *devPtr_base; + off_t file_offset; + off_t devPtr_offset; + size_t size; + }batch; + }u; + CUfileHandle_t fh; + CUfileOpcode_t opcode; + void *cookie; +}CUfileIOParams_t; + +typedef struct CUfileIOEvents { + void *cookie; + CUfileStatus_t status; /* status of the operation */ + size_t ret; /* -ve error or amount of I/O done. */ +}CUfileIOEvents_t; + +typedef void* CUfileBatchHandle_t; + +CUfileError_t cuFileBatchIOSetUp(CUfileBatchHandle_t *batch_idp, unsigned nr); +CUfileError_t cuFileBatchIOSubmit(CUfileBatchHandle_t batch_idp, unsigned nr, CUfileIOParams_t *iocbp, unsigned int flags); +CUfileError_t cuFileBatchIOGetStatus(CUfileBatchHandle_t batch_idp, unsigned min_nr, unsigned* nr, + CUfileIOEvents_t *iocbp, struct timespec* timeout); +CUfileError_t cuFileBatchIOCancel(CUfileBatchHandle_t batch_idp); +void cuFileBatchIODestroy(CUfileBatchHandle_t batch_idp); + +#pragma GCC visibility pop + +/// @cond DOXYGEN_SKIP_MACRO +#endif // CUFILE_H +/// @endcond +#if __cplusplus +} +#endif diff --git a/include/miniocpp/nvidia-cuobjclient.h b/include/miniocpp/nvidia-cuobjclient.h new file mode 100644 index 00000000..364d6516 --- /dev/null +++ b/include/miniocpp/nvidia-cuobjclient.h @@ -0,0 +1,236 @@ +/* + * SPDX-FileCopyrightText: Copyright (c) 2024 NVIDIA CORPORATION & AFFILIATES. All rights reserved. + * SPDX-License-Identifier: LicenseRef-NvidiaProprietary + * + * NVIDIA CORPORATION, its affiliates and licensors retain all intellectual + * property and proprietary rights in and to this material, related + * documentation and any modifications thereto. Any use, reproduction, + * disclosure or distribution of this material and related documentation + * without an express license agreement from NVIDIA CORPORATION or + * its affiliates is strictly prohibited. + */ +#ifndef _CUOBJCLIENT_H_ +#define _CUOBJCLIENT_H_ + +#define OBJ_RDMA_V1 "CUOBJ" + +#include +#include +#include +#include "request.h" +#include "nvidia-cufile.h" +#include "providers.h" + +/** + * @brief cuObject error numbers. + * + * @note These errors will be expanded in future + * + */ + +typedef enum cuObjErr_enum { + CU_OBJ_SUCCESS =0, /**< Operation successfully completed */ + CU_OBJ_FAIL =1, /**< Operation failed */ +} cuObjErr_t; + +/** + * @brief cuObject RDMA descriptor protocol version + * + */ +typedef enum cuObjProto_enum { + CUOBJ_PROTO_RDMA_DC_V1=1001, /**< RDMA support version 1 */ + CUOBJ_PROTO_MAX +} cuObjProto_t; + + +/** + * @brief cuObject Operation type + * + */ +typedef enum cuObjOpType_enum { + CUOBJ_GET = 0, /**< GET operation */ + CUOBJ_PUT = 1, /**< PUT operation */ + CUOBJ_INVALID=9999 +} cuObjOpType_t; + +/** + * @brief cuObject Operation callbacks + * This struct specifies the callback interfaces used by cuObjClient class object during IO operations. + * @note The callbacks can be called from a different thread than the caller thread. user must lock any shared resources + * that can be used concurrently across multiple callers. + */ +typedef struct CUObjIOOps { + /** + * @brief cuObject GET callback + * @param handle cookie to the user context provided in the cuObjGet call. cuObjClient::getCtx(handle) should be called for getting the user context + * @param ptr pointer to the start of the memory chunk + * @param size size of the memory chunk being read. + * @param offset starting object offset for this memory chunk. + * @param cufileRDMAInfo_t Pointer to a RDMA memory descriptor string + * + * @return size of the data read on success or negative -1, the data read is obtained from control path + * + * @note offset will be set to zero for cases where the MaxReqCallbackSize is equal to or greater the cuObjectGet call size + * @note size will be set to total requested size n cuObjectGet for cases where the MaxReqCallbackSize is equal to or greater the cuObjectGet call size + * + * + * @see cuObjClient::cuObjGet + */ + + ssize_t (*get) (const void *handle, char *ptr, size_t size, loff_t offset, const cufileRDMAInfo_t*); + /** + * @brief cuObject PUT callback + * @param handle to the user context provided in the cuObjPut call. cuObjClient::getCtx(handle) should be called for getting the user context + * @param ptr pointer to the start of the memory chunk + * @param size size of the memory chunk being written + * @param offset starting object offset for this memory chunk. + * @param cufileRDMAInfo_t Pointer to a RDMA memory descriptor string + * + * @return size of the data written on success or negative -1, the data written is obtained from control path + * + * @note offset will be set to zero for cases where the MaxReqCallbackSize is equal to or greater the cuObjectPut call size + * @note size will be set to total requested size n cuObjectGet for cases where the MaxReqCallbackSize is equal to or greater the cuObjectPut call size + * + * + * @see cuObjClient::cuObjPut + */ + + ssize_t (*put) (const void *handle, const char *ptr, size_t size, loff_t offset, const cufileRDMAInfo_t*); +}CUObjOps_t; + +/** + * @brief cuObject memory type + * + */ +typedef enum cuObjMemoryType_enum { + CUOBJ_MEMORY_SYSTEM = 0, + CUOBJ_MEMORY_CUDA_MANAGED = 1, + CUOBJ_MEMORY_CUDA_DEVICE = 2, + CUOBJ_MEMORY_UNKNOWN = 3 +} cuObjMemoryType_t; + +/** + * @brief cuObjClient class. + * + * cuObjClient Provides client side APIs to prepare PUT/GET operations for out-of-band RDMA IO operations. + * The user of this object is expected to implement a set of callback interfaces specified in CUObjIOOps. + * Once the client object is created, user is expected to optionally register the memory for RDMA and + * perform PUT and GET operations on this client object. + * The cuObjClient will validate the memory and prepare a memory region for RDMA transer. + * The cuObjClient will call one or more callback operations with relevant RDMA information. + * The user is expected to relay the RDMA information and other data to cuObjServer using standard control path. + * After the IO completion, the callback should return the total data read or written in this context. + * The client object may perform additional operations before the cuObjectPut/cuObjectGet operation finishes. + */ + +class cuObjClient { +public: + + /** + * @brief constructor for cuObjClient class. + * @param ops callback reference to CUObjIOOps + * @param proto RDMA descriptor protocol used for this client. defaults to CUOBJ_PROTO_RDMA_DC_V1 + */ + cuObjClient(CUObjOps_t& ops, cuObjProto_t proto=CUOBJ_PROTO_RDMA_DC_V1); + ~cuObjClient(); + + /** + * @brief Acquire a RDMA memory descriptor for the user memory + * @param ptr start address of user memory + * @param size size of memory that needs pinning starting from the start address of user memory + */ + cuObjErr_t cuMemObjGetDescriptor(void *ptr, size_t size); + /** + * @brief Get a RDMA memory descriptor for the user memory + * @param ptr start address of user memory + * @return max size of the callback for this memory pointer + * @note: The size can be smaller than allocated memory if the memory is not registered or + * the underlying RDMA subsystem does not allow for pinning/transfer of the entire memory in a single callback + */ + ssize_t cuMemObjGetMaxRequestCallbackSize(void *ptr); + + /** + * @brief release the RDMA memory descriptor for the user memory + * @param ptr start address of user memory used during cuMemObjGetDescriptor + * @return error status if the memory cannot be unregistered + */ + + cuObjErr_t cuMemObjPutDescriptor(void *ptr); + + /** + * @brief Get the user context provided in the cuObjGet and cuObjPut from handle in the callback + * @param handle pointer to the handle from the callback + * @return void pointer to the user context. + */ + + static void* getCtx(const void *handle); + + /** + * @brief API to perform GET operation using cuObject + * @param ctx pointer to a user control context, used in GET callback + * @param ptr pointer to a user memory + * @param size size of the GET operation + * @param offset currently set to 0. reserved for future use + * @param buf_offset currently set to 0. reserved for future use + * @return data returned by the cuObjServer or a negative error code. + */ + + ssize_t cuObjGet(void *ctx, void *ptr, size_t size, loff_t offset=0, loff_t buf_offset=0); + /** + * @brief API to perform PUT operation using cuObject + * @param ctx pointer to a user control context, used in PUT callback + * @param ptr pointer to a user memory + * @param size size of the PUT operation + * @param offset currently set to 0. reserved for future use + * @param buf_offset currently set to 0. reserved for future use + * @return data returned by the cuObjServer or a negative error code. + */ + + ssize_t cuObjPut(void *ctx, void *ptr, size_t size, loff_t offset=0, loff_t buf_offset=0); + /** + * @brief check if the client is connected + */ + bool isConnected(void); + /** + * @brief setup telemetry output stream + */ + static void setupTelemetry(bool use_OTEL, std::ostream *os); + + /** + * @brief setup telemetry stream logging level + */ + static void setTelemFlags(unsigned flags); + + /** + * @brief Get the memory type of a given pointer + * @param ptr pointer to the memory + * @return memory type + */ + static cuObjMemoryType_t getMemoryType(const void* ptr); + +private: + bool cuObjRegisterKey(); + void* _ctx; + CUfileHandle_t _cufh; + CUfileFSOps _objectFsOps; + bool _connected; + cuObjProto_t _proto; + static std::mutex _telemMutex; + static std::ostream *_os; + static int _telemRefCnt; + static unsigned _debugFlags; + static bool _useOTEL; +}; + +typedef struct s3_rdma_client_ctx { + minio::creds::Provider* const provider = nullptr; + std::string bucket; + std::string object; + std::string uploadId; + size_t partNumber; + std::string etag; + minio::s3::BaseUrl url; + cuObjOpType_t op; +} s3_rdma_client_ctx_t; + +#endif diff --git a/include/miniocpp/rdma-httplib.h b/include/miniocpp/rdma-httplib.h new file mode 100644 index 00000000..121ce349 --- /dev/null +++ b/include/miniocpp/rdma-httplib.h @@ -0,0 +1,10154 @@ +// +// httplib.h +// +// Copyright (c) 2024 Yuji Hirose. All rights reserved. +// MIT License +// + +#ifndef CPPHTTPLIB_HTTPLIB_H +#define CPPHTTPLIB_HTTPLIB_H + +#define CPPHTTPLIB_VERSION "0.18.0" + +/* + * Configuration + */ + +#ifndef CPPHTTPLIB_KEEPALIVE_TIMEOUT_SECOND +#define CPPHTTPLIB_KEEPALIVE_TIMEOUT_SECOND 5 +#endif + +#ifndef CPPHTTPLIB_KEEPALIVE_MAX_COUNT +#define CPPHTTPLIB_KEEPALIVE_MAX_COUNT 100 +#endif + +#ifndef CPPHTTPLIB_CONNECTION_TIMEOUT_SECOND +#define CPPHTTPLIB_CONNECTION_TIMEOUT_SECOND 300 +#endif + +#ifndef CPPHTTPLIB_CONNECTION_TIMEOUT_USECOND +#define CPPHTTPLIB_CONNECTION_TIMEOUT_USECOND 0 +#endif + +#ifndef CPPHTTPLIB_SERVER_READ_TIMEOUT_SECOND +#define CPPHTTPLIB_SERVER_READ_TIMEOUT_SECOND 5 +#endif + +#ifndef CPPHTTPLIB_SERVER_READ_TIMEOUT_USECOND +#define CPPHTTPLIB_SERVER_READ_TIMEOUT_USECOND 0 +#endif + +#ifndef CPPHTTPLIB_SERVER_WRITE_TIMEOUT_SECOND +#define CPPHTTPLIB_SERVER_WRITE_TIMEOUT_SECOND 5 +#endif + +#ifndef CPPHTTPLIB_SERVER_WRITE_TIMEOUT_USECOND +#define CPPHTTPLIB_SERVER_WRITE_TIMEOUT_USECOND 0 +#endif + +#ifndef CPPHTTPLIB_CLIENT_READ_TIMEOUT_SECOND +#define CPPHTTPLIB_CLIENT_READ_TIMEOUT_SECOND 300 +#endif + +#ifndef CPPHTTPLIB_CLIENT_READ_TIMEOUT_USECOND +#define CPPHTTPLIB_CLIENT_READ_TIMEOUT_USECOND 0 +#endif + +#ifndef CPPHTTPLIB_CLIENT_WRITE_TIMEOUT_SECOND +#define CPPHTTPLIB_CLIENT_WRITE_TIMEOUT_SECOND 5 +#endif + +#ifndef CPPHTTPLIB_CLIENT_WRITE_TIMEOUT_USECOND +#define CPPHTTPLIB_CLIENT_WRITE_TIMEOUT_USECOND 0 +#endif + +#ifndef CPPHTTPLIB_IDLE_INTERVAL_SECOND +#define CPPHTTPLIB_IDLE_INTERVAL_SECOND 0 +#endif + +#ifndef CPPHTTPLIB_IDLE_INTERVAL_USECOND +#ifdef _WIN32 +#define CPPHTTPLIB_IDLE_INTERVAL_USECOND 10000 +#else +#define CPPHTTPLIB_IDLE_INTERVAL_USECOND 0 +#endif +#endif + +#ifndef CPPHTTPLIB_REQUEST_URI_MAX_LENGTH +#define CPPHTTPLIB_REQUEST_URI_MAX_LENGTH 8192 +#endif + +#ifndef CPPHTTPLIB_HEADER_MAX_LENGTH +#define CPPHTTPLIB_HEADER_MAX_LENGTH 8192 +#endif + +#ifndef CPPHTTPLIB_REDIRECT_MAX_COUNT +#define CPPHTTPLIB_REDIRECT_MAX_COUNT 20 +#endif + +#ifndef CPPHTTPLIB_MULTIPART_FORM_DATA_FILE_MAX_COUNT +#define CPPHTTPLIB_MULTIPART_FORM_DATA_FILE_MAX_COUNT 1024 +#endif + +#ifndef CPPHTTPLIB_PAYLOAD_MAX_LENGTH +#define CPPHTTPLIB_PAYLOAD_MAX_LENGTH ((std::numeric_limits::max)()) +#endif + +#ifndef CPPHTTPLIB_FORM_URL_ENCODED_PAYLOAD_MAX_LENGTH +#define CPPHTTPLIB_FORM_URL_ENCODED_PAYLOAD_MAX_LENGTH 8192 +#endif + +#ifndef CPPHTTPLIB_RANGE_MAX_COUNT +#define CPPHTTPLIB_RANGE_MAX_COUNT 1024 +#endif + +#ifndef CPPHTTPLIB_TCP_NODELAY +#define CPPHTTPLIB_TCP_NODELAY false +#endif + +#ifndef CPPHTTPLIB_IPV6_V6ONLY +#define CPPHTTPLIB_IPV6_V6ONLY false +#endif + +#ifndef CPPHTTPLIB_RECV_BUFSIZ +#define CPPHTTPLIB_RECV_BUFSIZ size_t(16384u) +#endif + +#ifndef CPPHTTPLIB_COMPRESSION_BUFSIZ +#define CPPHTTPLIB_COMPRESSION_BUFSIZ size_t(16384u) +#endif + +#ifndef CPPHTTPLIB_THREAD_POOL_COUNT +#define CPPHTTPLIB_THREAD_POOL_COUNT \ + ((std::max)(8u, std::thread::hardware_concurrency() > 0 \ + ? std::thread::hardware_concurrency() - 1 \ + : 0)) +#endif + +#ifndef CPPHTTPLIB_RECV_FLAGS +#define CPPHTTPLIB_RECV_FLAGS 0 +#endif + +#ifndef CPPHTTPLIB_SEND_FLAGS +#define CPPHTTPLIB_SEND_FLAGS 0 +#endif + +#ifndef CPPHTTPLIB_LISTEN_BACKLOG +#define CPPHTTPLIB_LISTEN_BACKLOG 5 +#endif + +/* + * Headers + */ + +#ifdef _WIN32 +#ifndef _CRT_SECURE_NO_WARNINGS +#define _CRT_SECURE_NO_WARNINGS +#endif //_CRT_SECURE_NO_WARNINGS + +#ifndef _CRT_NONSTDC_NO_DEPRECATE +#define _CRT_NONSTDC_NO_DEPRECATE +#endif //_CRT_NONSTDC_NO_DEPRECATE + +#if defined(_MSC_VER) +#if _MSC_VER < 1900 +#error Sorry, Visual Studio versions prior to 2015 are not supported +#endif + +#pragma comment(lib, "ws2_32.lib") + +#ifdef _WIN64 +using ssize_t = __int64; +#else +using ssize_t = long; +#endif +#endif // _MSC_VER + +#ifndef S_ISREG +#define S_ISREG(m) (((m) & S_IFREG) == S_IFREG) +#endif // S_ISREG + +#ifndef S_ISDIR +#define S_ISDIR(m) (((m) & S_IFDIR) == S_IFDIR) +#endif // S_ISDIR + +#ifndef NOMINMAX +#define NOMINMAX +#endif // NOMINMAX + +#include +#include +#include + +#ifndef WSA_FLAG_NO_HANDLE_INHERIT +#define WSA_FLAG_NO_HANDLE_INHERIT 0x80 +#endif + +using socket_t = SOCKET; +#ifdef CPPHTTPLIB_USE_POLL +#define poll(fds, nfds, timeout) WSAPoll(fds, nfds, timeout) +#endif + +#else // not _WIN32 + +#include +#if !defined(_AIX) && !defined(__MVS__) +#include +#endif +#ifdef __MVS__ +#include +#ifndef NI_MAXHOST +#define NI_MAXHOST 1025 +#endif +#endif +#include +#include +#include +#ifdef __linux__ +#include +#endif +#include +#ifdef CPPHTTPLIB_USE_POLL +#include +#endif +#include +#include +#include +#include +#include +#include +#include + +using socket_t = int; +#ifndef INVALID_SOCKET +#define INVALID_SOCKET (-1) +#endif +#endif //_WIN32 + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +#ifdef _WIN32 +#include + +// these are defined in wincrypt.h and it breaks compilation if BoringSSL is +// used +#undef X509_NAME +#undef X509_CERT_PAIR +#undef X509_EXTENSIONS +#undef PKCS7_SIGNER_INFO + +#ifdef _MSC_VER +#pragma comment(lib, "crypt32.lib") +#endif +#elif defined(CPPHTTPLIB_USE_CERTS_FROM_MACOSX_KEYCHAIN) && defined(__APPLE__) +#include +#if TARGET_OS_OSX +#include +#include +#endif // TARGET_OS_OSX +#endif // _WIN32 + +#include +#include +#include +#include + +#if defined(_WIN32) && defined(OPENSSL_USE_APPLINK) +#include +#endif + +#include +#include + +#if defined(OPENSSL_IS_BORINGSSL) || defined(LIBRESSL_VERSION_NUMBER) +#if OPENSSL_VERSION_NUMBER < 0x1010107f +#error Please use OpenSSL or a current version of BoringSSL +#endif +#define SSL_get1_peer_certificate SSL_get_peer_certificate +#elif OPENSSL_VERSION_NUMBER < 0x30000000L +#error Sorry, OpenSSL versions prior to 3.0.0 are not supported +#endif + +#endif + +#ifdef CPPHTTPLIB_ZLIB_SUPPORT +#include +#endif + +#ifdef CPPHTTPLIB_BROTLI_SUPPORT +#include +#include +#endif + +/* + * Declaration + */ +namespace httplib { + +namespace detail { + +/* + * Backport std::make_unique from C++14. + * + * NOTE: This code came up with the following stackoverflow post: + * https://stackoverflow.com/questions/10149840/c-arrays-and-make-unique + * + */ + +template +typename std::enable_if::value, std::unique_ptr>::type +make_unique(Args &&...args) { + return std::unique_ptr(new T(std::forward(args)...)); +} + +template +typename std::enable_if::value, std::unique_ptr>::type +make_unique(std::size_t n) { + typedef typename std::remove_extent::type RT; + return std::unique_ptr(new RT[n]); +} + +namespace case_ignore { + +inline unsigned char to_lower(int c) { + const static unsigned char table[256] = { + 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, + 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, + 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, + 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, + 60, 61, 62, 63, 64, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, + 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, + 122, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, + 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, + 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, 134, + 135, 136, 137, 138, 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, + 150, 151, 152, 153, 154, 155, 156, 157, 158, 159, 160, 161, 162, 163, 164, + 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175, 176, 177, 178, 179, + 180, 181, 182, 183, 184, 185, 186, 187, 188, 189, 190, 191, 224, 225, 226, + 227, 228, 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, 240, 241, + 242, 243, 244, 245, 246, 215, 248, 249, 250, 251, 252, 253, 254, 223, 224, + 225, 226, 227, 228, 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, + 240, 241, 242, 243, 244, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254, + 255, + }; + return table[(unsigned char)(char)c]; +} + +inline bool equal(const std::string &a, const std::string &b) { + return a.size() == b.size() && + std::equal(a.begin(), a.end(), b.begin(), + [](char ca, char cb) { return to_lower(ca) == to_lower(cb); }); +} + +struct equal_to { + bool operator()(const std::string &a, const std::string &b) const { + return equal(a, b); + } +}; + +struct hash { + size_t operator()(const std::string &key) const { + return hash_core(key.data(), key.size(), 0); + } + + size_t hash_core(const char *s, size_t l, size_t h) const { + return (l == 0) ? h + : hash_core(s + 1, l - 1, + // Unsets the 6 high bits of h, therefore no + // overflow happens + (((std::numeric_limits::max)() >> 6) & + h * 33) ^ + static_cast(to_lower(*s))); + } +}; + +}; // namespace case_ignore + +// This is based on +// "http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2014/n4189". + +struct scope_exit { + explicit scope_exit(std::function &&f) + : exit_function(std::move(f)), execute_on_destruction{true} {} + + scope_exit(scope_exit &&rhs) noexcept + : exit_function(std::move(rhs.exit_function)), + execute_on_destruction{rhs.execute_on_destruction} { + rhs.release(); + } + + ~scope_exit() { + if (execute_on_destruction) { this->exit_function(); } + } + + void release() { this->execute_on_destruction = false; } + +private: + scope_exit(const scope_exit &) = delete; + void operator=(const scope_exit &) = delete; + scope_exit &operator=(scope_exit &&) = delete; + + std::function exit_function; + bool execute_on_destruction; +}; + +} // namespace detail + +enum StatusCode { + // Information responses + Continue_100 = 100, + SwitchingProtocol_101 = 101, + Processing_102 = 102, + EarlyHints_103 = 103, + + // Successful responses + OK_200 = 200, + Created_201 = 201, + Accepted_202 = 202, + NonAuthoritativeInformation_203 = 203, + NoContent_204 = 204, + ResetContent_205 = 205, + PartialContent_206 = 206, + MultiStatus_207 = 207, + AlreadyReported_208 = 208, + IMUsed_226 = 226, + + // Redirection messages + MultipleChoices_300 = 300, + MovedPermanently_301 = 301, + Found_302 = 302, + SeeOther_303 = 303, + NotModified_304 = 304, + UseProxy_305 = 305, + unused_306 = 306, + TemporaryRedirect_307 = 307, + PermanentRedirect_308 = 308, + + // Client error responses + BadRequest_400 = 400, + Unauthorized_401 = 401, + PaymentRequired_402 = 402, + Forbidden_403 = 403, + NotFound_404 = 404, + MethodNotAllowed_405 = 405, + NotAcceptable_406 = 406, + ProxyAuthenticationRequired_407 = 407, + RequestTimeout_408 = 408, + Conflict_409 = 409, + Gone_410 = 410, + LengthRequired_411 = 411, + PreconditionFailed_412 = 412, + PayloadTooLarge_413 = 413, + UriTooLong_414 = 414, + UnsupportedMediaType_415 = 415, + RangeNotSatisfiable_416 = 416, + ExpectationFailed_417 = 417, + ImATeapot_418 = 418, + MisdirectedRequest_421 = 421, + UnprocessableContent_422 = 422, + Locked_423 = 423, + FailedDependency_424 = 424, + TooEarly_425 = 425, + UpgradeRequired_426 = 426, + PreconditionRequired_428 = 428, + TooManyRequests_429 = 429, + RequestHeaderFieldsTooLarge_431 = 431, + UnavailableForLegalReasons_451 = 451, + + // Server error responses + InternalServerError_500 = 500, + NotImplemented_501 = 501, + BadGateway_502 = 502, + ServiceUnavailable_503 = 503, + GatewayTimeout_504 = 504, + HttpVersionNotSupported_505 = 505, + VariantAlsoNegotiates_506 = 506, + InsufficientStorage_507 = 507, + LoopDetected_508 = 508, + NotExtended_510 = 510, + NetworkAuthenticationRequired_511 = 511, +}; + +using Headers = + std::unordered_multimap; + +using Params = std::multimap; +using Match = std::smatch; + +using Progress = std::function; + +struct Response; +using ResponseHandler = std::function; + +struct MultipartFormData { + std::string name; + std::string content; + std::string filename; + std::string content_type; +}; +using MultipartFormDataItems = std::vector; +using MultipartFormDataMap = std::multimap; + +class DataSink { +public: + DataSink() : os(&sb_), sb_(*this) {} + + DataSink(const DataSink &) = delete; + DataSink &operator=(const DataSink &) = delete; + DataSink(DataSink &&) = delete; + DataSink &operator=(DataSink &&) = delete; + + std::function write; + std::function is_writable; + std::function done; + std::function done_with_trailer; + std::ostream os; + +private: + class data_sink_streambuf final : public std::streambuf { + public: + explicit data_sink_streambuf(DataSink &sink) : sink_(sink) {} + + protected: + std::streamsize xsputn(const char *s, std::streamsize n) override { + sink_.write(s, static_cast(n)); + return n; + } + + private: + DataSink &sink_; + }; + + data_sink_streambuf sb_; +}; + +using ContentProvider = + std::function; + +using ContentProviderWithoutLength = + std::function; + +using ContentProviderResourceReleaser = std::function; + +struct MultipartFormDataProvider { + std::string name; + ContentProviderWithoutLength provider; + std::string filename; + std::string content_type; +}; +using MultipartFormDataProviderItems = std::vector; + +using ContentReceiverWithProgress = + std::function; + +using ContentReceiver = + std::function; + +using MultipartContentHeader = + std::function; + +class ContentReader { +public: + using Reader = std::function; + using MultipartReader = std::function; + + ContentReader(Reader reader, MultipartReader multipart_reader) + : reader_(std::move(reader)), + multipart_reader_(std::move(multipart_reader)) {} + + bool operator()(MultipartContentHeader header, + ContentReceiver receiver) const { + return multipart_reader_(std::move(header), std::move(receiver)); + } + + bool operator()(ContentReceiver receiver) const { + return reader_(std::move(receiver)); + } + + Reader reader_; + MultipartReader multipart_reader_; +}; + +using Range = std::pair; +using Ranges = std::vector; + +struct Request { + std::string method; + std::string path; + Headers headers; + std::string body; + + std::string remote_addr; + int remote_port = -1; + std::string local_addr; + int local_port = -1; + + // for server + std::string version; + std::string target; + Params params; + MultipartFormDataMap files; + Ranges ranges; + Match matches; + std::unordered_map path_params; + + // for client + ResponseHandler response_handler; + ContentReceiverWithProgress content_receiver; + Progress progress; +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + const SSL *ssl = nullptr; +#endif + + bool has_header(const std::string &key) const; + std::string get_header_value(const std::string &key, const char *def = "", + size_t id = 0) const; + uint64_t get_header_value_u64(const std::string &key, uint64_t def = 0, + size_t id = 0) const; + size_t get_header_value_count(const std::string &key) const; + void set_header(const std::string &key, const std::string &val); + + bool has_param(const std::string &key) const; + std::string get_param_value(const std::string &key, size_t id = 0) const; + size_t get_param_value_count(const std::string &key) const; + + bool is_multipart_form_data() const; + + bool has_file(const std::string &key) const; + MultipartFormData get_file_value(const std::string &key) const; + std::vector get_file_values(const std::string &key) const; + + // private members... + size_t redirect_count_ = CPPHTTPLIB_REDIRECT_MAX_COUNT; + size_t content_length_ = 0; + ContentProvider content_provider_; + bool is_chunked_content_provider_ = false; + size_t authorization_count_ = 0; +}; + +struct Response { + std::string version; + int status = -1; + std::string reason; + Headers headers; + std::string body; + std::string location; // Redirect location + + bool has_header(const std::string &key) const; + std::string get_header_value(const std::string &key, const char *def = "", + size_t id = 0) const; + uint64_t get_header_value_u64(const std::string &key, uint64_t def = 0, + size_t id = 0) const; + size_t get_header_value_count(const std::string &key) const; + void set_header(const std::string &key, const std::string &val); + + void set_redirect(const std::string &url, int status = StatusCode::Found_302); + void set_content(const char *s, size_t n, const std::string &content_type); + void set_content(const std::string &s, const std::string &content_type); + void set_content(std::string &&s, const std::string &content_type); + + void set_content_provider( + size_t length, const std::string &content_type, ContentProvider provider, + ContentProviderResourceReleaser resource_releaser = nullptr); + + void set_content_provider( + const std::string &content_type, ContentProviderWithoutLength provider, + ContentProviderResourceReleaser resource_releaser = nullptr); + + void set_chunked_content_provider( + const std::string &content_type, ContentProviderWithoutLength provider, + ContentProviderResourceReleaser resource_releaser = nullptr); + + void set_file_content(const std::string &path, + const std::string &content_type); + void set_file_content(const std::string &path); + + Response() = default; + Response(const Response &) = default; + Response &operator=(const Response &) = default; + Response(Response &&) = default; + Response &operator=(Response &&) = default; + ~Response() { + if (content_provider_resource_releaser_) { + content_provider_resource_releaser_(content_provider_success_); + } + } + + // private members... + size_t content_length_ = 0; + ContentProvider content_provider_; + ContentProviderResourceReleaser content_provider_resource_releaser_; + bool is_chunked_content_provider_ = false; + bool content_provider_success_ = false; + std::string file_content_path_; + std::string file_content_content_type_; +}; + +class Stream { +public: + virtual ~Stream() = default; + + virtual bool is_readable() const = 0; + virtual bool is_writable() const = 0; + + virtual ssize_t read(char *ptr, size_t size) = 0; + virtual ssize_t write(const char *ptr, size_t size) = 0; + virtual void get_remote_ip_and_port(std::string &ip, int &port) const = 0; + virtual void get_local_ip_and_port(std::string &ip, int &port) const = 0; + virtual socket_t socket() const = 0; + + ssize_t write(const char *ptr); + ssize_t write(const std::string &s); +}; + +class TaskQueue { +public: + TaskQueue() = default; + virtual ~TaskQueue() = default; + + virtual bool enqueue(std::function fn) = 0; + virtual void shutdown() = 0; + + virtual void on_idle() {} +}; + +class ThreadPool final : public TaskQueue { +public: + explicit ThreadPool(size_t n, size_t mqr = 0) + : shutdown_(false), max_queued_requests_(mqr) { + while (n) { + threads_.emplace_back(worker(*this)); + n--; + } + } + + ThreadPool(const ThreadPool &) = delete; + ~ThreadPool() override = default; + + bool enqueue(std::function fn) override { + { + std::unique_lock lock(mutex_); + if (max_queued_requests_ > 0 && jobs_.size() >= max_queued_requests_) { + return false; + } + jobs_.push_back(std::move(fn)); + } + + cond_.notify_one(); + return true; + } + + void shutdown() override { + // Stop all worker threads... + { + std::unique_lock lock(mutex_); + shutdown_ = true; + } + + cond_.notify_all(); + + // Join... + for (auto &t : threads_) { + t.join(); + } + } + +private: + struct worker { + explicit worker(ThreadPool &pool) : pool_(pool) {} + + void operator()() { + for (;;) { + std::function fn; + { + std::unique_lock lock(pool_.mutex_); + + pool_.cond_.wait( + lock, [&] { return !pool_.jobs_.empty() || pool_.shutdown_; }); + + if (pool_.shutdown_ && pool_.jobs_.empty()) { break; } + + fn = pool_.jobs_.front(); + pool_.jobs_.pop_front(); + } + + assert(true == static_cast(fn)); + fn(); + } + +#if defined(CPPHTTPLIB_OPENSSL_SUPPORT) && !defined(OPENSSL_IS_BORINGSSL) && \ + !defined(LIBRESSL_VERSION_NUMBER) + OPENSSL_thread_stop(); +#endif + } + + ThreadPool &pool_; + }; + friend struct worker; + + std::vector threads_; + std::list> jobs_; + + bool shutdown_; + size_t max_queued_requests_ = 0; + + std::condition_variable cond_; + std::mutex mutex_; +}; + +using Logger = std::function; + +using SocketOptions = std::function; + +void default_socket_options(socket_t sock); + +const char *status_message(int status); + +std::string get_bearer_token_auth(const Request &req); + +namespace detail { + +class MatcherBase { +public: + virtual ~MatcherBase() = default; + + // Match request path and populate its matches and + virtual bool match(Request &request) const = 0; +}; + +/** + * Captures parameters in request path and stores them in Request::path_params + * + * Capture name is a substring of a pattern from : to /. + * The rest of the pattern is matched agains the request path directly + * Parameters are captured starting from the next character after + * the end of the last matched static pattern fragment until the next /. + * + * Example pattern: + * "/path/fragments/:capture/more/fragments/:second_capture" + * Static fragments: + * "/path/fragments/", "more/fragments/" + * + * Given the following request path: + * "/path/fragments/:1/more/fragments/:2" + * the resulting capture will be + * {{"capture", "1"}, {"second_capture", "2"}} + */ +class PathParamsMatcher final : public MatcherBase { +public: + PathParamsMatcher(const std::string &pattern); + + bool match(Request &request) const override; + +private: + // Treat segment separators as the end of path parameter capture + // Does not need to handle query parameters as they are parsed before path + // matching + static constexpr char separator = '/'; + + // Contains static path fragments to match against, excluding the '/' after + // path params + // Fragments are separated by path params + std::vector static_fragments_; + // Stores the names of the path parameters to be used as keys in the + // Request::path_params map + std::vector param_names_; +}; + +/** + * Performs std::regex_match on request path + * and stores the result in Request::matches + * + * Note that regex match is performed directly on the whole request. + * This means that wildcard patterns may match multiple path segments with /: + * "/begin/(.*)/end" will match both "/begin/middle/end" and "/begin/1/2/end". + */ +class RegexMatcher final : public MatcherBase { +public: + RegexMatcher(const std::string &pattern) : regex_(pattern) {} + + bool match(Request &request) const override; + +private: + std::regex regex_; +}; + +ssize_t write_headers(Stream &strm, const Headers &headers); + +} // namespace detail + +class Server { +public: + using Handler = std::function; + + using ExceptionHandler = + std::function; + + enum class HandlerResponse { + Handled, + Unhandled, + }; + using HandlerWithResponse = + std::function; + + using HandlerWithContentReader = std::function; + + using Expect100ContinueHandler = + std::function; + + Server(); + + virtual ~Server(); + + virtual bool is_valid() const; + + Server &Get(const std::string &pattern, Handler handler); + Server &Post(const std::string &pattern, Handler handler); + Server &Post(const std::string &pattern, HandlerWithContentReader handler); + Server &Put(const std::string &pattern, Handler handler); + Server &Put(const std::string &pattern, HandlerWithContentReader handler); + Server &Patch(const std::string &pattern, Handler handler); + Server &Patch(const std::string &pattern, HandlerWithContentReader handler); + Server &Delete(const std::string &pattern, Handler handler); + Server &Delete(const std::string &pattern, HandlerWithContentReader handler); + Server &Options(const std::string &pattern, Handler handler); + + bool set_base_dir(const std::string &dir, + const std::string &mount_point = std::string()); + bool set_mount_point(const std::string &mount_point, const std::string &dir, + Headers headers = Headers()); + bool remove_mount_point(const std::string &mount_point); + Server &set_file_extension_and_mimetype_mapping(const std::string &ext, + const std::string &mime); + Server &set_default_file_mimetype(const std::string &mime); + Server &set_file_request_handler(Handler handler); + + template + Server &set_error_handler(ErrorHandlerFunc &&handler) { + return set_error_handler_core( + std::forward(handler), + std::is_convertible{}); + } + + Server &set_exception_handler(ExceptionHandler handler); + Server &set_pre_routing_handler(HandlerWithResponse handler); + Server &set_post_routing_handler(Handler handler); + + Server &set_expect_100_continue_handler(Expect100ContinueHandler handler); + Server &set_logger(Logger logger); + + Server &set_address_family(int family); + Server &set_tcp_nodelay(bool on); + Server &set_ipv6_v6only(bool on); + Server &set_socket_options(SocketOptions socket_options); + + Server &set_default_headers(Headers headers); + Server & + set_header_writer(std::function const &writer); + + Server &set_keep_alive_max_count(size_t count); + Server &set_keep_alive_timeout(time_t sec); + + Server &set_read_timeout(time_t sec, time_t usec = 0); + template + Server &set_read_timeout(const std::chrono::duration &duration); + + Server &set_write_timeout(time_t sec, time_t usec = 0); + template + Server &set_write_timeout(const std::chrono::duration &duration); + + Server &set_idle_interval(time_t sec, time_t usec = 0); + template + Server &set_idle_interval(const std::chrono::duration &duration); + + Server &set_payload_max_length(size_t length); + + bool bind_to_port(const std::string &host, int port, int socket_flags = 0); + int bind_to_any_port(const std::string &host, int socket_flags = 0); + bool listen_after_bind(); + + bool listen(const std::string &host, int port, int socket_flags = 0); + + bool is_running() const; + void wait_until_ready() const; + void stop(); + void decommission(); + + std::function new_task_queue; + +protected: + bool process_request(Stream &strm, const std::string &remote_addr, + int remote_port, const std::string &local_addr, + int local_port, bool close_connection, + bool &connection_closed, + const std::function &setup_request); + + std::atomic svr_sock_{INVALID_SOCKET}; + size_t keep_alive_max_count_ = CPPHTTPLIB_KEEPALIVE_MAX_COUNT; + time_t keep_alive_timeout_sec_ = CPPHTTPLIB_KEEPALIVE_TIMEOUT_SECOND; + time_t read_timeout_sec_ = CPPHTTPLIB_SERVER_READ_TIMEOUT_SECOND; + time_t read_timeout_usec_ = CPPHTTPLIB_SERVER_READ_TIMEOUT_USECOND; + time_t write_timeout_sec_ = CPPHTTPLIB_SERVER_WRITE_TIMEOUT_SECOND; + time_t write_timeout_usec_ = CPPHTTPLIB_SERVER_WRITE_TIMEOUT_USECOND; + time_t idle_interval_sec_ = CPPHTTPLIB_IDLE_INTERVAL_SECOND; + time_t idle_interval_usec_ = CPPHTTPLIB_IDLE_INTERVAL_USECOND; + size_t payload_max_length_ = CPPHTTPLIB_PAYLOAD_MAX_LENGTH; + +private: + using Handlers = + std::vector, Handler>>; + using HandlersForContentReader = + std::vector, + HandlerWithContentReader>>; + + static std::unique_ptr + make_matcher(const std::string &pattern); + + Server &set_error_handler_core(HandlerWithResponse handler, std::true_type); + Server &set_error_handler_core(Handler handler, std::false_type); + + socket_t create_server_socket(const std::string &host, int port, + int socket_flags, + SocketOptions socket_options) const; + int bind_internal(const std::string &host, int port, int socket_flags); + bool listen_internal(); + + bool routing(Request &req, Response &res, Stream &strm); + bool handle_file_request(const Request &req, Response &res, + bool head = false); + bool dispatch_request(Request &req, Response &res, + const Handlers &handlers) const; + bool dispatch_request_for_content_reader( + Request &req, Response &res, ContentReader content_reader, + const HandlersForContentReader &handlers) const; + + bool parse_request_line(const char *s, Request &req) const; + void apply_ranges(const Request &req, Response &res, + std::string &content_type, std::string &boundary) const; + bool write_response(Stream &strm, bool close_connection, Request &req, + Response &res); + bool write_response_with_content(Stream &strm, bool close_connection, + const Request &req, Response &res); + bool write_response_core(Stream &strm, bool close_connection, + const Request &req, Response &res, + bool need_apply_ranges); + bool write_content_with_provider(Stream &strm, const Request &req, + Response &res, const std::string &boundary, + const std::string &content_type); + bool read_content(Stream &strm, Request &req, Response &res); + bool + read_content_with_content_receiver(Stream &strm, Request &req, Response &res, + ContentReceiver receiver, + MultipartContentHeader multipart_header, + ContentReceiver multipart_receiver); + bool read_content_core(Stream &strm, Request &req, Response &res, + ContentReceiver receiver, + MultipartContentHeader multipart_header, + ContentReceiver multipart_receiver) const; + + virtual bool process_and_close_socket(socket_t sock); + + std::atomic is_running_{false}; + std::atomic is_decommisioned{false}; + + struct MountPointEntry { + std::string mount_point; + std::string base_dir; + Headers headers; + }; + std::vector base_dirs_; + std::map file_extension_and_mimetype_map_; + std::string default_file_mimetype_ = "application/octet-stream"; + Handler file_request_handler_; + + Handlers get_handlers_; + Handlers post_handlers_; + HandlersForContentReader post_handlers_for_content_reader_; + Handlers put_handlers_; + HandlersForContentReader put_handlers_for_content_reader_; + Handlers patch_handlers_; + HandlersForContentReader patch_handlers_for_content_reader_; + Handlers delete_handlers_; + HandlersForContentReader delete_handlers_for_content_reader_; + Handlers options_handlers_; + + HandlerWithResponse error_handler_; + ExceptionHandler exception_handler_; + HandlerWithResponse pre_routing_handler_; + Handler post_routing_handler_; + Expect100ContinueHandler expect_100_continue_handler_; + + Logger logger_; + + int address_family_ = AF_UNSPEC; + bool tcp_nodelay_ = CPPHTTPLIB_TCP_NODELAY; + bool ipv6_v6only_ = CPPHTTPLIB_IPV6_V6ONLY; + SocketOptions socket_options_ = default_socket_options; + + Headers default_headers_; + std::function header_writer_ = + detail::write_headers; +}; + +enum class Error { + Success = 0, + Unknown, + Connection, + BindIPAddress, + Read, + Write, + ExceedRedirectCount, + Canceled, + SSLConnection, + SSLLoadingCerts, + SSLServerVerification, + SSLServerHostnameVerification, + UnsupportedMultipartBoundaryChars, + Compression, + ConnectionTimeout, + ProxyConnection, + + // For internal use only + SSLPeerCouldBeClosed_, +}; + +std::string to_string(Error error); + +std::ostream &operator<<(std::ostream &os, const Error &obj); + +class Result { +public: + Result() = default; + Result(std::unique_ptr &&res, Error err, + Headers &&request_headers = Headers{}) + : res_(std::move(res)), err_(err), + request_headers_(std::move(request_headers)) {} + // Response + operator bool() const { return res_ != nullptr; } + bool operator==(std::nullptr_t) const { return res_ == nullptr; } + bool operator!=(std::nullptr_t) const { return res_ != nullptr; } + const Response &value() const { return *res_; } + Response &value() { return *res_; } + const Response &operator*() const { return *res_; } + Response &operator*() { return *res_; } + const Response *operator->() const { return res_.get(); } + Response *operator->() { return res_.get(); } + + // Error + Error error() const { return err_; } + + // Request Headers + bool has_request_header(const std::string &key) const; + std::string get_request_header_value(const std::string &key, + const char *def = "", + size_t id = 0) const; + uint64_t get_request_header_value_u64(const std::string &key, + uint64_t def = 0, size_t id = 0) const; + size_t get_request_header_value_count(const std::string &key) const; + +private: + std::unique_ptr res_; + Error err_ = Error::Unknown; + Headers request_headers_; +}; + +class ClientImpl { +public: + explicit ClientImpl(const std::string &host); + + explicit ClientImpl(const std::string &host, int port); + + explicit ClientImpl(const std::string &host, int port, + const std::string &client_cert_path, + const std::string &client_key_path); + + virtual ~ClientImpl(); + + virtual bool is_valid() const; + + Result Get(const std::string &path); + Result Get(const std::string &path, const Headers &headers); + Result Get(const std::string &path, Progress progress); + Result Get(const std::string &path, const Headers &headers, + Progress progress); + Result Get(const std::string &path, ContentReceiver content_receiver); + Result Get(const std::string &path, const Headers &headers, + ContentReceiver content_receiver); + Result Get(const std::string &path, ContentReceiver content_receiver, + Progress progress); + Result Get(const std::string &path, const Headers &headers, + ContentReceiver content_receiver, Progress progress); + Result Get(const std::string &path, ResponseHandler response_handler, + ContentReceiver content_receiver); + Result Get(const std::string &path, const Headers &headers, + ResponseHandler response_handler, + ContentReceiver content_receiver); + Result Get(const std::string &path, ResponseHandler response_handler, + ContentReceiver content_receiver, Progress progress); + Result Get(const std::string &path, const Headers &headers, + ResponseHandler response_handler, ContentReceiver content_receiver, + Progress progress); + + Result Get(const std::string &path, const Params ¶ms, + const Headers &headers, Progress progress = nullptr); + Result Get(const std::string &path, const Params ¶ms, + const Headers &headers, ContentReceiver content_receiver, + Progress progress = nullptr); + Result Get(const std::string &path, const Params ¶ms, + const Headers &headers, ResponseHandler response_handler, + ContentReceiver content_receiver, Progress progress = nullptr); + + Result Head(const std::string &path); + Result Head(const std::string &path, const Headers &headers); + + Result Post(const std::string &path); + Result Post(const std::string &path, const Headers &headers); + Result Post(const std::string &path, const char *body, size_t content_length, + const std::string &content_type); + Result Post(const std::string &path, const Headers &headers, const char *body, + size_t content_length, const std::string &content_type); + Result Post(const std::string &path, const Headers &headers, const char *body, + size_t content_length, const std::string &content_type, + Progress progress); + Result Post(const std::string &path, const std::string &body, + const std::string &content_type); + Result Post(const std::string &path, const std::string &body, + const std::string &content_type, Progress progress); + Result Post(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type); + Result Post(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type, + Progress progress); + Result Post(const std::string &path, size_t content_length, + ContentProvider content_provider, + const std::string &content_type); + Result Post(const std::string &path, + ContentProviderWithoutLength content_provider, + const std::string &content_type); + Result Post(const std::string &path, const Headers &headers, + size_t content_length, ContentProvider content_provider, + const std::string &content_type); + Result Post(const std::string &path, const Headers &headers, + ContentProviderWithoutLength content_provider, + const std::string &content_type); + Result Post(const std::string &path, const Params ¶ms); + Result Post(const std::string &path, const Headers &headers, + const Params ¶ms); + Result Post(const std::string &path, const Headers &headers, + const Params ¶ms, Progress progress); + Result Post(const std::string &path, const MultipartFormDataItems &items); + Result Post(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items); + Result Post(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, const std::string &boundary); + Result Post(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items); + + Result Put(const std::string &path); + Result Put(const std::string &path, const char *body, size_t content_length, + const std::string &content_type); + Result Put(const std::string &path, const Headers &headers, const char *body, + size_t content_length, const std::string &content_type); + Result Put(const std::string &path, const Headers &headers, const char *body, + size_t content_length, const std::string &content_type, + Progress progress); + Result Put(const std::string &path, const std::string &body, + const std::string &content_type); + Result Put(const std::string &path, const std::string &body, + const std::string &content_type, Progress progress); + Result Put(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type); + Result Put(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type, + Progress progress); + Result Put(const std::string &path, size_t content_length, + ContentProvider content_provider, const std::string &content_type); + Result Put(const std::string &path, + ContentProviderWithoutLength content_provider, + const std::string &content_type); + Result Put(const std::string &path, const Headers &headers, + size_t content_length, ContentProvider content_provider, + const std::string &content_type); + Result Put(const std::string &path, const Headers &headers, + ContentProviderWithoutLength content_provider, + const std::string &content_type); + Result Put(const std::string &path, const Params ¶ms); + Result Put(const std::string &path, const Headers &headers, + const Params ¶ms); + Result Put(const std::string &path, const Headers &headers, + const Params ¶ms, Progress progress); + Result Put(const std::string &path, const MultipartFormDataItems &items); + Result Put(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items); + Result Put(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, const std::string &boundary); + Result Put(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items); + + Result Patch(const std::string &path); + Result Patch(const std::string &path, const char *body, size_t content_length, + const std::string &content_type); + Result Patch(const std::string &path, const char *body, size_t content_length, + const std::string &content_type, Progress progress); + Result Patch(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type); + Result Patch(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type, Progress progress); + Result Patch(const std::string &path, const std::string &body, + const std::string &content_type); + Result Patch(const std::string &path, const std::string &body, + const std::string &content_type, Progress progress); + Result Patch(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type); + Result Patch(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type, + Progress progress); + Result Patch(const std::string &path, size_t content_length, + ContentProvider content_provider, + const std::string &content_type); + Result Patch(const std::string &path, + ContentProviderWithoutLength content_provider, + const std::string &content_type); + Result Patch(const std::string &path, const Headers &headers, + size_t content_length, ContentProvider content_provider, + const std::string &content_type); + Result Patch(const std::string &path, const Headers &headers, + ContentProviderWithoutLength content_provider, + const std::string &content_type); + + Result Delete(const std::string &path); + Result Delete(const std::string &path, const Headers &headers); + Result Delete(const std::string &path, const char *body, + size_t content_length, const std::string &content_type); + Result Delete(const std::string &path, const char *body, + size_t content_length, const std::string &content_type, + Progress progress); + Result Delete(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type); + Result Delete(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type, Progress progress); + Result Delete(const std::string &path, const std::string &body, + const std::string &content_type); + Result Delete(const std::string &path, const std::string &body, + const std::string &content_type, Progress progress); + Result Delete(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type); + Result Delete(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type, + Progress progress); + + Result Options(const std::string &path); + Result Options(const std::string &path, const Headers &headers); + + bool send(Request &req, Response &res, Error &error); + Result send(const Request &req); + + void stop(); + + std::string host() const; + int port() const; + + size_t is_socket_open() const; + socket_t socket() const; + + void set_hostname_addr_map(std::map addr_map); + + void set_default_headers(Headers headers); + + void + set_header_writer(std::function const &writer); + + void set_address_family(int family); + void set_tcp_nodelay(bool on); + void set_ipv6_v6only(bool on); + void set_socket_options(SocketOptions socket_options); + + void set_connection_timeout(time_t sec, time_t usec = 0); + template + void + set_connection_timeout(const std::chrono::duration &duration); + + void set_read_timeout(time_t sec, time_t usec = 0); + template + void set_read_timeout(const std::chrono::duration &duration); + + void set_write_timeout(time_t sec, time_t usec = 0); + template + void set_write_timeout(const std::chrono::duration &duration); + + void set_basic_auth(const std::string &username, const std::string &password); + void set_bearer_token_auth(const std::string &token); +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + void set_digest_auth(const std::string &username, + const std::string &password); +#endif + + void set_keep_alive(bool on); + void set_follow_location(bool on); + + void set_url_encode(bool on); + + void set_compress(bool on); + + void set_decompress(bool on); + + void set_interface(const std::string &intf); + + void set_proxy(const std::string &host, int port); + void set_proxy_basic_auth(const std::string &username, + const std::string &password); + void set_proxy_bearer_token_auth(const std::string &token); +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + void set_proxy_digest_auth(const std::string &username, + const std::string &password); +#endif + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + void set_ca_cert_path(const std::string &ca_cert_file_path, + const std::string &ca_cert_dir_path = std::string()); + void set_ca_cert_store(X509_STORE *ca_cert_store); + X509_STORE *create_ca_cert_store(const char *ca_cert, std::size_t size) const; +#endif + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + void enable_server_certificate_verification(bool enabled); + void enable_server_hostname_verification(bool enabled); + void set_server_certificate_verifier(std::function verifier); +#endif + + void set_logger(Logger logger); + +protected: + struct Socket { + socket_t sock = INVALID_SOCKET; +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + SSL *ssl = nullptr; +#endif + + bool is_open() const { return sock != INVALID_SOCKET; } + }; + + virtual bool create_and_connect_socket(Socket &socket, Error &error); + + // All of: + // shutdown_ssl + // shutdown_socket + // close_socket + // should ONLY be called when socket_mutex_ is locked. + // Also, shutdown_ssl and close_socket should also NOT be called concurrently + // with a DIFFERENT thread sending requests using that socket. + virtual void shutdown_ssl(Socket &socket, bool shutdown_gracefully); + void shutdown_socket(Socket &socket) const; + void close_socket(Socket &socket); + + bool process_request(Stream &strm, Request &req, Response &res, + bool close_connection, Error &error); + + bool write_content_with_provider(Stream &strm, const Request &req, + Error &error) const; + + void copy_settings(const ClientImpl &rhs); + + // Socket endpoint information + const std::string host_; + const int port_; + const std::string host_and_port_; + + // Current open socket + Socket socket_; + mutable std::mutex socket_mutex_; + std::recursive_mutex request_mutex_; + + // These are all protected under socket_mutex + size_t socket_requests_in_flight_ = 0; + std::thread::id socket_requests_are_from_thread_ = std::thread::id(); + bool socket_should_be_closed_when_request_is_done_ = false; + + // Hostname-IP map + std::map addr_map_; + + // Default headers + Headers default_headers_; + + // Header writer + std::function header_writer_ = + detail::write_headers; + + // Settings + std::string client_cert_path_; + std::string client_key_path_; + + time_t connection_timeout_sec_ = CPPHTTPLIB_CONNECTION_TIMEOUT_SECOND; + time_t connection_timeout_usec_ = CPPHTTPLIB_CONNECTION_TIMEOUT_USECOND; + time_t read_timeout_sec_ = CPPHTTPLIB_CLIENT_READ_TIMEOUT_SECOND; + time_t read_timeout_usec_ = CPPHTTPLIB_CLIENT_READ_TIMEOUT_USECOND; + time_t write_timeout_sec_ = CPPHTTPLIB_CLIENT_WRITE_TIMEOUT_SECOND; + time_t write_timeout_usec_ = CPPHTTPLIB_CLIENT_WRITE_TIMEOUT_USECOND; + + std::string basic_auth_username_; + std::string basic_auth_password_; + std::string bearer_token_auth_token_; +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + std::string digest_auth_username_; + std::string digest_auth_password_; +#endif + + bool keep_alive_ = false; + bool follow_location_ = false; + + bool url_encode_ = true; + + int address_family_ = AF_UNSPEC; + bool tcp_nodelay_ = CPPHTTPLIB_TCP_NODELAY; + bool ipv6_v6only_ = CPPHTTPLIB_IPV6_V6ONLY; + SocketOptions socket_options_ = nullptr; + + bool compress_ = false; + bool decompress_ = true; + + std::string interface_; + + std::string proxy_host_; + int proxy_port_ = -1; + + std::string proxy_basic_auth_username_; + std::string proxy_basic_auth_password_; + std::string proxy_bearer_token_auth_token_; +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + std::string proxy_digest_auth_username_; + std::string proxy_digest_auth_password_; +#endif + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + std::string ca_cert_file_path_; + std::string ca_cert_dir_path_; + + X509_STORE *ca_cert_store_ = nullptr; +#endif + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + bool server_certificate_verification_ = true; + bool server_hostname_verification_ = true; + std::function server_certificate_verifier_; +#endif + + Logger logger_; + +private: + bool send_(Request &req, Response &res, Error &error); + Result send_(Request &&req); + + socket_t create_client_socket(Error &error) const; + bool read_response_line(Stream &strm, const Request &req, + Response &res) const; + bool write_request(Stream &strm, Request &req, bool close_connection, + Error &error); + bool redirect(Request &req, Response &res, Error &error); + bool handle_request(Stream &strm, Request &req, Response &res, + bool close_connection, Error &error); + std::unique_ptr send_with_content_provider( + Request &req, const char *body, size_t content_length, + ContentProvider content_provider, + ContentProviderWithoutLength content_provider_without_length, + const std::string &content_type, Error &error); + Result send_with_content_provider( + const std::string &method, const std::string &path, + const Headers &headers, const char *body, size_t content_length, + ContentProvider content_provider, + ContentProviderWithoutLength content_provider_without_length, + const std::string &content_type, Progress progress); + ContentProviderWithoutLength get_multipart_content_provider( + const std::string &boundary, const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items) const; + + std::string adjust_host_string(const std::string &host) const; + + virtual bool process_socket(const Socket &socket, + std::function callback); + virtual bool is_ssl() const; +}; + +class Client { +public: + // Universal interface + explicit Client(const std::string &scheme_host_port); + + explicit Client(const std::string &scheme_host_port, + const std::string &client_cert_path, + const std::string &client_key_path); + + // HTTP only interface + explicit Client(const std::string &host, int port); + + explicit Client(const std::string &host, int port, + const std::string &client_cert_path, + const std::string &client_key_path); + + Client(Client &&) = default; + Client &operator=(Client &&) = default; + + ~Client(); + + bool is_valid() const; + + Result Get(const std::string &path); + Result Get(const std::string &path, const Headers &headers); + Result Get(const std::string &path, Progress progress); + Result Get(const std::string &path, const Headers &headers, + Progress progress); + Result Get(const std::string &path, ContentReceiver content_receiver); + Result Get(const std::string &path, const Headers &headers, + ContentReceiver content_receiver); + Result Get(const std::string &path, ContentReceiver content_receiver, + Progress progress); + Result Get(const std::string &path, const Headers &headers, + ContentReceiver content_receiver, Progress progress); + Result Get(const std::string &path, ResponseHandler response_handler, + ContentReceiver content_receiver); + Result Get(const std::string &path, const Headers &headers, + ResponseHandler response_handler, + ContentReceiver content_receiver); + Result Get(const std::string &path, const Headers &headers, + ResponseHandler response_handler, ContentReceiver content_receiver, + Progress progress); + Result Get(const std::string &path, ResponseHandler response_handler, + ContentReceiver content_receiver, Progress progress); + + Result Get(const std::string &path, const Params ¶ms, + const Headers &headers, Progress progress = nullptr); + Result Get(const std::string &path, const Params ¶ms, + const Headers &headers, ContentReceiver content_receiver, + Progress progress = nullptr); + Result Get(const std::string &path, const Params ¶ms, + const Headers &headers, ResponseHandler response_handler, + ContentReceiver content_receiver, Progress progress = nullptr); + + Result Head(const std::string &path); + Result Head(const std::string &path, const Headers &headers); + + Result Post(const std::string &path); + Result Post(const std::string &path, const Headers &headers); + Result Post(const std::string &path, const char *body, size_t content_length, + const std::string &content_type); + Result Post(const std::string &path, const Headers &headers, const char *body, + size_t content_length, const std::string &content_type); + Result Post(const std::string &path, const Headers &headers, const char *body, + size_t content_length, const std::string &content_type, + Progress progress); + Result Post(const std::string &path, const std::string &body, + const std::string &content_type); + Result Post(const std::string &path, const std::string &body, + const std::string &content_type, Progress progress); + Result Post(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type); + Result Post(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type, + Progress progress); + Result Post(const std::string &path, size_t content_length, + ContentProvider content_provider, + const std::string &content_type); + Result Post(const std::string &path, + ContentProviderWithoutLength content_provider, + const std::string &content_type); + Result Post(const std::string &path, const Headers &headers, + size_t content_length, ContentProvider content_provider, + const std::string &content_type); + Result Post(const std::string &path, const Headers &headers, + ContentProviderWithoutLength content_provider, + const std::string &content_type); + Result Post(const std::string &path, const Params ¶ms); + Result Post(const std::string &path, const Headers &headers, + const Params ¶ms); + Result Post(const std::string &path, const Headers &headers, + const Params ¶ms, Progress progress); + Result Post(const std::string &path, const MultipartFormDataItems &items); + Result Post(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items); + Result Post(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, const std::string &boundary); + Result Post(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items); + + Result Put(const std::string &path); + Result Put(const std::string &path, const char *body, size_t content_length, + const std::string &content_type); + Result Put(const std::string &path, const Headers &headers, const char *body, + size_t content_length, const std::string &content_type); + Result Put(const std::string &path, const Headers &headers, const char *body, + size_t content_length, const std::string &content_type, + Progress progress); + Result Put(const std::string &path, const std::string &body, + const std::string &content_type); + Result Put(const std::string &path, const std::string &body, + const std::string &content_type, Progress progress); + Result Put(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type); + Result Put(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type, + Progress progress); + Result Put(const std::string &path, size_t content_length, + ContentProvider content_provider, const std::string &content_type); + Result Put(const std::string &path, + ContentProviderWithoutLength content_provider, + const std::string &content_type); + Result Put(const std::string &path, const Headers &headers, + size_t content_length, ContentProvider content_provider, + const std::string &content_type); + Result Put(const std::string &path, const Headers &headers, + ContentProviderWithoutLength content_provider, + const std::string &content_type); + Result Put(const std::string &path, const Params ¶ms); + Result Put(const std::string &path, const Headers &headers, + const Params ¶ms); + Result Put(const std::string &path, const Headers &headers, + const Params ¶ms, Progress progress); + Result Put(const std::string &path, const MultipartFormDataItems &items); + Result Put(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items); + Result Put(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, const std::string &boundary); + Result Put(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items); + + Result Patch(const std::string &path); + Result Patch(const std::string &path, const char *body, size_t content_length, + const std::string &content_type); + Result Patch(const std::string &path, const char *body, size_t content_length, + const std::string &content_type, Progress progress); + Result Patch(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type); + Result Patch(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type, Progress progress); + Result Patch(const std::string &path, const std::string &body, + const std::string &content_type); + Result Patch(const std::string &path, const std::string &body, + const std::string &content_type, Progress progress); + Result Patch(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type); + Result Patch(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type, + Progress progress); + Result Patch(const std::string &path, size_t content_length, + ContentProvider content_provider, + const std::string &content_type); + Result Patch(const std::string &path, + ContentProviderWithoutLength content_provider, + const std::string &content_type); + Result Patch(const std::string &path, const Headers &headers, + size_t content_length, ContentProvider content_provider, + const std::string &content_type); + Result Patch(const std::string &path, const Headers &headers, + ContentProviderWithoutLength content_provider, + const std::string &content_type); + + Result Delete(const std::string &path); + Result Delete(const std::string &path, const Headers &headers); + Result Delete(const std::string &path, const char *body, + size_t content_length, const std::string &content_type); + Result Delete(const std::string &path, const char *body, + size_t content_length, const std::string &content_type, + Progress progress); + Result Delete(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type); + Result Delete(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type, Progress progress); + Result Delete(const std::string &path, const std::string &body, + const std::string &content_type); + Result Delete(const std::string &path, const std::string &body, + const std::string &content_type, Progress progress); + Result Delete(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type); + Result Delete(const std::string &path, const Headers &headers, + const std::string &body, const std::string &content_type, + Progress progress); + + Result Options(const std::string &path); + Result Options(const std::string &path, const Headers &headers); + + bool send(Request &req, Response &res, Error &error); + Result send(const Request &req); + + void stop(); + + std::string host() const; + int port() const; + + size_t is_socket_open() const; + socket_t socket() const; + + void set_hostname_addr_map(std::map addr_map); + + void set_default_headers(Headers headers); + + void + set_header_writer(std::function const &writer); + + void set_address_family(int family); + void set_tcp_nodelay(bool on); + void set_socket_options(SocketOptions socket_options); + + void set_connection_timeout(time_t sec, time_t usec = 0); + template + void + set_connection_timeout(const std::chrono::duration &duration); + + void set_read_timeout(time_t sec, time_t usec = 0); + template + void set_read_timeout(const std::chrono::duration &duration); + + void set_write_timeout(time_t sec, time_t usec = 0); + template + void set_write_timeout(const std::chrono::duration &duration); + + void set_basic_auth(const std::string &username, const std::string &password); + void set_bearer_token_auth(const std::string &token); +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + void set_digest_auth(const std::string &username, + const std::string &password); +#endif + + void set_keep_alive(bool on); + void set_follow_location(bool on); + + void set_url_encode(bool on); + + void set_compress(bool on); + + void set_decompress(bool on); + + void set_interface(const std::string &intf); + + void set_proxy(const std::string &host, int port); + void set_proxy_basic_auth(const std::string &username, + const std::string &password); + void set_proxy_bearer_token_auth(const std::string &token); +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + void set_proxy_digest_auth(const std::string &username, + const std::string &password); +#endif + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + void enable_server_certificate_verification(bool enabled); + void enable_server_hostname_verification(bool enabled); + void set_server_certificate_verifier(std::function verifier); +#endif + + void set_logger(Logger logger); + + // SSL +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + void set_ca_cert_path(const std::string &ca_cert_file_path, + const std::string &ca_cert_dir_path = std::string()); + + void set_ca_cert_store(X509_STORE *ca_cert_store); + void load_ca_cert_store(const char *ca_cert, std::size_t size); + + long get_openssl_verify_result() const; + + SSL_CTX *ssl_context() const; +#endif + +private: + std::unique_ptr cli_; + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + bool is_ssl_ = false; +#endif +}; + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +class SSLServer : public Server { +public: + SSLServer(const char *cert_path, const char *private_key_path, + const char *client_ca_cert_file_path = nullptr, + const char *client_ca_cert_dir_path = nullptr, + const char *private_key_password = nullptr); + + SSLServer(X509 *cert, EVP_PKEY *private_key, + X509_STORE *client_ca_cert_store = nullptr); + + SSLServer( + const std::function &setup_ssl_ctx_callback); + + ~SSLServer() override; + + bool is_valid() const override; + + SSL_CTX *ssl_context() const; + + void update_certs(X509 *cert, EVP_PKEY *private_key, + X509_STORE *client_ca_cert_store = nullptr); + +private: + bool process_and_close_socket(socket_t sock) override; + + SSL_CTX *ctx_; + std::mutex ctx_mutex_; +}; + +class SSLClient final : public ClientImpl { +public: + explicit SSLClient(const std::string &host); + + explicit SSLClient(const std::string &host, int port); + + explicit SSLClient(const std::string &host, int port, + const std::string &client_cert_path, + const std::string &client_key_path, + const std::string &private_key_password = std::string()); + + explicit SSLClient(const std::string &host, int port, X509 *client_cert, + EVP_PKEY *client_key, + const std::string &private_key_password = std::string()); + + ~SSLClient() override; + + bool is_valid() const override; + + void set_ca_cert_store(X509_STORE *ca_cert_store); + void load_ca_cert_store(const char *ca_cert, std::size_t size); + + long get_openssl_verify_result() const; + + SSL_CTX *ssl_context() const; + +private: + bool create_and_connect_socket(Socket &socket, Error &error) override; + void shutdown_ssl(Socket &socket, bool shutdown_gracefully) override; + void shutdown_ssl_impl(Socket &socket, bool shutdown_gracefully); + + bool process_socket(const Socket &socket, + std::function callback) override; + bool is_ssl() const override; + + bool connect_with_proxy(Socket &sock, Response &res, bool &success, + Error &error); + bool initialize_ssl(Socket &socket, Error &error); + + bool load_certs(); + + bool verify_host(X509 *server_cert) const; + bool verify_host_with_subject_alt_name(X509 *server_cert) const; + bool verify_host_with_common_name(X509 *server_cert) const; + bool check_host_name(const char *pattern, size_t pattern_len) const; + + SSL_CTX *ctx_; + std::mutex ctx_mutex_; + std::once_flag initialize_cert_; + + std::vector host_components_; + + long verify_result_ = 0; + + friend class ClientImpl; +}; +#endif + +/* + * Implementation of template methods. + */ + +namespace detail { + +template +inline void duration_to_sec_and_usec(const T &duration, U callback) { + auto sec = std::chrono::duration_cast(duration).count(); + auto usec = std::chrono::duration_cast( + duration - std::chrono::seconds(sec)) + .count(); + callback(static_cast(sec), static_cast(usec)); +} + +inline uint64_t get_header_value_u64(const Headers &headers, + const std::string &key, uint64_t def, + size_t id) { + auto rng = headers.equal_range(key); + auto it = rng.first; + std::advance(it, static_cast(id)); + if (it != rng.second) { + return std::strtoull(it->second.data(), nullptr, 10); + } + return def; +} + +} // namespace detail + +inline uint64_t Request::get_header_value_u64(const std::string &key, + uint64_t def, size_t id) const { + return detail::get_header_value_u64(headers, key, def, id); +} + +inline uint64_t Response::get_header_value_u64(const std::string &key, + uint64_t def, size_t id) const { + return detail::get_header_value_u64(headers, key, def, id); +} + +inline void default_socket_options(socket_t sock) { + int opt = 1; +#ifdef _WIN32 + setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, + reinterpret_cast(&opt), sizeof(opt)); + setsockopt(sock, SOL_SOCKET, SO_EXCLUSIVEADDRUSE, + reinterpret_cast(&opt), sizeof(opt)); +#else +#ifdef SO_REUSEPORT + setsockopt(sock, SOL_SOCKET, SO_REUSEPORT, + reinterpret_cast(&opt), sizeof(opt)); +#else + setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, + reinterpret_cast(&opt), sizeof(opt)); +#endif +#endif +} + +inline const char *status_message(int status) { + switch (status) { + case StatusCode::Continue_100: return "Continue"; + case StatusCode::SwitchingProtocol_101: return "Switching Protocol"; + case StatusCode::Processing_102: return "Processing"; + case StatusCode::EarlyHints_103: return "Early Hints"; + case StatusCode::OK_200: return "OK"; + case StatusCode::Created_201: return "Created"; + case StatusCode::Accepted_202: return "Accepted"; + case StatusCode::NonAuthoritativeInformation_203: + return "Non-Authoritative Information"; + case StatusCode::NoContent_204: return "No Content"; + case StatusCode::ResetContent_205: return "Reset Content"; + case StatusCode::PartialContent_206: return "Partial Content"; + case StatusCode::MultiStatus_207: return "Multi-Status"; + case StatusCode::AlreadyReported_208: return "Already Reported"; + case StatusCode::IMUsed_226: return "IM Used"; + case StatusCode::MultipleChoices_300: return "Multiple Choices"; + case StatusCode::MovedPermanently_301: return "Moved Permanently"; + case StatusCode::Found_302: return "Found"; + case StatusCode::SeeOther_303: return "See Other"; + case StatusCode::NotModified_304: return "Not Modified"; + case StatusCode::UseProxy_305: return "Use Proxy"; + case StatusCode::unused_306: return "unused"; + case StatusCode::TemporaryRedirect_307: return "Temporary Redirect"; + case StatusCode::PermanentRedirect_308: return "Permanent Redirect"; + case StatusCode::BadRequest_400: return "Bad Request"; + case StatusCode::Unauthorized_401: return "Unauthorized"; + case StatusCode::PaymentRequired_402: return "Payment Required"; + case StatusCode::Forbidden_403: return "Forbidden"; + case StatusCode::NotFound_404: return "Not Found"; + case StatusCode::MethodNotAllowed_405: return "Method Not Allowed"; + case StatusCode::NotAcceptable_406: return "Not Acceptable"; + case StatusCode::ProxyAuthenticationRequired_407: + return "Proxy Authentication Required"; + case StatusCode::RequestTimeout_408: return "Request Timeout"; + case StatusCode::Conflict_409: return "Conflict"; + case StatusCode::Gone_410: return "Gone"; + case StatusCode::LengthRequired_411: return "Length Required"; + case StatusCode::PreconditionFailed_412: return "Precondition Failed"; + case StatusCode::PayloadTooLarge_413: return "Payload Too Large"; + case StatusCode::UriTooLong_414: return "URI Too Long"; + case StatusCode::UnsupportedMediaType_415: return "Unsupported Media Type"; + case StatusCode::RangeNotSatisfiable_416: return "Range Not Satisfiable"; + case StatusCode::ExpectationFailed_417: return "Expectation Failed"; + case StatusCode::ImATeapot_418: return "I'm a teapot"; + case StatusCode::MisdirectedRequest_421: return "Misdirected Request"; + case StatusCode::UnprocessableContent_422: return "Unprocessable Content"; + case StatusCode::Locked_423: return "Locked"; + case StatusCode::FailedDependency_424: return "Failed Dependency"; + case StatusCode::TooEarly_425: return "Too Early"; + case StatusCode::UpgradeRequired_426: return "Upgrade Required"; + case StatusCode::PreconditionRequired_428: return "Precondition Required"; + case StatusCode::TooManyRequests_429: return "Too Many Requests"; + case StatusCode::RequestHeaderFieldsTooLarge_431: + return "Request Header Fields Too Large"; + case StatusCode::UnavailableForLegalReasons_451: + return "Unavailable For Legal Reasons"; + case StatusCode::NotImplemented_501: return "Not Implemented"; + case StatusCode::BadGateway_502: return "Bad Gateway"; + case StatusCode::ServiceUnavailable_503: return "Service Unavailable"; + case StatusCode::GatewayTimeout_504: return "Gateway Timeout"; + case StatusCode::HttpVersionNotSupported_505: + return "HTTP Version Not Supported"; + case StatusCode::VariantAlsoNegotiates_506: return "Variant Also Negotiates"; + case StatusCode::InsufficientStorage_507: return "Insufficient Storage"; + case StatusCode::LoopDetected_508: return "Loop Detected"; + case StatusCode::NotExtended_510: return "Not Extended"; + case StatusCode::NetworkAuthenticationRequired_511: + return "Network Authentication Required"; + + default: + case StatusCode::InternalServerError_500: return "Internal Server Error"; + } +} + +inline std::string get_bearer_token_auth(const Request &req) { + if (req.has_header("Authorization")) { + static std::string BearerHeaderPrefix = "Bearer "; + return req.get_header_value("Authorization") + .substr(BearerHeaderPrefix.length()); + } + return ""; +} + +template +inline Server & +Server::set_read_timeout(const std::chrono::duration &duration) { + detail::duration_to_sec_and_usec( + duration, [&](time_t sec, time_t usec) { set_read_timeout(sec, usec); }); + return *this; +} + +template +inline Server & +Server::set_write_timeout(const std::chrono::duration &duration) { + detail::duration_to_sec_and_usec( + duration, [&](time_t sec, time_t usec) { set_write_timeout(sec, usec); }); + return *this; +} + +template +inline Server & +Server::set_idle_interval(const std::chrono::duration &duration) { + detail::duration_to_sec_and_usec( + duration, [&](time_t sec, time_t usec) { set_idle_interval(sec, usec); }); + return *this; +} + +inline std::string to_string(const Error error) { + switch (error) { + case Error::Success: return "Success (no error)"; + case Error::Connection: return "Could not establish connection"; + case Error::BindIPAddress: return "Failed to bind IP address"; + case Error::Read: return "Failed to read connection"; + case Error::Write: return "Failed to write connection"; + case Error::ExceedRedirectCount: return "Maximum redirect count exceeded"; + case Error::Canceled: return "Connection handling canceled"; + case Error::SSLConnection: return "SSL connection failed"; + case Error::SSLLoadingCerts: return "SSL certificate loading failed"; + case Error::SSLServerVerification: return "SSL server verification failed"; + case Error::SSLServerHostnameVerification: + return "SSL server hostname verification failed"; + case Error::UnsupportedMultipartBoundaryChars: + return "Unsupported HTTP multipart boundary characters"; + case Error::Compression: return "Compression failed"; + case Error::ConnectionTimeout: return "Connection timed out"; + case Error::ProxyConnection: return "Proxy connection failed"; + case Error::Unknown: return "Unknown"; + default: break; + } + + return "Invalid"; +} + +inline std::ostream &operator<<(std::ostream &os, const Error &obj) { + os << to_string(obj); + os << " (" << static_cast::type>(obj) << ')'; + return os; +} + +inline uint64_t Result::get_request_header_value_u64(const std::string &key, + uint64_t def, + size_t id) const { + return detail::get_header_value_u64(request_headers_, key, def, id); +} + +template +inline void ClientImpl::set_connection_timeout( + const std::chrono::duration &duration) { + detail::duration_to_sec_and_usec(duration, [&](time_t sec, time_t usec) { + set_connection_timeout(sec, usec); + }); +} + +template +inline void ClientImpl::set_read_timeout( + const std::chrono::duration &duration) { + detail::duration_to_sec_and_usec( + duration, [&](time_t sec, time_t usec) { set_read_timeout(sec, usec); }); +} + +template +inline void ClientImpl::set_write_timeout( + const std::chrono::duration &duration) { + detail::duration_to_sec_and_usec( + duration, [&](time_t sec, time_t usec) { set_write_timeout(sec, usec); }); +} + +template +inline void Client::set_connection_timeout( + const std::chrono::duration &duration) { + cli_->set_connection_timeout(duration); +} + +template +inline void +Client::set_read_timeout(const std::chrono::duration &duration) { + cli_->set_read_timeout(duration); +} + +template +inline void +Client::set_write_timeout(const std::chrono::duration &duration) { + cli_->set_write_timeout(duration); +} + +/* + * Forward declarations and types that will be part of the .h file if split into + * .h + .cc. + */ + +std::string hosted_at(const std::string &hostname); + +void hosted_at(const std::string &hostname, std::vector &addrs); + +std::string append_query_params(const std::string &path, const Params ¶ms); + +std::pair make_range_header(const Ranges &ranges); + +std::pair +make_basic_authentication_header(const std::string &username, + const std::string &password, + bool is_proxy = false); + +namespace detail { + +struct FileStat { + FileStat(const std::string &path); + bool is_file() const; + bool is_dir() const; + +private: + struct stat st_; + int ret_ = -1; +}; + +std::string encode_query_param(const std::string &value); + +std::string decode_url(const std::string &s, bool convert_plus_to_space); + +void read_file(const std::string &path, std::string &out); + +std::string trim_copy(const std::string &s); + +void divide( + const char *data, std::size_t size, char d, + std::function + fn); + +void divide( + const std::string &str, char d, + std::function + fn); + +void split(const char *b, const char *e, char d, + std::function fn); + +void split(const char *b, const char *e, char d, size_t m, + std::function fn); + +bool process_client_socket(socket_t sock, time_t read_timeout_sec, + time_t read_timeout_usec, time_t write_timeout_sec, + time_t write_timeout_usec, + std::function callback); + +socket_t create_client_socket(const std::string &host, const std::string &ip, + int port, int address_family, bool tcp_nodelay, + bool ipv6_v6only, SocketOptions socket_options, + time_t connection_timeout_sec, + time_t connection_timeout_usec, + time_t read_timeout_sec, time_t read_timeout_usec, + time_t write_timeout_sec, + time_t write_timeout_usec, + const std::string &intf, Error &error); + +const char *get_header_value(const Headers &headers, const std::string &key, + const char *def, size_t id); + +std::string params_to_query_str(const Params ¶ms); + +void parse_query_text(const char *data, std::size_t size, Params ¶ms); + +void parse_query_text(const std::string &s, Params ¶ms); + +bool parse_multipart_boundary(const std::string &content_type, + std::string &boundary); + +bool parse_range_header(const std::string &s, Ranges &ranges); + +int close_socket(socket_t sock); + +ssize_t send_socket(socket_t sock, const void *ptr, size_t size, int flags); + +ssize_t read_socket(socket_t sock, void *ptr, size_t size, int flags); + +enum class EncodingType { None = 0, Gzip, Brotli }; + +EncodingType encoding_type(const Request &req, const Response &res); + +class BufferStream final : public Stream { +public: + BufferStream() = default; + ~BufferStream() override = default; + + bool is_readable() const override; + bool is_writable() const override; + ssize_t read(char *ptr, size_t size) override; + ssize_t write(const char *ptr, size_t size) override; + void get_remote_ip_and_port(std::string &ip, int &port) const override; + void get_local_ip_and_port(std::string &ip, int &port) const override; + socket_t socket() const override; + + const std::string &get_buffer() const; + +private: + std::string buffer; + size_t position = 0; +}; + +class compressor { +public: + virtual ~compressor() = default; + + typedef std::function Callback; + virtual bool compress(const char *data, size_t data_length, bool last, + Callback callback) = 0; +}; + +class decompressor { +public: + virtual ~decompressor() = default; + + virtual bool is_valid() const = 0; + + typedef std::function Callback; + virtual bool decompress(const char *data, size_t data_length, + Callback callback) = 0; +}; + +class nocompressor final : public compressor { +public: + ~nocompressor() override = default; + + bool compress(const char *data, size_t data_length, bool /*last*/, + Callback callback) override; +}; + +#ifdef CPPHTTPLIB_ZLIB_SUPPORT +class gzip_compressor final : public compressor { +public: + gzip_compressor(); + ~gzip_compressor() override; + + bool compress(const char *data, size_t data_length, bool last, + Callback callback) override; + +private: + bool is_valid_ = false; + z_stream strm_; +}; + +class gzip_decompressor final : public decompressor { +public: + gzip_decompressor(); + ~gzip_decompressor() override; + + bool is_valid() const override; + + bool decompress(const char *data, size_t data_length, + Callback callback) override; + +private: + bool is_valid_ = false; + z_stream strm_; +}; +#endif + +#ifdef CPPHTTPLIB_BROTLI_SUPPORT +class brotli_compressor final : public compressor { +public: + brotli_compressor(); + ~brotli_compressor(); + + bool compress(const char *data, size_t data_length, bool last, + Callback callback) override; + +private: + BrotliEncoderState *state_ = nullptr; +}; + +class brotli_decompressor final : public decompressor { +public: + brotli_decompressor(); + ~brotli_decompressor(); + + bool is_valid() const override; + + bool decompress(const char *data, size_t data_length, + Callback callback) override; + +private: + BrotliDecoderResult decoder_r; + BrotliDecoderState *decoder_s = nullptr; +}; +#endif + +// NOTE: until the read size reaches `fixed_buffer_size`, use `fixed_buffer` +// to store data. The call can set memory on stack for performance. +class stream_line_reader { +public: + stream_line_reader(Stream &strm, char *fixed_buffer, + size_t fixed_buffer_size); + const char *ptr() const; + size_t size() const; + bool end_with_crlf() const; + bool getline(); + +private: + void append(char c); + + Stream &strm_; + char *fixed_buffer_; + const size_t fixed_buffer_size_; + size_t fixed_buffer_used_size_ = 0; + std::string glowable_buffer_; +}; + +class mmap { +public: + mmap(const char *path); + ~mmap(); + + bool open(const char *path); + void close(); + + bool is_open() const; + size_t size() const; + const char *data() const; + +private: +#if defined(_WIN32) + HANDLE hFile_ = NULL; + HANDLE hMapping_ = NULL; +#else + int fd_ = -1; +#endif + size_t size_ = 0; + void *addr_ = nullptr; + bool is_open_empty_file = false; +}; + +} // namespace detail + +// ---------------------------------------------------------------------------- + +/* + * Implementation that will be part of the .cc file if split into .h + .cc. + */ + +namespace detail { + +inline bool is_hex(char c, int &v) { + if (0x20 <= c && isdigit(c)) { + v = c - '0'; + return true; + } else if ('A' <= c && c <= 'F') { + v = c - 'A' + 10; + return true; + } else if ('a' <= c && c <= 'f') { + v = c - 'a' + 10; + return true; + } + return false; +} + +inline bool from_hex_to_i(const std::string &s, size_t i, size_t cnt, + int &val) { + if (i >= s.size()) { return false; } + + val = 0; + for (; cnt; i++, cnt--) { + if (!s[i]) { return false; } + auto v = 0; + if (is_hex(s[i], v)) { + val = val * 16 + v; + } else { + return false; + } + } + return true; +} + +inline std::string from_i_to_hex(size_t n) { + static const auto charset = "0123456789abcdef"; + std::string ret; + do { + ret = charset[n & 15] + ret; + n >>= 4; + } while (n > 0); + return ret; +} + +inline size_t to_utf8(int code, char *buff) { + if (code < 0x0080) { + buff[0] = static_cast(code & 0x7F); + return 1; + } else if (code < 0x0800) { + buff[0] = static_cast(0xC0 | ((code >> 6) & 0x1F)); + buff[1] = static_cast(0x80 | (code & 0x3F)); + return 2; + } else if (code < 0xD800) { + buff[0] = static_cast(0xE0 | ((code >> 12) & 0xF)); + buff[1] = static_cast(0x80 | ((code >> 6) & 0x3F)); + buff[2] = static_cast(0x80 | (code & 0x3F)); + return 3; + } else if (code < 0xE000) { // D800 - DFFF is invalid... + return 0; + } else if (code < 0x10000) { + buff[0] = static_cast(0xE0 | ((code >> 12) & 0xF)); + buff[1] = static_cast(0x80 | ((code >> 6) & 0x3F)); + buff[2] = static_cast(0x80 | (code & 0x3F)); + return 3; + } else if (code < 0x110000) { + buff[0] = static_cast(0xF0 | ((code >> 18) & 0x7)); + buff[1] = static_cast(0x80 | ((code >> 12) & 0x3F)); + buff[2] = static_cast(0x80 | ((code >> 6) & 0x3F)); + buff[3] = static_cast(0x80 | (code & 0x3F)); + return 4; + } + + // NOTREACHED + return 0; +} + +// NOTE: This code came up with the following stackoverflow post: +// https://stackoverflow.com/questions/180947/base64-decode-snippet-in-c +inline std::string base64_encode(const std::string &in) { + static const auto lookup = + "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; + + std::string out; + out.reserve(in.size()); + + auto val = 0; + auto valb = -6; + + for (auto c : in) { + val = (val << 8) + static_cast(c); + valb += 8; + while (valb >= 0) { + out.push_back(lookup[(val >> valb) & 0x3F]); + valb -= 6; + } + } + + if (valb > -6) { out.push_back(lookup[((val << 8) >> (valb + 8)) & 0x3F]); } + + while (out.size() % 4) { + out.push_back('='); + } + + return out; +} + +inline bool is_valid_path(const std::string &path) { + size_t level = 0; + size_t i = 0; + + // Skip slash + while (i < path.size() && path[i] == '/') { + i++; + } + + while (i < path.size()) { + // Read component + auto beg = i; + while (i < path.size() && path[i] != '/') { + if (path[i] == '\0') { + return false; + } else if (path[i] == '\\') { + return false; + } + i++; + } + + auto len = i - beg; + assert(len > 0); + + if (!path.compare(beg, len, ".")) { + ; + } else if (!path.compare(beg, len, "..")) { + if (level == 0) { return false; } + level--; + } else { + level++; + } + + // Skip slash + while (i < path.size() && path[i] == '/') { + i++; + } + } + + return true; +} + +inline FileStat::FileStat(const std::string &path) { + ret_ = stat(path.c_str(), &st_); +} +inline bool FileStat::is_file() const { + return ret_ >= 0 && S_ISREG(st_.st_mode); +} +inline bool FileStat::is_dir() const { + return ret_ >= 0 && S_ISDIR(st_.st_mode); +} + +inline std::string encode_query_param(const std::string &value) { + std::ostringstream escaped; + escaped.fill('0'); + escaped << std::hex; + + for (auto c : value) { + if (std::isalnum(static_cast(c)) || c == '-' || c == '_' || + c == '.' || c == '!' || c == '~' || c == '*' || c == '\'' || c == '(' || + c == ')') { + escaped << c; + } else { + escaped << std::uppercase; + escaped << '%' << std::setw(2) + << static_cast(static_cast(c)); + escaped << std::nouppercase; + } + } + + return escaped.str(); +} + +inline std::string encode_url(const std::string &s) { + std::string result; + result.reserve(s.size()); + + for (size_t i = 0; s[i]; i++) { + switch (s[i]) { + case ' ': result += "%20"; break; + case '+': result += "%2B"; break; + case '\r': result += "%0D"; break; + case '\n': result += "%0A"; break; + case '\'': result += "%27"; break; + case ',': result += "%2C"; break; + // case ':': result += "%3A"; break; // ok? probably... + case ';': result += "%3B"; break; + default: + auto c = static_cast(s[i]); + if (c >= 0x80) { + result += '%'; + char hex[4]; + auto len = snprintf(hex, sizeof(hex) - 1, "%02X", c); + assert(len == 2); + result.append(hex, static_cast(len)); + } else { + result += s[i]; + } + break; + } + } + + return result; +} + +inline std::string decode_url(const std::string &s, + bool convert_plus_to_space) { + std::string result; + + for (size_t i = 0; i < s.size(); i++) { + if (s[i] == '%' && i + 1 < s.size()) { + if (s[i + 1] == 'u') { + auto val = 0; + if (from_hex_to_i(s, i + 2, 4, val)) { + // 4 digits Unicode codes + char buff[4]; + size_t len = to_utf8(val, buff); + if (len > 0) { result.append(buff, len); } + i += 5; // 'u0000' + } else { + result += s[i]; + } + } else { + auto val = 0; + if (from_hex_to_i(s, i + 1, 2, val)) { + // 2 digits hex codes + result += static_cast(val); + i += 2; // '00' + } else { + result += s[i]; + } + } + } else if (convert_plus_to_space && s[i] == '+') { + result += ' '; + } else { + result += s[i]; + } + } + + return result; +} + +inline void read_file(const std::string &path, std::string &out) { + std::ifstream fs(path, std::ios_base::binary); + fs.seekg(0, std::ios_base::end); + auto size = fs.tellg(); + fs.seekg(0); + out.resize(static_cast(size)); + fs.read(&out[0], static_cast(size)); +} + +inline std::string file_extension(const std::string &path) { + std::smatch m; + static auto re = std::regex("\\.([a-zA-Z0-9]+)$"); + if (std::regex_search(path, m, re)) { return m[1].str(); } + return std::string(); +} + +inline bool is_space_or_tab(char c) { return c == ' ' || c == '\t'; } + +inline std::pair trim(const char *b, const char *e, size_t left, + size_t right) { + while (b + left < e && is_space_or_tab(b[left])) { + left++; + } + while (right > 0 && is_space_or_tab(b[right - 1])) { + right--; + } + return std::make_pair(left, right); +} + +inline std::string trim_copy(const std::string &s) { + auto r = trim(s.data(), s.data() + s.size(), 0, s.size()); + return s.substr(r.first, r.second - r.first); +} + +inline std::string trim_double_quotes_copy(const std::string &s) { + if (s.length() >= 2 && s.front() == '"' && s.back() == '"') { + return s.substr(1, s.size() - 2); + } + return s; +} + +inline void +divide(const char *data, std::size_t size, char d, + std::function + fn) { + const auto it = std::find(data, data + size, d); + const auto found = static_cast(it != data + size); + const auto lhs_data = data; + const auto lhs_size = static_cast(it - data); + const auto rhs_data = it + found; + const auto rhs_size = size - lhs_size - found; + + fn(lhs_data, lhs_size, rhs_data, rhs_size); +} + +inline void +divide(const std::string &str, char d, + std::function + fn) { + divide(str.data(), str.size(), d, std::move(fn)); +} + +inline void split(const char *b, const char *e, char d, + std::function fn) { + return split(b, e, d, (std::numeric_limits::max)(), std::move(fn)); +} + +inline void split(const char *b, const char *e, char d, size_t m, + std::function fn) { + size_t i = 0; + size_t beg = 0; + size_t count = 1; + + while (e ? (b + i < e) : (b[i] != '\0')) { + if (b[i] == d && count < m) { + auto r = trim(b, e, beg, i); + if (r.first < r.second) { fn(&b[r.first], &b[r.second]); } + beg = i + 1; + count++; + } + i++; + } + + if (i) { + auto r = trim(b, e, beg, i); + if (r.first < r.second) { fn(&b[r.first], &b[r.second]); } + } +} + +inline stream_line_reader::stream_line_reader(Stream &strm, char *fixed_buffer, + size_t fixed_buffer_size) + : strm_(strm), fixed_buffer_(fixed_buffer), + fixed_buffer_size_(fixed_buffer_size) {} + +inline const char *stream_line_reader::ptr() const { + if (glowable_buffer_.empty()) { + return fixed_buffer_; + } else { + return glowable_buffer_.data(); + } +} + +inline size_t stream_line_reader::size() const { + if (glowable_buffer_.empty()) { + return fixed_buffer_used_size_; + } else { + return glowable_buffer_.size(); + } +} + +inline bool stream_line_reader::end_with_crlf() const { + auto end = ptr() + size(); + return size() >= 2 && end[-2] == '\r' && end[-1] == '\n'; +} + +inline bool stream_line_reader::getline() { + fixed_buffer_used_size_ = 0; + glowable_buffer_.clear(); + +#ifndef CPPHTTPLIB_ALLOW_LF_AS_LINE_TERMINATOR + char prev_byte = 0; +#endif + + for (size_t i = 0;; i++) { + char byte; + auto n = strm_.read(&byte, 1); + + if (n < 0) { + return false; + } else if (n == 0) { + if (i == 0) { + return false; + } else { + break; + } + } + + append(byte); + +#ifdef CPPHTTPLIB_ALLOW_LF_AS_LINE_TERMINATOR + if (byte == '\n') { break; } +#else + if (prev_byte == '\r' && byte == '\n') { break; } + prev_byte = byte; +#endif + } + + return true; +} + +inline void stream_line_reader::append(char c) { + if (fixed_buffer_used_size_ < fixed_buffer_size_ - 1) { + fixed_buffer_[fixed_buffer_used_size_++] = c; + fixed_buffer_[fixed_buffer_used_size_] = '\0'; + } else { + if (glowable_buffer_.empty()) { + assert(fixed_buffer_[fixed_buffer_used_size_] == '\0'); + glowable_buffer_.assign(fixed_buffer_, fixed_buffer_used_size_); + } + glowable_buffer_ += c; + } +} + +inline mmap::mmap(const char *path) { + open(path); +} + +inline mmap::~mmap() { close(); } + +inline bool mmap::open(const char *path) { + close(); + +#if defined(_WIN32) + std::wstring wpath; + for (size_t i = 0; i < strlen(path); i++) { + wpath += path[i]; + } + +#if _WIN32_WINNT >= _WIN32_WINNT_WIN8 + hFile_ = ::CreateFile2(wpath.c_str(), GENERIC_READ, FILE_SHARE_READ, + OPEN_EXISTING, NULL); +#else + hFile_ = ::CreateFileW(wpath.c_str(), GENERIC_READ, FILE_SHARE_READ, NULL, + OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); +#endif + + if (hFile_ == INVALID_HANDLE_VALUE) { return false; } + + LARGE_INTEGER size{}; + if (!::GetFileSizeEx(hFile_, &size)) { return false; } + // If the following line doesn't compile due to QuadPart, update Windows SDK. + // See: + // https://github.com/yhirose/cpp-httplib/issues/1903#issuecomment-2316520721 + if (static_cast(size.QuadPart) > + (std::numeric_limits::max)()) { + // `size_t` might be 32-bits, on 32-bits Windows. + return false; + } + size_ = static_cast(size.QuadPart); + +#if _WIN32_WINNT >= _WIN32_WINNT_WIN8 + hMapping_ = + ::CreateFileMappingFromApp(hFile_, NULL, PAGE_READONLY, size_, NULL); +#else + hMapping_ = ::CreateFileMappingW(hFile_, NULL, PAGE_READONLY, 0, 0, NULL); +#endif + + // Special treatment for an empty file... + if (hMapping_ == NULL && size_ == 0) { + close(); + is_open_empty_file = true; + return true; + } + + if (hMapping_ == NULL) { + close(); + return false; + } + +#if _WIN32_WINNT >= _WIN32_WINNT_WIN8 + addr_ = ::MapViewOfFileFromApp(hMapping_, FILE_MAP_READ, 0, 0); +#else + addr_ = ::MapViewOfFile(hMapping_, FILE_MAP_READ, 0, 0, 0); +#endif + + if (addr_ == nullptr) { + close(); + return false; + } +#else + fd_ = ::open(path, O_RDONLY); + if (fd_ == -1) { return false; } + + struct stat sb; + if (fstat(fd_, &sb) == -1) { + close(); + return false; + } + size_ = static_cast(sb.st_size); + + addr_ = ::mmap(NULL, size_, PROT_READ, MAP_PRIVATE, fd_, 0); + + // Special treatment for an empty file... + if (addr_ == MAP_FAILED && size_ == 0) { + close(); + is_open_empty_file = true; + return false; + } +#endif + + return true; +} + +inline bool mmap::is_open() const { + return is_open_empty_file ? true : addr_ != nullptr; +} + +inline size_t mmap::size() const { return size_; } + +inline const char *mmap::data() const { + return is_open_empty_file ? "" : static_cast(addr_); +} + +inline void mmap::close() { +#if defined(_WIN32) + if (addr_) { + ::UnmapViewOfFile(addr_); + addr_ = nullptr; + } + + if (hMapping_) { + ::CloseHandle(hMapping_); + hMapping_ = NULL; + } + + if (hFile_ != INVALID_HANDLE_VALUE) { + ::CloseHandle(hFile_); + hFile_ = INVALID_HANDLE_VALUE; + } + + is_open_empty_file = false; +#else + if (addr_ != nullptr) { + munmap(addr_, size_); + addr_ = nullptr; + } + + if (fd_ != -1) { + ::close(fd_); + fd_ = -1; + } +#endif + size_ = 0; +} +inline int close_socket(socket_t sock) { +#ifdef _WIN32 + return closesocket(sock); +#else + return close(sock); +#endif +} + +template inline ssize_t handle_EINTR(T fn) { + ssize_t res = 0; + while (true) { + res = fn(); + if (res < 0 && errno == EINTR) { + std::this_thread::sleep_for(std::chrono::microseconds{1}); + continue; + } + break; + } + return res; +} + +inline ssize_t read_socket(socket_t sock, void *ptr, size_t size, int flags) { + return handle_EINTR([&]() { + return recv(sock, +#ifdef _WIN32 + static_cast(ptr), static_cast(size), +#else + ptr, size, +#endif + flags); + }); +} + +inline ssize_t send_socket(socket_t sock, const void *ptr, size_t size, + int flags) { + return handle_EINTR([&]() { + return send(sock, +#ifdef _WIN32 + static_cast(ptr), static_cast(size), +#else + ptr, size, +#endif + flags); + }); +} + +inline ssize_t select_read(socket_t sock, time_t sec, time_t usec) { +#ifdef CPPHTTPLIB_USE_POLL + struct pollfd pfd_read; + pfd_read.fd = sock; + pfd_read.events = POLLIN; + + auto timeout = static_cast(sec * 1000 + usec / 1000); + + return handle_EINTR([&]() { return poll(&pfd_read, 1, timeout); }); +#else +#ifndef _WIN32 + if (sock >= FD_SETSIZE) { return -1; } +#endif + + fd_set fds; + FD_ZERO(&fds); + FD_SET(sock, &fds); + + timeval tv; + tv.tv_sec = static_cast(sec); + tv.tv_usec = static_cast(usec); + + return handle_EINTR([&]() { + return select(static_cast(sock + 1), &fds, nullptr, nullptr, &tv); + }); +#endif +} + +inline ssize_t select_write(socket_t sock, time_t sec, time_t usec) { +#ifdef CPPHTTPLIB_USE_POLL + struct pollfd pfd_read; + pfd_read.fd = sock; + pfd_read.events = POLLOUT; + + auto timeout = static_cast(sec * 1000 + usec / 1000); + + return handle_EINTR([&]() { return poll(&pfd_read, 1, timeout); }); +#else +#ifndef _WIN32 + if (sock >= FD_SETSIZE) { return -1; } +#endif + + fd_set fds; + FD_ZERO(&fds); + FD_SET(sock, &fds); + + timeval tv; + tv.tv_sec = static_cast(sec); + tv.tv_usec = static_cast(usec); + + return handle_EINTR([&]() { + return select(static_cast(sock + 1), nullptr, &fds, nullptr, &tv); + }); +#endif +} + +inline Error wait_until_socket_is_ready(socket_t sock, time_t sec, + time_t usec) { +#ifdef CPPHTTPLIB_USE_POLL + struct pollfd pfd_read; + pfd_read.fd = sock; + pfd_read.events = POLLIN | POLLOUT; + + auto timeout = static_cast(sec * 1000 + usec / 1000); + + auto poll_res = handle_EINTR([&]() { return poll(&pfd_read, 1, timeout); }); + + if (poll_res == 0) { return Error::ConnectionTimeout; } + + if (poll_res > 0 && pfd_read.revents & (POLLIN | POLLOUT)) { + auto error = 0; + socklen_t len = sizeof(error); + auto res = getsockopt(sock, SOL_SOCKET, SO_ERROR, + reinterpret_cast(&error), &len); + auto successful = res >= 0 && !error; + return successful ? Error::Success : Error::Connection; + } + + return Error::Connection; +#else +#ifndef _WIN32 + if (sock >= FD_SETSIZE) { return Error::Connection; } +#endif + + fd_set fdsr; + FD_ZERO(&fdsr); + FD_SET(sock, &fdsr); + + auto fdsw = fdsr; + auto fdse = fdsr; + + timeval tv; + tv.tv_sec = static_cast(sec); + tv.tv_usec = static_cast(usec); + + auto ret = handle_EINTR([&]() { + return select(static_cast(sock + 1), &fdsr, &fdsw, &fdse, &tv); + }); + + if (ret == 0) { return Error::ConnectionTimeout; } + + if (ret > 0 && (FD_ISSET(sock, &fdsr) || FD_ISSET(sock, &fdsw))) { + auto error = 0; + socklen_t len = sizeof(error); + auto res = getsockopt(sock, SOL_SOCKET, SO_ERROR, + reinterpret_cast(&error), &len); + auto successful = res >= 0 && !error; + return successful ? Error::Success : Error::Connection; + } + return Error::Connection; +#endif +} + +inline bool is_socket_alive(socket_t sock) { + const auto val = detail::select_read(sock, 0, 0); + if (val == 0) { + return true; + } else if (val < 0 && errno == EBADF) { + return false; + } + char buf[1]; + return detail::read_socket(sock, &buf[0], sizeof(buf), MSG_PEEK) > 0; +} + +class SocketStream final : public Stream { +public: + SocketStream(socket_t sock, time_t read_timeout_sec, time_t read_timeout_usec, + time_t write_timeout_sec, time_t write_timeout_usec); + ~SocketStream() override; + + bool is_readable() const override; + bool is_writable() const override; + ssize_t read(char *ptr, size_t size) override; + ssize_t write(const char *ptr, size_t size) override; + void get_remote_ip_and_port(std::string &ip, int &port) const override; + void get_local_ip_and_port(std::string &ip, int &port) const override; + socket_t socket() const override; + +private: + socket_t sock_; + time_t read_timeout_sec_; + time_t read_timeout_usec_; + time_t write_timeout_sec_; + time_t write_timeout_usec_; + + std::vector read_buff_; + size_t read_buff_off_ = 0; + size_t read_buff_content_size_ = 0; + + static const size_t read_buff_size_ = 1024l * 4; +}; + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +class SSLSocketStream final : public Stream { +public: + SSLSocketStream(socket_t sock, SSL *ssl, time_t read_timeout_sec, + time_t read_timeout_usec, time_t write_timeout_sec, + time_t write_timeout_usec); + ~SSLSocketStream() override; + + bool is_readable() const override; + bool is_writable() const override; + ssize_t read(char *ptr, size_t size) override; + ssize_t write(const char *ptr, size_t size) override; + void get_remote_ip_and_port(std::string &ip, int &port) const override; + void get_local_ip_and_port(std::string &ip, int &port) const override; + socket_t socket() const override; + +private: + socket_t sock_; + SSL *ssl_; + time_t read_timeout_sec_; + time_t read_timeout_usec_; + time_t write_timeout_sec_; + time_t write_timeout_usec_; +}; +#endif + +template +inline bool +process_server_socket_core(const std::atomic &svr_sock, socket_t sock, + size_t keep_alive_max_count, + time_t keep_alive_timeout_sec, T callback) { + assert(keep_alive_max_count > 0); + auto ret = false; + auto count = keep_alive_max_count; + while (svr_sock != INVALID_SOCKET && count > 0 && + select_read(sock, keep_alive_timeout_sec, 0) > 0) { + auto close_connection = count == 1; + auto connection_closed = false; + ret = callback(close_connection, connection_closed); + if (!ret || connection_closed) { break; } + count--; + } + return ret; +} + +template +inline bool +process_server_socket(const std::atomic &svr_sock, socket_t sock, + size_t keep_alive_max_count, + time_t keep_alive_timeout_sec, time_t read_timeout_sec, + time_t read_timeout_usec, time_t write_timeout_sec, + time_t write_timeout_usec, T callback) { + return process_server_socket_core( + svr_sock, sock, keep_alive_max_count, keep_alive_timeout_sec, + [&](bool close_connection, bool &connection_closed) { + SocketStream strm(sock, read_timeout_sec, read_timeout_usec, + write_timeout_sec, write_timeout_usec); + return callback(strm, close_connection, connection_closed); + }); +} + +inline bool process_client_socket(socket_t sock, time_t read_timeout_sec, + time_t read_timeout_usec, + time_t write_timeout_sec, + time_t write_timeout_usec, + std::function callback) { + SocketStream strm(sock, read_timeout_sec, read_timeout_usec, + write_timeout_sec, write_timeout_usec); + return callback(strm); +} + +inline int shutdown_socket(socket_t sock) { +#ifdef _WIN32 + return shutdown(sock, SD_BOTH); +#else + return shutdown(sock, SHUT_RDWR); +#endif +} + +inline std::string escape_abstract_namespace_unix_domain(const std::string &s) { + if (s.size() > 1 && s[0] == '\0') { + auto ret = s; + ret[0] = '@'; + return ret; + } + return s; +} + +inline std::string +unescape_abstract_namespace_unix_domain(const std::string &s) { + if (s.size() > 1 && s[0] == '@') { + auto ret = s; + ret[0] = '\0'; + return ret; + } + return s; +} + +template +socket_t create_socket(const std::string &host, const std::string &ip, int port, + int address_family, int socket_flags, bool tcp_nodelay, + bool ipv6_v6only, SocketOptions socket_options, + BindOrConnect bind_or_connect) { + // Get address info + const char *node = nullptr; + struct addrinfo hints; + struct addrinfo *result; + + memset(&hints, 0, sizeof(struct addrinfo)); + hints.ai_socktype = SOCK_STREAM; + hints.ai_protocol = IPPROTO_IP; + + if (!ip.empty()) { + node = ip.c_str(); + // Ask getaddrinfo to convert IP in c-string to address + hints.ai_family = AF_UNSPEC; + hints.ai_flags = AI_NUMERICHOST; + } else { + if (!host.empty()) { node = host.c_str(); } + hints.ai_family = address_family; + hints.ai_flags = socket_flags; + } + +#ifndef _WIN32 + if (hints.ai_family == AF_UNIX) { + const auto addrlen = host.length(); + if (addrlen > sizeof(sockaddr_un::sun_path)) { return INVALID_SOCKET; } + +#ifdef SOCK_CLOEXEC + auto sock = socket(hints.ai_family, hints.ai_socktype | SOCK_CLOEXEC, + hints.ai_protocol); +#else + auto sock = socket(hints.ai_family, hints.ai_socktype, hints.ai_protocol); +#endif + + if (sock != INVALID_SOCKET) { + sockaddr_un addr{}; + addr.sun_family = AF_UNIX; + + auto unescaped_host = unescape_abstract_namespace_unix_domain(host); + std::copy(unescaped_host.begin(), unescaped_host.end(), addr.sun_path); + + hints.ai_addr = reinterpret_cast(&addr); + hints.ai_addrlen = static_cast( + sizeof(addr) - sizeof(addr.sun_path) + addrlen); + +#ifndef SOCK_CLOEXEC + fcntl(sock, F_SETFD, FD_CLOEXEC); +#endif + + if (socket_options) { socket_options(sock); } + + bool dummy; + if (!bind_or_connect(sock, hints, dummy)) { + close_socket(sock); + sock = INVALID_SOCKET; + } + } + return sock; + } +#endif + + auto service = std::to_string(port); + + if (getaddrinfo(node, service.c_str(), &hints, &result)) { +#if defined __linux__ && !defined __ANDROID__ + res_init(); +#endif + return INVALID_SOCKET; + } + auto se = detail::scope_exit([&] { freeaddrinfo(result); }); + + for (auto rp = result; rp; rp = rp->ai_next) { + // Create a socket +#ifdef _WIN32 + auto sock = + WSASocketW(rp->ai_family, rp->ai_socktype, rp->ai_protocol, nullptr, 0, + WSA_FLAG_NO_HANDLE_INHERIT | WSA_FLAG_OVERLAPPED); + /** + * Since the WSA_FLAG_NO_HANDLE_INHERIT is only supported on Windows 7 SP1 + * and above the socket creation fails on older Windows Systems. + * + * Let's try to create a socket the old way in this case. + * + * Reference: + * https://docs.microsoft.com/en-us/windows/win32/api/winsock2/nf-winsock2-wsasocketa + * + * WSA_FLAG_NO_HANDLE_INHERIT: + * This flag is supported on Windows 7 with SP1, Windows Server 2008 R2 with + * SP1, and later + * + */ + if (sock == INVALID_SOCKET) { + sock = socket(rp->ai_family, rp->ai_socktype, rp->ai_protocol); + } +#else + +#ifdef SOCK_CLOEXEC + auto sock = + socket(rp->ai_family, rp->ai_socktype | SOCK_CLOEXEC, rp->ai_protocol); +#else + auto sock = socket(rp->ai_family, rp->ai_socktype, rp->ai_protocol); +#endif + +#endif + if (sock == INVALID_SOCKET) { continue; } + +#if !defined _WIN32 && !defined SOCK_CLOEXEC + if (fcntl(sock, F_SETFD, FD_CLOEXEC) == -1) { + close_socket(sock); + continue; + } +#endif + + if (tcp_nodelay) { + auto opt = 1; +#ifdef _WIN32 + setsockopt(sock, IPPROTO_TCP, TCP_NODELAY, + reinterpret_cast(&opt), sizeof(opt)); +#else + setsockopt(sock, IPPROTO_TCP, TCP_NODELAY, + reinterpret_cast(&opt), sizeof(opt)); +#endif + } + + if (rp->ai_family == AF_INET6) { + auto opt = ipv6_v6only ? 1 : 0; +#ifdef _WIN32 + setsockopt(sock, IPPROTO_IPV6, IPV6_V6ONLY, + reinterpret_cast(&opt), sizeof(opt)); +#else + setsockopt(sock, IPPROTO_IPV6, IPV6_V6ONLY, + reinterpret_cast(&opt), sizeof(opt)); +#endif + } + + if (socket_options) { socket_options(sock); } + + // bind or connect + auto quit = false; + if (bind_or_connect(sock, *rp, quit)) { return sock; } + + close_socket(sock); + + if (quit) { break; } + } + + return INVALID_SOCKET; +} + +inline void set_nonblocking(socket_t sock, bool nonblocking) { +#ifdef _WIN32 + auto flags = nonblocking ? 1UL : 0UL; + ioctlsocket(sock, FIONBIO, &flags); +#else + auto flags = fcntl(sock, F_GETFL, 0); + fcntl(sock, F_SETFL, + nonblocking ? (flags | O_NONBLOCK) : (flags & (~O_NONBLOCK))); +#endif +} + +inline bool is_connection_error() { +#ifdef _WIN32 + return WSAGetLastError() != WSAEWOULDBLOCK; +#else + return errno != EINPROGRESS; +#endif +} + +inline bool bind_ip_address(socket_t sock, const std::string &host) { + struct addrinfo hints; + struct addrinfo *result; + + memset(&hints, 0, sizeof(struct addrinfo)); + hints.ai_family = AF_UNSPEC; + hints.ai_socktype = SOCK_STREAM; + hints.ai_protocol = 0; + + if (getaddrinfo(host.c_str(), "0", &hints, &result)) { return false; } + auto se = detail::scope_exit([&] { freeaddrinfo(result); }); + + auto ret = false; + for (auto rp = result; rp; rp = rp->ai_next) { + const auto &ai = *rp; + if (!::bind(sock, ai.ai_addr, static_cast(ai.ai_addrlen))) { + ret = true; + break; + } + } + + return ret; +} + +#if !defined _WIN32 && !defined ANDROID && !defined _AIX && !defined __MVS__ +#define USE_IF2IP +#endif + +#ifdef USE_IF2IP +inline std::string if2ip(int address_family, const std::string &ifn) { + struct ifaddrs *ifap; + getifaddrs(&ifap); + auto se = detail::scope_exit([&] { freeifaddrs(ifap); }); + + std::string addr_candidate; + for (auto ifa = ifap; ifa; ifa = ifa->ifa_next) { + if (ifa->ifa_addr && ifn == ifa->ifa_name && + (AF_UNSPEC == address_family || + ifa->ifa_addr->sa_family == address_family)) { + if (ifa->ifa_addr->sa_family == AF_INET) { + auto sa = reinterpret_cast(ifa->ifa_addr); + char buf[INET_ADDRSTRLEN]; + if (inet_ntop(AF_INET, &sa->sin_addr, buf, INET_ADDRSTRLEN)) { + return std::string(buf, INET_ADDRSTRLEN); + } + } else if (ifa->ifa_addr->sa_family == AF_INET6) { + auto sa = reinterpret_cast(ifa->ifa_addr); + if (!IN6_IS_ADDR_LINKLOCAL(&sa->sin6_addr)) { + char buf[INET6_ADDRSTRLEN] = {}; + if (inet_ntop(AF_INET6, &sa->sin6_addr, buf, INET6_ADDRSTRLEN)) { + // equivalent to mac's IN6_IS_ADDR_UNIQUE_LOCAL + auto s6_addr_head = sa->sin6_addr.s6_addr[0]; + if (s6_addr_head == 0xfc || s6_addr_head == 0xfd) { + addr_candidate = std::string(buf, INET6_ADDRSTRLEN); + } else { + return std::string(buf, INET6_ADDRSTRLEN); + } + } + } + } + } + } + return addr_candidate; +} +#endif + +inline socket_t create_client_socket( + const std::string &host, const std::string &ip, int port, + int address_family, bool tcp_nodelay, bool ipv6_v6only, + SocketOptions socket_options, time_t connection_timeout_sec, + time_t connection_timeout_usec, time_t read_timeout_sec, + time_t read_timeout_usec, time_t write_timeout_sec, + time_t write_timeout_usec, const std::string &intf, Error &error) { + auto sock = create_socket( + host, ip, port, address_family, 0, tcp_nodelay, ipv6_v6only, + std::move(socket_options), + [&](socket_t sock2, struct addrinfo &ai, bool &quit) -> bool { + if (!intf.empty()) { +#ifdef USE_IF2IP + auto ip_from_if = if2ip(address_family, intf); + if (ip_from_if.empty()) { ip_from_if = intf; } + if (!bind_ip_address(sock2, ip_from_if)) { + error = Error::BindIPAddress; + return false; + } +#endif + } + + set_nonblocking(sock2, true); + + auto ret = + ::connect(sock2, ai.ai_addr, static_cast(ai.ai_addrlen)); + + if (ret < 0) { + if (is_connection_error()) { + error = Error::Connection; + return false; + } + error = wait_until_socket_is_ready(sock2, connection_timeout_sec, + connection_timeout_usec); + if (error != Error::Success) { + if (error == Error::ConnectionTimeout) { quit = true; } + return false; + } + } + + set_nonblocking(sock2, false); + + { +#ifdef _WIN32 + auto timeout = static_cast(read_timeout_sec * 1000 + + read_timeout_usec / 1000); + setsockopt(sock2, SOL_SOCKET, SO_RCVTIMEO, + reinterpret_cast(&timeout), sizeof(timeout)); +#else + timeval tv; + tv.tv_sec = static_cast(read_timeout_sec); + tv.tv_usec = static_cast(read_timeout_usec); + setsockopt(sock2, SOL_SOCKET, SO_RCVTIMEO, + reinterpret_cast(&tv), sizeof(tv)); +#endif + } + { + +#ifdef _WIN32 + auto timeout = static_cast(write_timeout_sec * 1000 + + write_timeout_usec / 1000); + setsockopt(sock2, SOL_SOCKET, SO_SNDTIMEO, + reinterpret_cast(&timeout), sizeof(timeout)); +#else + timeval tv; + tv.tv_sec = static_cast(write_timeout_sec); + tv.tv_usec = static_cast(write_timeout_usec); + setsockopt(sock2, SOL_SOCKET, SO_SNDTIMEO, + reinterpret_cast(&tv), sizeof(tv)); +#endif + } + + error = Error::Success; + return true; + }); + + if (sock != INVALID_SOCKET) { + error = Error::Success; + } else { + if (error == Error::Success) { error = Error::Connection; } + } + + return sock; +} + +inline bool get_ip_and_port(const struct sockaddr_storage &addr, + socklen_t addr_len, std::string &ip, int &port) { + if (addr.ss_family == AF_INET) { + port = ntohs(reinterpret_cast(&addr)->sin_port); + } else if (addr.ss_family == AF_INET6) { + port = + ntohs(reinterpret_cast(&addr)->sin6_port); + } else { + return false; + } + + std::array ipstr{}; + if (getnameinfo(reinterpret_cast(&addr), addr_len, + ipstr.data(), static_cast(ipstr.size()), nullptr, + 0, NI_NUMERICHOST)) { + return false; + } + + ip = ipstr.data(); + return true; +} + +inline void get_local_ip_and_port(socket_t sock, std::string &ip, int &port) { + struct sockaddr_storage addr; + socklen_t addr_len = sizeof(addr); + if (!getsockname(sock, reinterpret_cast(&addr), + &addr_len)) { + get_ip_and_port(addr, addr_len, ip, port); + } +} + +inline void get_remote_ip_and_port(socket_t sock, std::string &ip, int &port) { + struct sockaddr_storage addr; + socklen_t addr_len = sizeof(addr); + + if (!getpeername(sock, reinterpret_cast(&addr), + &addr_len)) { +#ifndef _WIN32 + if (addr.ss_family == AF_UNIX) { +#if defined(__linux__) + struct ucred ucred; + socklen_t len = sizeof(ucred); + if (getsockopt(sock, SOL_SOCKET, SO_PEERCRED, &ucred, &len) == 0) { + port = ucred.pid; + } +#elif defined(SOL_LOCAL) && defined(SO_PEERPID) // __APPLE__ + pid_t pid; + socklen_t len = sizeof(pid); + if (getsockopt(sock, SOL_LOCAL, SO_PEERPID, &pid, &len) == 0) { + port = pid; + } +#endif + return; + } +#endif + get_ip_and_port(addr, addr_len, ip, port); + } +} + +inline constexpr unsigned int str2tag_core(const char *s, size_t l, + unsigned int h) { + return (l == 0) + ? h + : str2tag_core( + s + 1, l - 1, + // Unsets the 6 high bits of h, therefore no overflow happens + (((std::numeric_limits::max)() >> 6) & + h * 33) ^ + static_cast(*s)); +} + +inline unsigned int str2tag(const std::string &s) { + return str2tag_core(s.data(), s.size(), 0); +} + +namespace udl { + +inline constexpr unsigned int operator"" _t(const char *s, size_t l) { + return str2tag_core(s, l, 0); +} + +} // namespace udl + +inline std::string +find_content_type(const std::string &path, + const std::map &user_data, + const std::string &default_content_type) { + auto ext = file_extension(path); + + auto it = user_data.find(ext); + if (it != user_data.end()) { return it->second; } + + using udl::operator""_t; + + switch (str2tag(ext)) { + default: return default_content_type; + + case "css"_t: return "text/css"; + case "csv"_t: return "text/csv"; + case "htm"_t: + case "html"_t: return "text/html"; + case "js"_t: + case "mjs"_t: return "text/javascript"; + case "txt"_t: return "text/plain"; + case "vtt"_t: return "text/vtt"; + + case "apng"_t: return "image/apng"; + case "avif"_t: return "image/avif"; + case "bmp"_t: return "image/bmp"; + case "gif"_t: return "image/gif"; + case "png"_t: return "image/png"; + case "svg"_t: return "image/svg+xml"; + case "webp"_t: return "image/webp"; + case "ico"_t: return "image/x-icon"; + case "tif"_t: return "image/tiff"; + case "tiff"_t: return "image/tiff"; + case "jpg"_t: + case "jpeg"_t: return "image/jpeg"; + + case "mp4"_t: return "video/mp4"; + case "mpeg"_t: return "video/mpeg"; + case "webm"_t: return "video/webm"; + + case "mp3"_t: return "audio/mp3"; + case "mpga"_t: return "audio/mpeg"; + case "weba"_t: return "audio/webm"; + case "wav"_t: return "audio/wave"; + + case "otf"_t: return "font/otf"; + case "ttf"_t: return "font/ttf"; + case "woff"_t: return "font/woff"; + case "woff2"_t: return "font/woff2"; + + case "7z"_t: return "application/x-7z-compressed"; + case "atom"_t: return "application/atom+xml"; + case "pdf"_t: return "application/pdf"; + case "json"_t: return "application/json"; + case "rss"_t: return "application/rss+xml"; + case "tar"_t: return "application/x-tar"; + case "xht"_t: + case "xhtml"_t: return "application/xhtml+xml"; + case "xslt"_t: return "application/xslt+xml"; + case "xml"_t: return "application/xml"; + case "gz"_t: return "application/gzip"; + case "zip"_t: return "application/zip"; + case "wasm"_t: return "application/wasm"; + } +} + +inline bool can_compress_content_type(const std::string &content_type) { + using udl::operator""_t; + + auto tag = str2tag(content_type); + + switch (tag) { + case "image/svg+xml"_t: + case "application/javascript"_t: + case "application/json"_t: + case "application/xml"_t: + case "application/protobuf"_t: + case "application/xhtml+xml"_t: return true; + + case "text/event-stream"_t: return false; + + default: return !content_type.rfind("text/", 0); + } +} + +inline EncodingType encoding_type(const Request &req, const Response &res) { + auto ret = + detail::can_compress_content_type(res.get_header_value("Content-Type")); + if (!ret) { return EncodingType::None; } + + const auto &s = req.get_header_value("Accept-Encoding"); + (void)(s); + +#ifdef CPPHTTPLIB_BROTLI_SUPPORT + // TODO: 'Accept-Encoding' has br, not br;q=0 + ret = s.find("br") != std::string::npos; + if (ret) { return EncodingType::Brotli; } +#endif + +#ifdef CPPHTTPLIB_ZLIB_SUPPORT + // TODO: 'Accept-Encoding' has gzip, not gzip;q=0 + ret = s.find("gzip") != std::string::npos; + if (ret) { return EncodingType::Gzip; } +#endif + + return EncodingType::None; +} + +inline bool nocompressor::compress(const char *data, size_t data_length, + bool /*last*/, Callback callback) { + if (!data_length) { return true; } + return callback(data, data_length); +} + +#ifdef CPPHTTPLIB_ZLIB_SUPPORT +inline gzip_compressor::gzip_compressor() { + std::memset(&strm_, 0, sizeof(strm_)); + strm_.zalloc = Z_NULL; + strm_.zfree = Z_NULL; + strm_.opaque = Z_NULL; + + is_valid_ = deflateInit2(&strm_, Z_DEFAULT_COMPRESSION, Z_DEFLATED, 31, 8, + Z_DEFAULT_STRATEGY) == Z_OK; +} + +inline gzip_compressor::~gzip_compressor() { deflateEnd(&strm_); } + +inline bool gzip_compressor::compress(const char *data, size_t data_length, + bool last, Callback callback) { + assert(is_valid_); + + do { + constexpr size_t max_avail_in = + (std::numeric_limits::max)(); + + strm_.avail_in = static_cast( + (std::min)(data_length, max_avail_in)); + strm_.next_in = const_cast(reinterpret_cast(data)); + + data_length -= strm_.avail_in; + data += strm_.avail_in; + + auto flush = (last && data_length == 0) ? Z_FINISH : Z_NO_FLUSH; + auto ret = Z_OK; + + std::array buff{}; + do { + strm_.avail_out = static_cast(buff.size()); + strm_.next_out = reinterpret_cast(buff.data()); + + ret = deflate(&strm_, flush); + if (ret == Z_STREAM_ERROR) { return false; } + + if (!callback(buff.data(), buff.size() - strm_.avail_out)) { + return false; + } + } while (strm_.avail_out == 0); + + assert((flush == Z_FINISH && ret == Z_STREAM_END) || + (flush == Z_NO_FLUSH && ret == Z_OK)); + assert(strm_.avail_in == 0); + } while (data_length > 0); + + return true; +} + +inline gzip_decompressor::gzip_decompressor() { + std::memset(&strm_, 0, sizeof(strm_)); + strm_.zalloc = Z_NULL; + strm_.zfree = Z_NULL; + strm_.opaque = Z_NULL; + + // 15 is the value of wbits, which should be at the maximum possible value + // to ensure that any gzip stream can be decoded. The offset of 32 specifies + // that the stream type should be automatically detected either gzip or + // deflate. + is_valid_ = inflateInit2(&strm_, 32 + 15) == Z_OK; +} + +inline gzip_decompressor::~gzip_decompressor() { inflateEnd(&strm_); } + +inline bool gzip_decompressor::is_valid() const { return is_valid_; } + +inline bool gzip_decompressor::decompress(const char *data, size_t data_length, + Callback callback) { + assert(is_valid_); + + auto ret = Z_OK; + + do { + constexpr size_t max_avail_in = + (std::numeric_limits::max)(); + + strm_.avail_in = static_cast( + (std::min)(data_length, max_avail_in)); + strm_.next_in = const_cast(reinterpret_cast(data)); + + data_length -= strm_.avail_in; + data += strm_.avail_in; + + std::array buff{}; + while (strm_.avail_in > 0 && ret == Z_OK) { + strm_.avail_out = static_cast(buff.size()); + strm_.next_out = reinterpret_cast(buff.data()); + + ret = inflate(&strm_, Z_NO_FLUSH); + + assert(ret != Z_STREAM_ERROR); + switch (ret) { + case Z_NEED_DICT: + case Z_DATA_ERROR: + case Z_MEM_ERROR: inflateEnd(&strm_); return false; + } + + if (!callback(buff.data(), buff.size() - strm_.avail_out)) { + return false; + } + } + + if (ret != Z_OK && ret != Z_STREAM_END) { return false; } + + } while (data_length > 0); + + return true; +} +#endif + +#ifdef CPPHTTPLIB_BROTLI_SUPPORT +inline brotli_compressor::brotli_compressor() { + state_ = BrotliEncoderCreateInstance(nullptr, nullptr, nullptr); +} + +inline brotli_compressor::~brotli_compressor() { + BrotliEncoderDestroyInstance(state_); +} + +inline bool brotli_compressor::compress(const char *data, size_t data_length, + bool last, Callback callback) { + std::array buff{}; + + auto operation = last ? BROTLI_OPERATION_FINISH : BROTLI_OPERATION_PROCESS; + auto available_in = data_length; + auto next_in = reinterpret_cast(data); + + for (;;) { + if (last) { + if (BrotliEncoderIsFinished(state_)) { break; } + } else { + if (!available_in) { break; } + } + + auto available_out = buff.size(); + auto next_out = buff.data(); + + if (!BrotliEncoderCompressStream(state_, operation, &available_in, &next_in, + &available_out, &next_out, nullptr)) { + return false; + } + + auto output_bytes = buff.size() - available_out; + if (output_bytes) { + callback(reinterpret_cast(buff.data()), output_bytes); + } + } + + return true; +} + +inline brotli_decompressor::brotli_decompressor() { + decoder_s = BrotliDecoderCreateInstance(0, 0, 0); + decoder_r = decoder_s ? BROTLI_DECODER_RESULT_NEEDS_MORE_INPUT + : BROTLI_DECODER_RESULT_ERROR; +} + +inline brotli_decompressor::~brotli_decompressor() { + if (decoder_s) { BrotliDecoderDestroyInstance(decoder_s); } +} + +inline bool brotli_decompressor::is_valid() const { return decoder_s; } + +inline bool brotli_decompressor::decompress(const char *data, + size_t data_length, + Callback callback) { + if (decoder_r == BROTLI_DECODER_RESULT_SUCCESS || + decoder_r == BROTLI_DECODER_RESULT_ERROR) { + return 0; + } + + auto next_in = reinterpret_cast(data); + size_t avail_in = data_length; + size_t total_out; + + decoder_r = BROTLI_DECODER_RESULT_NEEDS_MORE_OUTPUT; + + std::array buff{}; + while (decoder_r == BROTLI_DECODER_RESULT_NEEDS_MORE_OUTPUT) { + char *next_out = buff.data(); + size_t avail_out = buff.size(); + + decoder_r = BrotliDecoderDecompressStream( + decoder_s, &avail_in, &next_in, &avail_out, + reinterpret_cast(&next_out), &total_out); + + if (decoder_r == BROTLI_DECODER_RESULT_ERROR) { return false; } + + if (!callback(buff.data(), buff.size() - avail_out)) { return false; } + } + + return decoder_r == BROTLI_DECODER_RESULT_SUCCESS || + decoder_r == BROTLI_DECODER_RESULT_NEEDS_MORE_INPUT; +} +#endif + +inline bool has_header(const Headers &headers, const std::string &key) { + return headers.find(key) != headers.end(); +} + +inline const char *get_header_value(const Headers &headers, + const std::string &key, const char *def, + size_t id) { + auto rng = headers.equal_range(key); + auto it = rng.first; + std::advance(it, static_cast(id)); + if (it != rng.second) { return it->second.c_str(); } + return def; +} + +template +inline bool parse_header(const char *beg, const char *end, T fn) { + // Skip trailing spaces and tabs. + while (beg < end && is_space_or_tab(end[-1])) { + end--; + } + + auto p = beg; + while (p < end && *p != ':') { + p++; + } + + if (p == end) { return false; } + + auto key_end = p; + + if (*p++ != ':') { return false; } + + while (p < end && is_space_or_tab(*p)) { + p++; + } + + if (p < end) { + auto key_len = key_end - beg; + if (!key_len) { return false; } + + auto key = std::string(beg, key_end); + auto val = case_ignore::equal(key, "Location") + ? std::string(p, end) + : decode_url(std::string(p, end), false); + + // NOTE: From RFC 9110: + // Field values containing CR, LF, or NUL characters are + // invalid and dangerous, due to the varying ways that + // implementations might parse and interpret those + // characters; a recipient of CR, LF, or NUL within a field + // value MUST either reject the message or replace each of + // those characters with SP before further processing or + // forwarding of that message. + static const std::string CR_LF_NUL("\r\n\0", 3); + if (val.find_first_of(CR_LF_NUL) != std::string::npos) { return false; } + + fn(key, val); + return true; + } + + return false; +} + +inline bool read_headers(Stream &strm, Headers &headers) { + const auto bufsiz = 2048; + char buf[bufsiz]; + stream_line_reader line_reader(strm, buf, bufsiz); + + for (;;) { + if (!line_reader.getline()) { return false; } + + // Check if the line ends with CRLF. + auto line_terminator_len = 2; + if (line_reader.end_with_crlf()) { + // Blank line indicates end of headers. + if (line_reader.size() == 2) { break; } + } else { +#ifdef CPPHTTPLIB_ALLOW_LF_AS_LINE_TERMINATOR + // Blank line indicates end of headers. + if (line_reader.size() == 1) { break; } + line_terminator_len = 1; +#else + continue; // Skip invalid line. +#endif + } + + if (line_reader.size() > CPPHTTPLIB_HEADER_MAX_LENGTH) { return false; } + + // Exclude line terminator + auto end = line_reader.ptr() + line_reader.size() - line_terminator_len; + + if (!parse_header(line_reader.ptr(), end, + [&](const std::string &key, std::string &val) { + headers.emplace(key, val); + })) { + return false; + } + } + + return true; +} + +inline bool read_content_with_length(Stream &strm, uint64_t len, + Progress progress, + ContentReceiverWithProgress out) { + char buf[CPPHTTPLIB_RECV_BUFSIZ]; + + uint64_t r = 0; + while (r < len) { + auto read_len = static_cast(len - r); + auto n = strm.read(buf, (std::min)(read_len, CPPHTTPLIB_RECV_BUFSIZ)); + if (n <= 0) { return false; } + + if (!out(buf, static_cast(n), r, len)) { return false; } + r += static_cast(n); + + if (progress) { + if (!progress(r, len)) { return false; } + } + } + + return true; +} + +inline void skip_content_with_length(Stream &strm, uint64_t len) { + char buf[CPPHTTPLIB_RECV_BUFSIZ]; + uint64_t r = 0; + while (r < len) { + auto read_len = static_cast(len - r); + auto n = strm.read(buf, (std::min)(read_len, CPPHTTPLIB_RECV_BUFSIZ)); + if (n <= 0) { return; } + r += static_cast(n); + } +} + +inline bool read_content_without_length(Stream &strm, + ContentReceiverWithProgress out) { + char buf[CPPHTTPLIB_RECV_BUFSIZ]; + uint64_t r = 0; + for (;;) { + auto n = strm.read(buf, CPPHTTPLIB_RECV_BUFSIZ); + if (n <= 0) { return true; } + + if (!out(buf, static_cast(n), r, 0)) { return false; } + r += static_cast(n); + } + + return true; +} + +template +inline bool read_content_chunked(Stream &strm, T &x, + ContentReceiverWithProgress out) { + const auto bufsiz = 16; + char buf[bufsiz]; + + stream_line_reader line_reader(strm, buf, bufsiz); + + if (!line_reader.getline()) { return false; } + + unsigned long chunk_len; + while (true) { + char *end_ptr; + + chunk_len = std::strtoul(line_reader.ptr(), &end_ptr, 16); + + if (end_ptr == line_reader.ptr()) { return false; } + if (chunk_len == ULONG_MAX) { return false; } + + if (chunk_len == 0) { break; } + + if (!read_content_with_length(strm, chunk_len, nullptr, out)) { + return false; + } + + if (!line_reader.getline()) { return false; } + + if (strcmp(line_reader.ptr(), "\r\n") != 0) { return false; } + + if (!line_reader.getline()) { return false; } + } + + assert(chunk_len == 0); + + // NOTE: In RFC 9112, '7.1 Chunked Transfer Coding' mentiones "The chunked + // transfer coding is complete when a chunk with a chunk-size of zero is + // received, possibly followed by a trailer section, and finally terminated by + // an empty line". https://www.rfc-editor.org/rfc/rfc9112.html#section-7.1 + // + // In '7.1.3. Decoding Chunked', however, the pseudo-code in the section + // does't care for the existence of the final CRLF. In other words, it seems + // to be ok whether the final CRLF exists or not in the chunked data. + // https://www.rfc-editor.org/rfc/rfc9112.html#section-7.1.3 + // + // According to the reference code in RFC 9112, cpp-htpplib now allows + // chuncked transfer coding data without the final CRLF. + if (!line_reader.getline()) { return true; } + + while (strcmp(line_reader.ptr(), "\r\n") != 0) { + if (line_reader.size() > CPPHTTPLIB_HEADER_MAX_LENGTH) { return false; } + + // Exclude line terminator + constexpr auto line_terminator_len = 2; + auto end = line_reader.ptr() + line_reader.size() - line_terminator_len; + + parse_header(line_reader.ptr(), end, + [&](const std::string &key, const std::string &val) { + x.headers.emplace(key, val); + }); + + if (!line_reader.getline()) { return false; } + } + + return true; +} + +inline bool is_chunked_transfer_encoding(const Headers &headers) { + return case_ignore::equal( + get_header_value(headers, "Transfer-Encoding", "", 0), "chunked"); +} + +template +bool prepare_content_receiver(T &x, int &status, + ContentReceiverWithProgress receiver, + bool decompress, U callback) { + if (decompress) { + std::string encoding = x.get_header_value("Content-Encoding"); + std::unique_ptr decompressor; + + if (encoding == "gzip" || encoding == "deflate") { +#ifdef CPPHTTPLIB_ZLIB_SUPPORT + decompressor = detail::make_unique(); +#else + status = StatusCode::UnsupportedMediaType_415; + return false; +#endif + } else if (encoding.find("br") != std::string::npos) { +#ifdef CPPHTTPLIB_BROTLI_SUPPORT + decompressor = detail::make_unique(); +#else + status = StatusCode::UnsupportedMediaType_415; + return false; +#endif + } + + if (decompressor) { + if (decompressor->is_valid()) { + ContentReceiverWithProgress out = [&](const char *buf, size_t n, + uint64_t off, uint64_t len) { + return decompressor->decompress(buf, n, + [&](const char *buf2, size_t n2) { + return receiver(buf2, n2, off, len); + }); + }; + return callback(std::move(out)); + } else { + status = StatusCode::InternalServerError_500; + return false; + } + } + } + + ContentReceiverWithProgress out = [&](const char *buf, size_t n, uint64_t off, + uint64_t len) { + return receiver(buf, n, off, len); + }; + return callback(std::move(out)); +} + +template +bool read_content(Stream &strm, T &x, size_t payload_max_length, int &status, + Progress progress, ContentReceiverWithProgress receiver, + bool decompress) { + return prepare_content_receiver( + x, status, std::move(receiver), decompress, + [&](const ContentReceiverWithProgress &out) { + auto ret = true; + auto exceed_payload_max_length = false; + + if (is_chunked_transfer_encoding(x.headers)) { + ret = read_content_chunked(strm, x, out); + } else if (!has_header(x.headers, "Content-Length")) { + ret = read_content_without_length(strm, out); + } else { + auto len = get_header_value_u64(x.headers, "Content-Length", 0, 0); + if (len > payload_max_length) { + exceed_payload_max_length = true; + skip_content_with_length(strm, len); + ret = false; + } else if (len > 0) { + ret = read_content_with_length(strm, len, std::move(progress), out); + } + } + + if (!ret) { + status = exceed_payload_max_length ? StatusCode::PayloadTooLarge_413 + : StatusCode::BadRequest_400; + } + return ret; + }); +} + +inline ssize_t write_request_line(Stream &strm, const std::string &method, + const std::string &path) { + std::string s = method; + s += " "; + s += path; + s += " HTTP/1.1\r\n"; + return strm.write(s.data(), s.size()); +} + +inline ssize_t write_response_line(Stream &strm, int status) { + std::string s = "HTTP/1.1 "; + s += std::to_string(status); + s += " "; + s += httplib::status_message(status); + s += "\r\n"; + return strm.write(s.data(), s.size()); +} + +inline ssize_t write_headers(Stream &strm, const Headers &headers) { + ssize_t write_len = 0; + for (const auto &x : headers) { + std::string s; + s = x.first; + s += ": "; + s += x.second; + s += "\r\n"; + + auto len = strm.write(s.data(), s.size()); + if (len < 0) { return len; } + write_len += len; + } + auto len = strm.write("\r\n"); + if (len < 0) { return len; } + write_len += len; + return write_len; +} + +inline bool write_data(Stream &strm, const char *d, size_t l) { + size_t offset = 0; + while (offset < l) { + auto length = strm.write(d + offset, l - offset); + if (length < 0) { return false; } + offset += static_cast(length); + } + return true; +} + +template +inline bool write_content(Stream &strm, const ContentProvider &content_provider, + size_t offset, size_t length, T is_shutting_down, + Error &error) { + size_t end_offset = offset + length; + auto ok = true; + DataSink data_sink; + + data_sink.write = [&](const char *d, size_t l) -> bool { + if (ok) { + if (strm.is_writable() && write_data(strm, d, l)) { + offset += l; + } else { + ok = false; + } + } + return ok; + }; + + data_sink.is_writable = [&]() -> bool { return strm.is_writable(); }; + + while (offset < end_offset && !is_shutting_down()) { + if (!strm.is_writable()) { + error = Error::Write; + return false; + } else if (!content_provider(offset, end_offset - offset, data_sink)) { + error = Error::Canceled; + return false; + } else if (!ok) { + error = Error::Write; + return false; + } + } + + error = Error::Success; + return true; +} + +template +inline bool write_content(Stream &strm, const ContentProvider &content_provider, + size_t offset, size_t length, + const T &is_shutting_down) { + auto error = Error::Success; + return write_content(strm, content_provider, offset, length, is_shutting_down, + error); +} + +template +inline bool +write_content_without_length(Stream &strm, + const ContentProvider &content_provider, + const T &is_shutting_down) { + size_t offset = 0; + auto data_available = true; + auto ok = true; + DataSink data_sink; + + data_sink.write = [&](const char *d, size_t l) -> bool { + if (ok) { + offset += l; + if (!strm.is_writable() || !write_data(strm, d, l)) { ok = false; } + } + return ok; + }; + + data_sink.is_writable = [&]() -> bool { return strm.is_writable(); }; + + data_sink.done = [&](void) { data_available = false; }; + + while (data_available && !is_shutting_down()) { + if (!strm.is_writable()) { + return false; + } else if (!content_provider(offset, 0, data_sink)) { + return false; + } else if (!ok) { + return false; + } + } + return true; +} + +template +inline bool +write_content_chunked(Stream &strm, const ContentProvider &content_provider, + const T &is_shutting_down, U &compressor, Error &error) { + size_t offset = 0; + auto data_available = true; + auto ok = true; + DataSink data_sink; + + data_sink.write = [&](const char *d, size_t l) -> bool { + if (ok) { + data_available = l > 0; + offset += l; + + std::string payload; + if (compressor.compress(d, l, false, + [&](const char *data, size_t data_len) { + payload.append(data, data_len); + return true; + })) { + if (!payload.empty()) { + // Emit chunked response header and footer for each chunk + auto chunk = + from_i_to_hex(payload.size()) + "\r\n" + payload + "\r\n"; + if (!strm.is_writable() || + !write_data(strm, chunk.data(), chunk.size())) { + ok = false; + } + } + } else { + ok = false; + } + } + return ok; + }; + + data_sink.is_writable = [&]() -> bool { return strm.is_writable(); }; + + auto done_with_trailer = [&](const Headers *trailer) { + if (!ok) { return; } + + data_available = false; + + std::string payload; + if (!compressor.compress(nullptr, 0, true, + [&](const char *data, size_t data_len) { + payload.append(data, data_len); + return true; + })) { + ok = false; + return; + } + + if (!payload.empty()) { + // Emit chunked response header and footer for each chunk + auto chunk = from_i_to_hex(payload.size()) + "\r\n" + payload + "\r\n"; + if (!strm.is_writable() || + !write_data(strm, chunk.data(), chunk.size())) { + ok = false; + return; + } + } + + static const std::string done_marker("0\r\n"); + if (!write_data(strm, done_marker.data(), done_marker.size())) { + ok = false; + } + + // Trailer + if (trailer) { + for (const auto &kv : *trailer) { + std::string field_line = kv.first + ": " + kv.second + "\r\n"; + if (!write_data(strm, field_line.data(), field_line.size())) { + ok = false; + } + } + } + + static const std::string crlf("\r\n"); + if (!write_data(strm, crlf.data(), crlf.size())) { ok = false; } + }; + + data_sink.done = [&](void) { done_with_trailer(nullptr); }; + + data_sink.done_with_trailer = [&](const Headers &trailer) { + done_with_trailer(&trailer); + }; + + while (data_available && !is_shutting_down()) { + if (!strm.is_writable()) { + error = Error::Write; + return false; + } else if (!content_provider(offset, 0, data_sink)) { + error = Error::Canceled; + return false; + } else if (!ok) { + error = Error::Write; + return false; + } + } + + error = Error::Success; + return true; +} + +template +inline bool write_content_chunked(Stream &strm, + const ContentProvider &content_provider, + const T &is_shutting_down, U &compressor) { + auto error = Error::Success; + return write_content_chunked(strm, content_provider, is_shutting_down, + compressor, error); +} + +template +inline bool redirect(T &cli, Request &req, Response &res, + const std::string &path, const std::string &location, + Error &error) { + Request new_req = req; + new_req.path = path; + new_req.redirect_count_ -= 1; + + if (res.status == StatusCode::SeeOther_303 && + (req.method != "GET" && req.method != "HEAD")) { + new_req.method = "GET"; + new_req.body.clear(); + new_req.headers.clear(); + } + + Response new_res; + + auto ret = cli.send(new_req, new_res, error); + if (ret) { + req = new_req; + res = new_res; + + if (res.location.empty()) { res.location = location; } + } + return ret; +} + +inline std::string params_to_query_str(const Params ¶ms) { + std::string query; + + for (auto it = params.begin(); it != params.end(); ++it) { + if (it != params.begin()) { query += "&"; } + query += it->first; + query += "="; + query += encode_query_param(it->second); + } + return query; +} + +inline void parse_query_text(const char *data, std::size_t size, + Params ¶ms) { + std::set cache; + split(data, data + size, '&', [&](const char *b, const char *e) { + std::string kv(b, e); + if (cache.find(kv) != cache.end()) { return; } + cache.insert(std::move(kv)); + + std::string key; + std::string val; + divide(b, static_cast(e - b), '=', + [&](const char *lhs_data, std::size_t lhs_size, const char *rhs_data, + std::size_t rhs_size) { + key.assign(lhs_data, lhs_size); + val.assign(rhs_data, rhs_size); + }); + + if (!key.empty()) { + params.emplace(decode_url(key, true), decode_url(val, true)); + } + }); +} + +inline void parse_query_text(const std::string &s, Params ¶ms) { + parse_query_text(s.data(), s.size(), params); +} + +inline bool parse_multipart_boundary(const std::string &content_type, + std::string &boundary) { + auto boundary_keyword = "boundary="; + auto pos = content_type.find(boundary_keyword); + if (pos == std::string::npos) { return false; } + auto end = content_type.find(';', pos); + auto beg = pos + strlen(boundary_keyword); + boundary = trim_double_quotes_copy(content_type.substr(beg, end - beg)); + return !boundary.empty(); +} + +inline void parse_disposition_params(const std::string &s, Params ¶ms) { + std::set cache; + split(s.data(), s.data() + s.size(), ';', [&](const char *b, const char *e) { + std::string kv(b, e); + if (cache.find(kv) != cache.end()) { return; } + cache.insert(kv); + + std::string key; + std::string val; + split(b, e, '=', [&](const char *b2, const char *e2) { + if (key.empty()) { + key.assign(b2, e2); + } else { + val.assign(b2, e2); + } + }); + + if (!key.empty()) { + params.emplace(trim_double_quotes_copy((key)), + trim_double_quotes_copy((val))); + } + }); +} + +#ifdef CPPHTTPLIB_NO_EXCEPTIONS +inline bool parse_range_header(const std::string &s, Ranges &ranges) { +#else +inline bool parse_range_header(const std::string &s, Ranges &ranges) try { +#endif + auto is_valid = [](const std::string &str) { + return std::all_of(str.cbegin(), str.cend(), + [](unsigned char c) { return std::isdigit(c); }); + }; + + if (s.size() > 7 && s.compare(0, 6, "bytes=") == 0) { + const auto pos = static_cast(6); + const auto len = static_cast(s.size() - 6); + auto all_valid_ranges = true; + split(&s[pos], &s[pos + len], ',', [&](const char *b, const char *e) { + if (!all_valid_ranges) { return; } + + const auto it = std::find(b, e, '-'); + if (it == e) { + all_valid_ranges = false; + return; + } + + const auto lhs = std::string(b, it); + const auto rhs = std::string(it + 1, e); + if (!is_valid(lhs) || !is_valid(rhs)) { + all_valid_ranges = false; + return; + } + + const auto first = + static_cast(lhs.empty() ? -1 : std::stoll(lhs)); + const auto last = + static_cast(rhs.empty() ? -1 : std::stoll(rhs)); + if ((first == -1 && last == -1) || + (first != -1 && last != -1 && first > last)) { + all_valid_ranges = false; + return; + } + + ranges.emplace_back(first, last); + }); + return all_valid_ranges && !ranges.empty(); + } + return false; +#ifdef CPPHTTPLIB_NO_EXCEPTIONS +} +#else +} catch (...) { return false; } +#endif + +class MultipartFormDataParser { +public: + MultipartFormDataParser() = default; + + void set_boundary(std::string &&boundary) { + boundary_ = boundary; + dash_boundary_crlf_ = dash_ + boundary_ + crlf_; + crlf_dash_boundary_ = crlf_ + dash_ + boundary_; + } + + bool is_valid() const { return is_valid_; } + + bool parse(const char *buf, size_t n, const ContentReceiver &content_callback, + const MultipartContentHeader &header_callback) { + + buf_append(buf, n); + + while (buf_size() > 0) { + switch (state_) { + case 0: { // Initial boundary + buf_erase(buf_find(dash_boundary_crlf_)); + if (dash_boundary_crlf_.size() > buf_size()) { return true; } + if (!buf_start_with(dash_boundary_crlf_)) { return false; } + buf_erase(dash_boundary_crlf_.size()); + state_ = 1; + break; + } + case 1: { // New entry + clear_file_info(); + state_ = 2; + break; + } + case 2: { // Headers + auto pos = buf_find(crlf_); + if (pos > CPPHTTPLIB_HEADER_MAX_LENGTH) { return false; } + while (pos < buf_size()) { + // Empty line + if (pos == 0) { + if (!header_callback(file_)) { + is_valid_ = false; + return false; + } + buf_erase(crlf_.size()); + state_ = 3; + break; + } + + const auto header = buf_head(pos); + + if (!parse_header(header.data(), header.data() + header.size(), + [&](const std::string &, const std::string &) {})) { + is_valid_ = false; + return false; + } + + static const std::string header_content_type = "Content-Type:"; + + if (start_with_case_ignore(header, header_content_type)) { + file_.content_type = + trim_copy(header.substr(header_content_type.size())); + } else { + static const std::regex re_content_disposition( + R"~(^Content-Disposition:\s*form-data;\s*(.*)$)~", + std::regex_constants::icase); + + std::smatch m; + if (std::regex_match(header, m, re_content_disposition)) { + Params params; + parse_disposition_params(m[1], params); + + auto it = params.find("name"); + if (it != params.end()) { + file_.name = it->second; + } else { + is_valid_ = false; + return false; + } + + it = params.find("filename"); + if (it != params.end()) { file_.filename = it->second; } + + it = params.find("filename*"); + if (it != params.end()) { + // Only allow UTF-8 enconnding... + static const std::regex re_rfc5987_encoding( + R"~(^UTF-8''(.+?)$)~", std::regex_constants::icase); + + std::smatch m2; + if (std::regex_match(it->second, m2, re_rfc5987_encoding)) { + file_.filename = decode_url(m2[1], false); // override... + } else { + is_valid_ = false; + return false; + } + } + } + } + buf_erase(pos + crlf_.size()); + pos = buf_find(crlf_); + } + if (state_ != 3) { return true; } + break; + } + case 3: { // Body + if (crlf_dash_boundary_.size() > buf_size()) { return true; } + auto pos = buf_find(crlf_dash_boundary_); + if (pos < buf_size()) { + if (!content_callback(buf_data(), pos)) { + is_valid_ = false; + return false; + } + buf_erase(pos + crlf_dash_boundary_.size()); + state_ = 4; + } else { + auto len = buf_size() - crlf_dash_boundary_.size(); + if (len > 0) { + if (!content_callback(buf_data(), len)) { + is_valid_ = false; + return false; + } + buf_erase(len); + } + return true; + } + break; + } + case 4: { // Boundary + if (crlf_.size() > buf_size()) { return true; } + if (buf_start_with(crlf_)) { + buf_erase(crlf_.size()); + state_ = 1; + } else { + if (dash_.size() > buf_size()) { return true; } + if (buf_start_with(dash_)) { + buf_erase(dash_.size()); + is_valid_ = true; + buf_erase(buf_size()); // Remove epilogue + } else { + return true; + } + } + break; + } + } + } + + return true; + } + +private: + void clear_file_info() { + file_.name.clear(); + file_.filename.clear(); + file_.content_type.clear(); + } + + bool start_with_case_ignore(const std::string &a, + const std::string &b) const { + if (a.size() < b.size()) { return false; } + for (size_t i = 0; i < b.size(); i++) { + if (case_ignore::to_lower(a[i]) != case_ignore::to_lower(b[i])) { + return false; + } + } + return true; + } + + const std::string dash_ = "--"; + const std::string crlf_ = "\r\n"; + std::string boundary_; + std::string dash_boundary_crlf_; + std::string crlf_dash_boundary_; + + size_t state_ = 0; + bool is_valid_ = false; + MultipartFormData file_; + + // Buffer + bool start_with(const std::string &a, size_t spos, size_t epos, + const std::string &b) const { + if (epos - spos < b.size()) { return false; } + for (size_t i = 0; i < b.size(); i++) { + if (a[i + spos] != b[i]) { return false; } + } + return true; + } + + size_t buf_size() const { return buf_epos_ - buf_spos_; } + + const char *buf_data() const { return &buf_[buf_spos_]; } + + std::string buf_head(size_t l) const { return buf_.substr(buf_spos_, l); } + + bool buf_start_with(const std::string &s) const { + return start_with(buf_, buf_spos_, buf_epos_, s); + } + + size_t buf_find(const std::string &s) const { + auto c = s.front(); + + size_t off = buf_spos_; + while (off < buf_epos_) { + auto pos = off; + while (true) { + if (pos == buf_epos_) { return buf_size(); } + if (buf_[pos] == c) { break; } + pos++; + } + + auto remaining_size = buf_epos_ - pos; + if (s.size() > remaining_size) { return buf_size(); } + + if (start_with(buf_, pos, buf_epos_, s)) { return pos - buf_spos_; } + + off = pos + 1; + } + + return buf_size(); + } + + void buf_append(const char *data, size_t n) { + auto remaining_size = buf_size(); + if (remaining_size > 0 && buf_spos_ > 0) { + for (size_t i = 0; i < remaining_size; i++) { + buf_[i] = buf_[buf_spos_ + i]; + } + } + buf_spos_ = 0; + buf_epos_ = remaining_size; + + if (remaining_size + n > buf_.size()) { buf_.resize(remaining_size + n); } + + for (size_t i = 0; i < n; i++) { + buf_[buf_epos_ + i] = data[i]; + } + buf_epos_ += n; + } + + void buf_erase(size_t size) { buf_spos_ += size; } + + std::string buf_; + size_t buf_spos_ = 0; + size_t buf_epos_ = 0; +}; + +inline std::string random_string(size_t length) { + static const char data[] = + "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; + + // std::random_device might actually be deterministic on some + // platforms, but due to lack of support in the c++ standard library, + // doing better requires either some ugly hacks or breaking portability. + static std::random_device seed_gen; + + // Request 128 bits of entropy for initialization + static std::seed_seq seed_sequence{seed_gen(), seed_gen(), seed_gen(), + seed_gen()}; + + static std::mt19937 engine(seed_sequence); + + std::string result; + for (size_t i = 0; i < length; i++) { + result += data[engine() % (sizeof(data) - 1)]; + } + return result; +} + +inline std::string make_multipart_data_boundary() { + return "--cpp-httplib-multipart-data-" + detail::random_string(16); +} + +inline bool is_multipart_boundary_chars_valid(const std::string &boundary) { + auto valid = true; + for (size_t i = 0; i < boundary.size(); i++) { + auto c = boundary[i]; + if (!std::isalnum(c) && c != '-' && c != '_') { + valid = false; + break; + } + } + return valid; +} + +template +inline std::string +serialize_multipart_formdata_item_begin(const T &item, + const std::string &boundary) { + std::string body = "--" + boundary + "\r\n"; + body += "Content-Disposition: form-data; name=\"" + item.name + "\""; + if (!item.filename.empty()) { + body += "; filename=\"" + item.filename + "\""; + } + body += "\r\n"; + if (!item.content_type.empty()) { + body += "Content-Type: " + item.content_type + "\r\n"; + } + body += "\r\n"; + + return body; +} + +inline std::string serialize_multipart_formdata_item_end() { return "\r\n"; } + +inline std::string +serialize_multipart_formdata_finish(const std::string &boundary) { + return "--" + boundary + "--\r\n"; +} + +inline std::string +serialize_multipart_formdata_get_content_type(const std::string &boundary) { + return "multipart/form-data; boundary=" + boundary; +} + +inline std::string +serialize_multipart_formdata(const MultipartFormDataItems &items, + const std::string &boundary, bool finish = true) { + std::string body; + + for (const auto &item : items) { + body += serialize_multipart_formdata_item_begin(item, boundary); + body += item.content + serialize_multipart_formdata_item_end(); + } + + if (finish) { body += serialize_multipart_formdata_finish(boundary); } + + return body; +} + +inline bool range_error(Request &req, Response &res) { + if (!req.ranges.empty() && 200 <= res.status && res.status < 300) { + ssize_t contant_len = static_cast( + res.content_length_ ? res.content_length_ : res.body.size()); + + ssize_t prev_first_pos = -1; + ssize_t prev_last_pos = -1; + size_t overwrapping_count = 0; + + // NOTE: The following Range check is based on '14.2. Range' in RFC 9110 + // 'HTTP Semantics' to avoid potential denial-of-service attacks. + // https://www.rfc-editor.org/rfc/rfc9110#section-14.2 + + // Too many ranges + if (req.ranges.size() > CPPHTTPLIB_RANGE_MAX_COUNT) { return true; } + + for (auto &r : req.ranges) { + auto &first_pos = r.first; + auto &last_pos = r.second; + + if (first_pos == -1 && last_pos == -1) { + first_pos = 0; + last_pos = contant_len; + } + + if (first_pos == -1) { + first_pos = contant_len - last_pos; + last_pos = contant_len - 1; + } + + if (last_pos == -1) { last_pos = contant_len - 1; } + + // Range must be within content length + if (!(0 <= first_pos && first_pos <= last_pos && + last_pos <= contant_len - 1)) { + return true; + } + + // Ranges must be in ascending order + if (first_pos <= prev_first_pos) { return true; } + + // Request must not have more than two overlapping ranges + if (first_pos <= prev_last_pos) { + overwrapping_count++; + if (overwrapping_count > 2) { return true; } + } + + prev_first_pos = (std::max)(prev_first_pos, first_pos); + prev_last_pos = (std::max)(prev_last_pos, last_pos); + } + } + + return false; +} + +inline std::pair +get_range_offset_and_length(Range r, size_t content_length) { + assert(r.first != -1 && r.second != -1); + assert(0 <= r.first && r.first < static_cast(content_length)); + assert(r.first <= r.second && + r.second < static_cast(content_length)); + (void)(content_length); + return std::make_pair(r.first, static_cast(r.second - r.first) + 1); +} + +inline std::string make_content_range_header_field( + const std::pair &offset_and_length, size_t content_length) { + auto st = offset_and_length.first; + auto ed = st + offset_and_length.second - 1; + + std::string field = "bytes "; + field += std::to_string(st); + field += "-"; + field += std::to_string(ed); + field += "/"; + field += std::to_string(content_length); + return field; +} + +template +bool process_multipart_ranges_data(const Request &req, + const std::string &boundary, + const std::string &content_type, + size_t content_length, SToken stoken, + CToken ctoken, Content content) { + for (size_t i = 0; i < req.ranges.size(); i++) { + ctoken("--"); + stoken(boundary); + ctoken("\r\n"); + if (!content_type.empty()) { + ctoken("Content-Type: "); + stoken(content_type); + ctoken("\r\n"); + } + + auto offset_and_length = + get_range_offset_and_length(req.ranges[i], content_length); + + ctoken("Content-Range: "); + stoken(make_content_range_header_field(offset_and_length, content_length)); + ctoken("\r\n"); + ctoken("\r\n"); + + if (!content(offset_and_length.first, offset_and_length.second)) { + return false; + } + ctoken("\r\n"); + } + + ctoken("--"); + stoken(boundary); + ctoken("--"); + + return true; +} + +inline void make_multipart_ranges_data(const Request &req, Response &res, + const std::string &boundary, + const std::string &content_type, + size_t content_length, + std::string &data) { + process_multipart_ranges_data( + req, boundary, content_type, content_length, + [&](const std::string &token) { data += token; }, + [&](const std::string &token) { data += token; }, + [&](size_t offset, size_t length) { + assert(offset + length <= content_length); + data += res.body.substr(offset, length); + return true; + }); +} + +inline size_t get_multipart_ranges_data_length(const Request &req, + const std::string &boundary, + const std::string &content_type, + size_t content_length) { + size_t data_length = 0; + + process_multipart_ranges_data( + req, boundary, content_type, content_length, + [&](const std::string &token) { data_length += token.size(); }, + [&](const std::string &token) { data_length += token.size(); }, + [&](size_t /*offset*/, size_t length) { + data_length += length; + return true; + }); + + return data_length; +} + +template +inline bool +write_multipart_ranges_data(Stream &strm, const Request &req, Response &res, + const std::string &boundary, + const std::string &content_type, + size_t content_length, const T &is_shutting_down) { + return process_multipart_ranges_data( + req, boundary, content_type, content_length, + [&](const std::string &token) { strm.write(token); }, + [&](const std::string &token) { strm.write(token); }, + [&](size_t offset, size_t length) { + return write_content(strm, res.content_provider_, offset, length, + is_shutting_down); + }); +} + +inline bool expect_content(const Request &req) { + if (req.method == "POST" || req.method == "PUT" || req.method == "PATCH" || + req.method == "PRI" || req.method == "DELETE") { + return true; + } + // TODO: check if Content-Length is set + return false; +} + +inline bool has_crlf(const std::string &s) { + auto p = s.c_str(); + while (*p) { + if (*p == '\r' || *p == '\n') { return true; } + p++; + } + return false; +} + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +inline std::string message_digest(const std::string &s, const EVP_MD *algo) { + auto context = std::unique_ptr( + EVP_MD_CTX_new(), EVP_MD_CTX_free); + + unsigned int hash_length = 0; + unsigned char hash[EVP_MAX_MD_SIZE]; + + EVP_DigestInit_ex(context.get(), algo, nullptr); + EVP_DigestUpdate(context.get(), s.c_str(), s.size()); + EVP_DigestFinal_ex(context.get(), hash, &hash_length); + + std::stringstream ss; + for (auto i = 0u; i < hash_length; ++i) { + ss << std::hex << std::setw(2) << std::setfill('0') + << static_cast(hash[i]); + } + + return ss.str(); +} + +inline std::string MD5(const std::string &s) { + return message_digest(s, EVP_md5()); +} + +inline std::string SHA_256(const std::string &s) { + return message_digest(s, EVP_sha256()); +} + +inline std::string SHA_512(const std::string &s) { + return message_digest(s, EVP_sha512()); +} +#endif + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +#ifdef _WIN32 +// NOTE: This code came up with the following stackoverflow post: +// https://stackoverflow.com/questions/9507184/can-openssl-on-windows-use-the-system-certificate-store +inline bool load_system_certs_on_windows(X509_STORE *store) { + auto hStore = CertOpenSystemStoreW((HCRYPTPROV_LEGACY)NULL, L"ROOT"); + if (!hStore) { return false; } + + auto result = false; + PCCERT_CONTEXT pContext = NULL; + while ((pContext = CertEnumCertificatesInStore(hStore, pContext)) != + nullptr) { + auto encoded_cert = + static_cast(pContext->pbCertEncoded); + + auto x509 = d2i_X509(NULL, &encoded_cert, pContext->cbCertEncoded); + if (x509) { + X509_STORE_add_cert(store, x509); + X509_free(x509); + result = true; + } + } + + CertFreeCertificateContext(pContext); + CertCloseStore(hStore, 0); + + return result; +} +#elif defined(CPPHTTPLIB_USE_CERTS_FROM_MACOSX_KEYCHAIN) && defined(__APPLE__) +#if TARGET_OS_OSX +template +using CFObjectPtr = + std::unique_ptr::type, void (*)(CFTypeRef)>; + +inline void cf_object_ptr_deleter(CFTypeRef obj) { + if (obj) { CFRelease(obj); } +} + +inline bool retrieve_certs_from_keychain(CFObjectPtr &certs) { + CFStringRef keys[] = {kSecClass, kSecMatchLimit, kSecReturnRef}; + CFTypeRef values[] = {kSecClassCertificate, kSecMatchLimitAll, + kCFBooleanTrue}; + + CFObjectPtr query( + CFDictionaryCreate(nullptr, reinterpret_cast(keys), values, + sizeof(keys) / sizeof(keys[0]), + &kCFTypeDictionaryKeyCallBacks, + &kCFTypeDictionaryValueCallBacks), + cf_object_ptr_deleter); + + if (!query) { return false; } + + CFTypeRef security_items = nullptr; + if (SecItemCopyMatching(query.get(), &security_items) != errSecSuccess || + CFArrayGetTypeID() != CFGetTypeID(security_items)) { + return false; + } + + certs.reset(reinterpret_cast(security_items)); + return true; +} + +inline bool retrieve_root_certs_from_keychain(CFObjectPtr &certs) { + CFArrayRef root_security_items = nullptr; + if (SecTrustCopyAnchorCertificates(&root_security_items) != errSecSuccess) { + return false; + } + + certs.reset(root_security_items); + return true; +} + +inline bool add_certs_to_x509_store(CFArrayRef certs, X509_STORE *store) { + auto result = false; + for (auto i = 0; i < CFArrayGetCount(certs); ++i) { + const auto cert = reinterpret_cast( + CFArrayGetValueAtIndex(certs, i)); + + if (SecCertificateGetTypeID() != CFGetTypeID(cert)) { continue; } + + CFDataRef cert_data = nullptr; + if (SecItemExport(cert, kSecFormatX509Cert, 0, nullptr, &cert_data) != + errSecSuccess) { + continue; + } + + CFObjectPtr cert_data_ptr(cert_data, cf_object_ptr_deleter); + + auto encoded_cert = static_cast( + CFDataGetBytePtr(cert_data_ptr.get())); + + auto x509 = + d2i_X509(NULL, &encoded_cert, CFDataGetLength(cert_data_ptr.get())); + + if (x509) { + X509_STORE_add_cert(store, x509); + X509_free(x509); + result = true; + } + } + + return result; +} + +inline bool load_system_certs_on_macos(X509_STORE *store) { + auto result = false; + CFObjectPtr certs(nullptr, cf_object_ptr_deleter); + if (retrieve_certs_from_keychain(certs) && certs) { + result = add_certs_to_x509_store(certs.get(), store); + } + + if (retrieve_root_certs_from_keychain(certs) && certs) { + result = add_certs_to_x509_store(certs.get(), store) || result; + } + + return result; +} +#endif // TARGET_OS_OSX +#endif // _WIN32 +#endif // CPPHTTPLIB_OPENSSL_SUPPORT + +#ifdef _WIN32 +class WSInit { +public: + WSInit() { + WSADATA wsaData; + if (WSAStartup(0x0002, &wsaData) == 0) is_valid_ = true; + } + + ~WSInit() { + if (is_valid_) WSACleanup(); + } + + bool is_valid_ = false; +}; + +static WSInit wsinit_; +#endif + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +inline std::pair make_digest_authentication_header( + const Request &req, const std::map &auth, + size_t cnonce_count, const std::string &cnonce, const std::string &username, + const std::string &password, bool is_proxy = false) { + std::string nc; + { + std::stringstream ss; + ss << std::setfill('0') << std::setw(8) << std::hex << cnonce_count; + nc = ss.str(); + } + + std::string qop; + if (auth.find("qop") != auth.end()) { + qop = auth.at("qop"); + if (qop.find("auth-int") != std::string::npos) { + qop = "auth-int"; + } else if (qop.find("auth") != std::string::npos) { + qop = "auth"; + } else { + qop.clear(); + } + } + + std::string algo = "MD5"; + if (auth.find("algorithm") != auth.end()) { algo = auth.at("algorithm"); } + + std::string response; + { + auto H = algo == "SHA-256" ? detail::SHA_256 + : algo == "SHA-512" ? detail::SHA_512 + : detail::MD5; + + auto A1 = username + ":" + auth.at("realm") + ":" + password; + + auto A2 = req.method + ":" + req.path; + if (qop == "auth-int") { A2 += ":" + H(req.body); } + + if (qop.empty()) { + response = H(H(A1) + ":" + auth.at("nonce") + ":" + H(A2)); + } else { + response = H(H(A1) + ":" + auth.at("nonce") + ":" + nc + ":" + cnonce + + ":" + qop + ":" + H(A2)); + } + } + + auto opaque = (auth.find("opaque") != auth.end()) ? auth.at("opaque") : ""; + + auto field = "Digest username=\"" + username + "\", realm=\"" + + auth.at("realm") + "\", nonce=\"" + auth.at("nonce") + + "\", uri=\"" + req.path + "\", algorithm=" + algo + + (qop.empty() ? ", response=\"" + : ", qop=" + qop + ", nc=" + nc + ", cnonce=\"" + + cnonce + "\", response=\"") + + response + "\"" + + (opaque.empty() ? "" : ", opaque=\"" + opaque + "\""); + + auto key = is_proxy ? "Proxy-Authorization" : "Authorization"; + return std::make_pair(key, field); +} +#endif + +inline bool parse_www_authenticate(const Response &res, + std::map &auth, + bool is_proxy) { + auto auth_key = is_proxy ? "Proxy-Authenticate" : "WWW-Authenticate"; + if (res.has_header(auth_key)) { + static auto re = std::regex(R"~((?:(?:,\s*)?(.+?)=(?:"(.*?)"|([^,]*))))~"); + auto s = res.get_header_value(auth_key); + auto pos = s.find(' '); + if (pos != std::string::npos) { + auto type = s.substr(0, pos); + if (type == "Basic") { + return false; + } else if (type == "Digest") { + s = s.substr(pos + 1); + auto beg = std::sregex_iterator(s.begin(), s.end(), re); + for (auto i = beg; i != std::sregex_iterator(); ++i) { + const auto &m = *i; + auto key = s.substr(static_cast(m.position(1)), + static_cast(m.length(1))); + auto val = m.length(2) > 0 + ? s.substr(static_cast(m.position(2)), + static_cast(m.length(2))) + : s.substr(static_cast(m.position(3)), + static_cast(m.length(3))); + auth[key] = val; + } + return true; + } + } + } + return false; +} + +class ContentProviderAdapter { +public: + explicit ContentProviderAdapter( + ContentProviderWithoutLength &&content_provider) + : content_provider_(content_provider) {} + + bool operator()(size_t offset, size_t, DataSink &sink) { + return content_provider_(offset, sink); + } + +private: + ContentProviderWithoutLength content_provider_; +}; + +} // namespace detail + +inline std::string hosted_at(const std::string &hostname) { + std::vector addrs; + hosted_at(hostname, addrs); + if (addrs.empty()) { return std::string(); } + return addrs[0]; +} + +inline void hosted_at(const std::string &hostname, + std::vector &addrs) { + struct addrinfo hints; + struct addrinfo *result; + + memset(&hints, 0, sizeof(struct addrinfo)); + hints.ai_family = AF_UNSPEC; + hints.ai_socktype = SOCK_STREAM; + hints.ai_protocol = 0; + + if (getaddrinfo(hostname.c_str(), nullptr, &hints, &result)) { +#if defined __linux__ && !defined __ANDROID__ + res_init(); +#endif + return; + } + auto se = detail::scope_exit([&] { freeaddrinfo(result); }); + + for (auto rp = result; rp; rp = rp->ai_next) { + const auto &addr = + *reinterpret_cast(rp->ai_addr); + std::string ip; + auto dummy = -1; + if (detail::get_ip_and_port(addr, sizeof(struct sockaddr_storage), ip, + dummy)) { + addrs.push_back(ip); + } + } +} + +inline std::string append_query_params(const std::string &path, + const Params ¶ms) { + std::string path_with_query = path; + const static std::regex re("[^?]+\\?.*"); + auto delm = std::regex_match(path, re) ? '&' : '?'; + path_with_query += delm + detail::params_to_query_str(params); + return path_with_query; +} + +// Header utilities +inline std::pair +make_range_header(const Ranges &ranges) { + std::string field = "bytes="; + auto i = 0; + for (const auto &r : ranges) { + if (i != 0) { field += ", "; } + if (r.first != -1) { field += std::to_string(r.first); } + field += '-'; + if (r.second != -1) { field += std::to_string(r.second); } + i++; + } + return std::make_pair("Range", std::move(field)); +} + +inline std::pair +make_basic_authentication_header(const std::string &username, + const std::string &password, bool is_proxy) { + auto field = "Basic " + detail::base64_encode(username + ":" + password); + auto key = is_proxy ? "Proxy-Authorization" : "Authorization"; + return std::make_pair(key, std::move(field)); +} + +inline std::pair +make_bearer_token_authentication_header(const std::string &token, + bool is_proxy = false) { + auto field = "Bearer " + token; + auto key = is_proxy ? "Proxy-Authorization" : "Authorization"; + return std::make_pair(key, std::move(field)); +} + +// Request implementation +inline bool Request::has_header(const std::string &key) const { + return detail::has_header(headers, key); +} + +inline std::string Request::get_header_value(const std::string &key, + const char *def, size_t id) const { + return detail::get_header_value(headers, key, def, id); +} + +inline size_t Request::get_header_value_count(const std::string &key) const { + auto r = headers.equal_range(key); + return static_cast(std::distance(r.first, r.second)); +} + +inline void Request::set_header(const std::string &key, + const std::string &val) { + if (!detail::has_crlf(key) && !detail::has_crlf(val)) { + headers.emplace(key, val); + } +} + +inline bool Request::has_param(const std::string &key) const { + return params.find(key) != params.end(); +} + +inline std::string Request::get_param_value(const std::string &key, + size_t id) const { + auto rng = params.equal_range(key); + auto it = rng.first; + std::advance(it, static_cast(id)); + if (it != rng.second) { return it->second; } + return std::string(); +} + +inline size_t Request::get_param_value_count(const std::string &key) const { + auto r = params.equal_range(key); + return static_cast(std::distance(r.first, r.second)); +} + +inline bool Request::is_multipart_form_data() const { + const auto &content_type = get_header_value("Content-Type"); + return !content_type.rfind("multipart/form-data", 0); +} + +inline bool Request::has_file(const std::string &key) const { + return files.find(key) != files.end(); +} + +inline MultipartFormData Request::get_file_value(const std::string &key) const { + auto it = files.find(key); + if (it != files.end()) { return it->second; } + return MultipartFormData(); +} + +inline std::vector +Request::get_file_values(const std::string &key) const { + std::vector values; + auto rng = files.equal_range(key); + for (auto it = rng.first; it != rng.second; it++) { + values.push_back(it->second); + } + return values; +} + +// Response implementation +inline bool Response::has_header(const std::string &key) const { + return headers.find(key) != headers.end(); +} + +inline std::string Response::get_header_value(const std::string &key, + const char *def, + size_t id) const { + return detail::get_header_value(headers, key, def, id); +} + +inline size_t Response::get_header_value_count(const std::string &key) const { + auto r = headers.equal_range(key); + return static_cast(std::distance(r.first, r.second)); +} + +inline void Response::set_header(const std::string &key, + const std::string &val) { + if (!detail::has_crlf(key) && !detail::has_crlf(val)) { + headers.emplace(key, val); + } +} + +inline void Response::set_redirect(const std::string &url, int stat) { + if (!detail::has_crlf(url)) { + set_header("Location", url); + if (300 <= stat && stat < 400) { + this->status = stat; + } else { + this->status = StatusCode::Found_302; + } + } +} + +inline void Response::set_content(const char *s, size_t n, + const std::string &content_type) { + body.assign(s, n); + + auto rng = headers.equal_range("Content-Type"); + headers.erase(rng.first, rng.second); + set_header("Content-Type", content_type); +} + +inline void Response::set_content(const std::string &s, + const std::string &content_type) { + set_content(s.data(), s.size(), content_type); +} + +inline void Response::set_content(std::string &&s, + const std::string &content_type) { + body = std::move(s); + + auto rng = headers.equal_range("Content-Type"); + headers.erase(rng.first, rng.second); + set_header("Content-Type", content_type); +} + +inline void Response::set_content_provider( + size_t in_length, const std::string &content_type, ContentProvider provider, + ContentProviderResourceReleaser resource_releaser) { + set_header("Content-Type", content_type); + content_length_ = in_length; + if (in_length > 0) { content_provider_ = std::move(provider); } + content_provider_resource_releaser_ = std::move(resource_releaser); + is_chunked_content_provider_ = false; +} + +inline void Response::set_content_provider( + const std::string &content_type, ContentProviderWithoutLength provider, + ContentProviderResourceReleaser resource_releaser) { + set_header("Content-Type", content_type); + content_length_ = 0; + content_provider_ = detail::ContentProviderAdapter(std::move(provider)); + content_provider_resource_releaser_ = std::move(resource_releaser); + is_chunked_content_provider_ = false; +} + +inline void Response::set_chunked_content_provider( + const std::string &content_type, ContentProviderWithoutLength provider, + ContentProviderResourceReleaser resource_releaser) { + set_header("Content-Type", content_type); + content_length_ = 0; + content_provider_ = detail::ContentProviderAdapter(std::move(provider)); + content_provider_resource_releaser_ = std::move(resource_releaser); + is_chunked_content_provider_ = true; +} + +inline void Response::set_file_content(const std::string &path, + const std::string &content_type) { + file_content_path_ = path; + file_content_content_type_ = content_type; +} + +inline void Response::set_file_content(const std::string &path) { + file_content_path_ = path; +} + +// Result implementation +inline bool Result::has_request_header(const std::string &key) const { + return request_headers_.find(key) != request_headers_.end(); +} + +inline std::string Result::get_request_header_value(const std::string &key, + const char *def, + size_t id) const { + return detail::get_header_value(request_headers_, key, def, id); +} + +inline size_t +Result::get_request_header_value_count(const std::string &key) const { + auto r = request_headers_.equal_range(key); + return static_cast(std::distance(r.first, r.second)); +} + +// Stream implementation +inline ssize_t Stream::write(const char *ptr) { + return write(ptr, strlen(ptr)); +} + +inline ssize_t Stream::write(const std::string &s) { + return write(s.data(), s.size()); +} + +namespace detail { + +// Socket stream implementation +inline SocketStream::SocketStream(socket_t sock, time_t read_timeout_sec, + time_t read_timeout_usec, + time_t write_timeout_sec, + time_t write_timeout_usec) + : sock_(sock), read_timeout_sec_(read_timeout_sec), + read_timeout_usec_(read_timeout_usec), + write_timeout_sec_(write_timeout_sec), + write_timeout_usec_(write_timeout_usec), read_buff_(read_buff_size_, 0) {} + +inline SocketStream::~SocketStream() = default; + +inline bool SocketStream::is_readable() const { + return select_read(sock_, read_timeout_sec_, read_timeout_usec_) > 0; +} + +inline bool SocketStream::is_writable() const { + return select_write(sock_, write_timeout_sec_, write_timeout_usec_) > 0 && + is_socket_alive(sock_); +} + +inline ssize_t SocketStream::read(char *ptr, size_t size) { +#ifdef _WIN32 + size = + (std::min)(size, static_cast((std::numeric_limits::max)())); +#else + size = (std::min)(size, + static_cast((std::numeric_limits::max)())); +#endif + + if (read_buff_off_ < read_buff_content_size_) { + auto remaining_size = read_buff_content_size_ - read_buff_off_; + if (size <= remaining_size) { + memcpy(ptr, read_buff_.data() + read_buff_off_, size); + read_buff_off_ += size; + return static_cast(size); + } else { + memcpy(ptr, read_buff_.data() + read_buff_off_, remaining_size); + read_buff_off_ += remaining_size; + return static_cast(remaining_size); + } + } + + if (!is_readable()) { return -1; } + + read_buff_off_ = 0; + read_buff_content_size_ = 0; + + if (size < read_buff_size_) { + auto n = read_socket(sock_, read_buff_.data(), read_buff_size_, + CPPHTTPLIB_RECV_FLAGS); + if (n <= 0) { + return n; + } else if (n <= static_cast(size)) { + memcpy(ptr, read_buff_.data(), static_cast(n)); + return n; + } else { + memcpy(ptr, read_buff_.data(), size); + read_buff_off_ = size; + read_buff_content_size_ = static_cast(n); + return static_cast(size); + } + } else { + return read_socket(sock_, ptr, size, CPPHTTPLIB_RECV_FLAGS); + } +} + +inline ssize_t SocketStream::write(const char *ptr, size_t size) { + if (!is_writable()) { return -1; } + +#if defined(_WIN32) && !defined(_WIN64) + size = + (std::min)(size, static_cast((std::numeric_limits::max)())); +#endif + + return send_socket(sock_, ptr, size, CPPHTTPLIB_SEND_FLAGS); +} + +inline void SocketStream::get_remote_ip_and_port(std::string &ip, + int &port) const { + return detail::get_remote_ip_and_port(sock_, ip, port); +} + +inline void SocketStream::get_local_ip_and_port(std::string &ip, + int &port) const { + return detail::get_local_ip_and_port(sock_, ip, port); +} + +inline socket_t SocketStream::socket() const { return sock_; } + +// Buffer stream implementation +inline bool BufferStream::is_readable() const { return true; } + +inline bool BufferStream::is_writable() const { return true; } + +inline ssize_t BufferStream::read(char *ptr, size_t size) { +#if defined(_MSC_VER) && _MSC_VER < 1910 + auto len_read = buffer._Copy_s(ptr, size, size, position); +#else + auto len_read = buffer.copy(ptr, size, position); +#endif + position += static_cast(len_read); + return static_cast(len_read); +} + +inline ssize_t BufferStream::write(const char *ptr, size_t size) { + buffer.append(ptr, size); + return static_cast(size); +} + +inline void BufferStream::get_remote_ip_and_port(std::string & /*ip*/, + int & /*port*/) const {} + +inline void BufferStream::get_local_ip_and_port(std::string & /*ip*/, + int & /*port*/) const {} + +inline socket_t BufferStream::socket() const { return 0; } + +inline const std::string &BufferStream::get_buffer() const { return buffer; } + +inline PathParamsMatcher::PathParamsMatcher(const std::string &pattern) { + static constexpr char marker[] = "/:"; + + // One past the last ending position of a path param substring + std::size_t last_param_end = 0; + +#ifndef CPPHTTPLIB_NO_EXCEPTIONS + // Needed to ensure that parameter names are unique during matcher + // construction + // If exceptions are disabled, only last duplicate path + // parameter will be set + std::unordered_set param_name_set; +#endif + + while (true) { + const auto marker_pos = pattern.find( + marker, last_param_end == 0 ? last_param_end : last_param_end - 1); + if (marker_pos == std::string::npos) { break; } + + static_fragments_.push_back( + pattern.substr(last_param_end, marker_pos - last_param_end + 1)); + + const auto param_name_start = marker_pos + 2; + + auto sep_pos = pattern.find(separator, param_name_start); + if (sep_pos == std::string::npos) { sep_pos = pattern.length(); } + + auto param_name = + pattern.substr(param_name_start, sep_pos - param_name_start); + +#ifndef CPPHTTPLIB_NO_EXCEPTIONS + if (param_name_set.find(param_name) != param_name_set.cend()) { + std::string msg = "Encountered path parameter '" + param_name + + "' multiple times in route pattern '" + pattern + "'."; + throw std::invalid_argument(msg); + } +#endif + + param_names_.push_back(std::move(param_name)); + + last_param_end = sep_pos + 1; + } + + if (last_param_end < pattern.length()) { + static_fragments_.push_back(pattern.substr(last_param_end)); + } +} + +inline bool PathParamsMatcher::match(Request &request) const { + request.matches = std::smatch(); + request.path_params.clear(); + request.path_params.reserve(param_names_.size()); + + // One past the position at which the path matched the pattern last time + std::size_t starting_pos = 0; + for (size_t i = 0; i < static_fragments_.size(); ++i) { + const auto &fragment = static_fragments_[i]; + + if (starting_pos + fragment.length() > request.path.length()) { + return false; + } + + // Avoid unnecessary allocation by using strncmp instead of substr + + // comparison + if (std::strncmp(request.path.c_str() + starting_pos, fragment.c_str(), + fragment.length()) != 0) { + return false; + } + + starting_pos += fragment.length(); + + // Should only happen when we have a static fragment after a param + // Example: '/users/:id/subscriptions' + // The 'subscriptions' fragment here does not have a corresponding param + if (i >= param_names_.size()) { continue; } + + auto sep_pos = request.path.find(separator, starting_pos); + if (sep_pos == std::string::npos) { sep_pos = request.path.length(); } + + const auto ¶m_name = param_names_[i]; + + request.path_params.emplace( + param_name, request.path.substr(starting_pos, sep_pos - starting_pos)); + + // Mark everything up to '/' as matched + starting_pos = sep_pos + 1; + } + // Returns false if the path is longer than the pattern + return starting_pos >= request.path.length(); +} + +inline bool RegexMatcher::match(Request &request) const { + request.path_params.clear(); + return std::regex_match(request.path, request.matches, regex_); +} + +} // namespace detail + +// HTTP server implementation +inline Server::Server() + : new_task_queue( + [] { return new ThreadPool(CPPHTTPLIB_THREAD_POOL_COUNT); }) { +#ifndef _WIN32 + signal(SIGPIPE, SIG_IGN); +#endif +} + +inline Server::~Server() = default; + +inline std::unique_ptr +Server::make_matcher(const std::string &pattern) { + if (pattern.find("/:") != std::string::npos) { + return detail::make_unique(pattern); + } else { + return detail::make_unique(pattern); + } +} + +inline Server &Server::Get(const std::string &pattern, Handler handler) { + get_handlers_.emplace_back(make_matcher(pattern), std::move(handler)); + return *this; +} + +inline Server &Server::Post(const std::string &pattern, Handler handler) { + post_handlers_.emplace_back(make_matcher(pattern), std::move(handler)); + return *this; +} + +inline Server &Server::Post(const std::string &pattern, + HandlerWithContentReader handler) { + post_handlers_for_content_reader_.emplace_back(make_matcher(pattern), + std::move(handler)); + return *this; +} + +inline Server &Server::Put(const std::string &pattern, Handler handler) { + put_handlers_.emplace_back(make_matcher(pattern), std::move(handler)); + return *this; +} + +inline Server &Server::Put(const std::string &pattern, + HandlerWithContentReader handler) { + put_handlers_for_content_reader_.emplace_back(make_matcher(pattern), + std::move(handler)); + return *this; +} + +inline Server &Server::Patch(const std::string &pattern, Handler handler) { + patch_handlers_.emplace_back(make_matcher(pattern), std::move(handler)); + return *this; +} + +inline Server &Server::Patch(const std::string &pattern, + HandlerWithContentReader handler) { + patch_handlers_for_content_reader_.emplace_back(make_matcher(pattern), + std::move(handler)); + return *this; +} + +inline Server &Server::Delete(const std::string &pattern, Handler handler) { + delete_handlers_.emplace_back(make_matcher(pattern), std::move(handler)); + return *this; +} + +inline Server &Server::Delete(const std::string &pattern, + HandlerWithContentReader handler) { + delete_handlers_for_content_reader_.emplace_back(make_matcher(pattern), + std::move(handler)); + return *this; +} + +inline Server &Server::Options(const std::string &pattern, Handler handler) { + options_handlers_.emplace_back(make_matcher(pattern), std::move(handler)); + return *this; +} + +inline bool Server::set_base_dir(const std::string &dir, + const std::string &mount_point) { + return set_mount_point(mount_point, dir); +} + +inline bool Server::set_mount_point(const std::string &mount_point, + const std::string &dir, Headers headers) { + detail::FileStat stat(dir); + if (stat.is_dir()) { + std::string mnt = !mount_point.empty() ? mount_point : "/"; + if (!mnt.empty() && mnt[0] == '/') { + base_dirs_.push_back({mnt, dir, std::move(headers)}); + return true; + } + } + return false; +} + +inline bool Server::remove_mount_point(const std::string &mount_point) { + for (auto it = base_dirs_.begin(); it != base_dirs_.end(); ++it) { + if (it->mount_point == mount_point) { + base_dirs_.erase(it); + return true; + } + } + return false; +} + +inline Server & +Server::set_file_extension_and_mimetype_mapping(const std::string &ext, + const std::string &mime) { + file_extension_and_mimetype_map_[ext] = mime; + return *this; +} + +inline Server &Server::set_default_file_mimetype(const std::string &mime) { + default_file_mimetype_ = mime; + return *this; +} + +inline Server &Server::set_file_request_handler(Handler handler) { + file_request_handler_ = std::move(handler); + return *this; +} + +inline Server &Server::set_error_handler_core(HandlerWithResponse handler, + std::true_type) { + error_handler_ = std::move(handler); + return *this; +} + +inline Server &Server::set_error_handler_core(Handler handler, + std::false_type) { + error_handler_ = [handler](const Request &req, Response &res) { + handler(req, res); + return HandlerResponse::Handled; + }; + return *this; +} + +inline Server &Server::set_exception_handler(ExceptionHandler handler) { + exception_handler_ = std::move(handler); + return *this; +} + +inline Server &Server::set_pre_routing_handler(HandlerWithResponse handler) { + pre_routing_handler_ = std::move(handler); + return *this; +} + +inline Server &Server::set_post_routing_handler(Handler handler) { + post_routing_handler_ = std::move(handler); + return *this; +} + +inline Server &Server::set_logger(Logger logger) { + logger_ = std::move(logger); + return *this; +} + +inline Server & +Server::set_expect_100_continue_handler(Expect100ContinueHandler handler) { + expect_100_continue_handler_ = std::move(handler); + return *this; +} + +inline Server &Server::set_address_family(int family) { + address_family_ = family; + return *this; +} + +inline Server &Server::set_tcp_nodelay(bool on) { + tcp_nodelay_ = on; + return *this; +} + +inline Server &Server::set_ipv6_v6only(bool on) { + ipv6_v6only_ = on; + return *this; +} + +inline Server &Server::set_socket_options(SocketOptions socket_options) { + socket_options_ = std::move(socket_options); + return *this; +} + +inline Server &Server::set_default_headers(Headers headers) { + default_headers_ = std::move(headers); + return *this; +} + +inline Server &Server::set_header_writer( + std::function const &writer) { + header_writer_ = writer; + return *this; +} + +inline Server &Server::set_keep_alive_max_count(size_t count) { + keep_alive_max_count_ = count; + return *this; +} + +inline Server &Server::set_keep_alive_timeout(time_t sec) { + keep_alive_timeout_sec_ = sec; + return *this; +} + +inline Server &Server::set_read_timeout(time_t sec, time_t usec) { + read_timeout_sec_ = sec; + read_timeout_usec_ = usec; + return *this; +} + +inline Server &Server::set_write_timeout(time_t sec, time_t usec) { + write_timeout_sec_ = sec; + write_timeout_usec_ = usec; + return *this; +} + +inline Server &Server::set_idle_interval(time_t sec, time_t usec) { + idle_interval_sec_ = sec; + idle_interval_usec_ = usec; + return *this; +} + +inline Server &Server::set_payload_max_length(size_t length) { + payload_max_length_ = length; + return *this; +} + +inline bool Server::bind_to_port(const std::string &host, int port, + int socket_flags) { + auto ret = bind_internal(host, port, socket_flags); + if (ret == -1) { is_decommisioned = true; } + return ret >= 0; +} +inline int Server::bind_to_any_port(const std::string &host, int socket_flags) { + auto ret = bind_internal(host, 0, socket_flags); + if (ret == -1) { is_decommisioned = true; } + return ret; +} + +inline bool Server::listen_after_bind() { return listen_internal(); } + +inline bool Server::listen(const std::string &host, int port, + int socket_flags) { + return bind_to_port(host, port, socket_flags) && listen_internal(); +} + +inline bool Server::is_running() const { return is_running_; } + +inline void Server::wait_until_ready() const { + while (!is_running_ && !is_decommisioned) { + std::this_thread::sleep_for(std::chrono::milliseconds{1}); + } +} + +inline void Server::stop() { + if (is_running_) { + assert(svr_sock_ != INVALID_SOCKET); + std::atomic sock(svr_sock_.exchange(INVALID_SOCKET)); + detail::shutdown_socket(sock); + detail::close_socket(sock); + } + is_decommisioned = false; +} + +inline void Server::decommission() { is_decommisioned = true; } + +inline bool Server::parse_request_line(const char *s, Request &req) const { + auto len = strlen(s); + if (len < 2 || s[len - 2] != '\r' || s[len - 1] != '\n') { return false; } + len -= 2; + + { + size_t count = 0; + + detail::split(s, s + len, ' ', [&](const char *b, const char *e) { + switch (count) { + case 0: req.method = std::string(b, e); break; + case 1: req.target = std::string(b, e); break; + case 2: req.version = std::string(b, e); break; + default: break; + } + count++; + }); + + if (count != 3) { return false; } + } + + static const std::set methods{ + "GET", "HEAD", "POST", "PUT", "DELETE", + "CONNECT", "OPTIONS", "TRACE", "PATCH", "PRI"}; + + if (methods.find(req.method) == methods.end()) { return false; } + + if (req.version != "HTTP/1.1" && req.version != "HTTP/1.0") { return false; } + + { + // Skip URL fragment + for (size_t i = 0; i < req.target.size(); i++) { + if (req.target[i] == '#') { + req.target.erase(i); + break; + } + } + + detail::divide(req.target, '?', + [&](const char *lhs_data, std::size_t lhs_size, + const char *rhs_data, std::size_t rhs_size) { + req.path = detail::decode_url( + std::string(lhs_data, lhs_size), false); + detail::parse_query_text(rhs_data, rhs_size, req.params); + }); + } + + return true; +} + +inline bool Server::write_response(Stream &strm, bool close_connection, + Request &req, Response &res) { + // NOTE: `req.ranges` should be empty, otherwise it will be applied + // incorrectly to the error content. + req.ranges.clear(); + return write_response_core(strm, close_connection, req, res, false); +} + +inline bool Server::write_response_with_content(Stream &strm, + bool close_connection, + const Request &req, + Response &res) { + return write_response_core(strm, close_connection, req, res, true); +} + +inline bool Server::write_response_core(Stream &strm, bool close_connection, + const Request &req, Response &res, + bool need_apply_ranges) { + assert(res.status != -1); + + if (400 <= res.status && error_handler_ && + error_handler_(req, res) == HandlerResponse::Handled) { + need_apply_ranges = true; + } + + std::string content_type; + std::string boundary; + if (need_apply_ranges) { apply_ranges(req, res, content_type, boundary); } + + // Prepare additional headers + if (close_connection || req.get_header_value("Connection") == "close") { + res.set_header("Connection", "close"); + } else { + std::string s = "timeout="; + s += std::to_string(keep_alive_timeout_sec_); + s += ", max="; + s += std::to_string(keep_alive_max_count_); + res.set_header("Keep-Alive", s); + } + + if ((!res.body.empty() || res.content_length_ > 0 || res.content_provider_) && + !res.has_header("Content-Type")) { + res.set_header("Content-Type", "text/plain"); + } + + if (res.body.empty() && !res.content_length_ && !res.content_provider_ && + !res.has_header("Content-Length")) { + res.set_header("Content-Length", "0"); + } + + if (req.method == "HEAD" && !res.has_header("Accept-Ranges")) { + res.set_header("Accept-Ranges", "bytes"); + } + + if (post_routing_handler_) { post_routing_handler_(req, res); } + + // Response line and headers + { + detail::BufferStream bstrm; + if (!detail::write_response_line(bstrm, res.status)) { return false; } + if (!header_writer_(bstrm, res.headers)) { return false; } + + // Flush buffer + auto &data = bstrm.get_buffer(); + detail::write_data(strm, data.data(), data.size()); + } + + // Body + auto ret = true; + if (req.method != "HEAD") { + if (!res.body.empty()) { + if (!detail::write_data(strm, res.body.data(), res.body.size())) { + ret = false; + } + } else if (res.content_provider_) { + if (write_content_with_provider(strm, req, res, boundary, content_type)) { + res.content_provider_success_ = true; + } else { + ret = false; + } + } + } + + // Log + if (logger_) { logger_(req, res); } + + return ret; +} + +inline bool +Server::write_content_with_provider(Stream &strm, const Request &req, + Response &res, const std::string &boundary, + const std::string &content_type) { + auto is_shutting_down = [this]() { + return this->svr_sock_ == INVALID_SOCKET; + }; + + if (res.content_length_ > 0) { + if (req.ranges.empty()) { + return detail::write_content(strm, res.content_provider_, 0, + res.content_length_, is_shutting_down); + } else if (req.ranges.size() == 1) { + auto offset_and_length = detail::get_range_offset_and_length( + req.ranges[0], res.content_length_); + + return detail::write_content(strm, res.content_provider_, + offset_and_length.first, + offset_and_length.second, is_shutting_down); + } else { + return detail::write_multipart_ranges_data( + strm, req, res, boundary, content_type, res.content_length_, + is_shutting_down); + } + } else { + if (res.is_chunked_content_provider_) { + auto type = detail::encoding_type(req, res); + + std::unique_ptr compressor; + if (type == detail::EncodingType::Gzip) { +#ifdef CPPHTTPLIB_ZLIB_SUPPORT + compressor = detail::make_unique(); +#endif + } else if (type == detail::EncodingType::Brotli) { +#ifdef CPPHTTPLIB_BROTLI_SUPPORT + compressor = detail::make_unique(); +#endif + } else { + compressor = detail::make_unique(); + } + assert(compressor != nullptr); + + return detail::write_content_chunked(strm, res.content_provider_, + is_shutting_down, *compressor); + } else { + return detail::write_content_without_length(strm, res.content_provider_, + is_shutting_down); + } + } +} + +inline bool Server::read_content(Stream &strm, Request &req, Response &res) { + MultipartFormDataMap::iterator cur; + auto file_count = 0; + if (read_content_core( + strm, req, res, + // Regular + [&](const char *buf, size_t n) { + if (req.body.size() + n > req.body.max_size()) { return false; } + req.body.append(buf, n); + return true; + }, + // Multipart + [&](const MultipartFormData &file) { + if (file_count++ == CPPHTTPLIB_MULTIPART_FORM_DATA_FILE_MAX_COUNT) { + return false; + } + cur = req.files.emplace(file.name, file); + return true; + }, + [&](const char *buf, size_t n) { + auto &content = cur->second.content; + if (content.size() + n > content.max_size()) { return false; } + content.append(buf, n); + return true; + })) { + const auto &content_type = req.get_header_value("Content-Type"); + if (!content_type.find("application/x-www-form-urlencoded")) { + if (req.body.size() > CPPHTTPLIB_FORM_URL_ENCODED_PAYLOAD_MAX_LENGTH) { + res.status = StatusCode::PayloadTooLarge_413; // NOTE: should be 414? + return false; + } + detail::parse_query_text(req.body, req.params); + } + return true; + } + return false; +} + +inline bool Server::read_content_with_content_receiver( + Stream &strm, Request &req, Response &res, ContentReceiver receiver, + MultipartContentHeader multipart_header, + ContentReceiver multipart_receiver) { + return read_content_core(strm, req, res, std::move(receiver), + std::move(multipart_header), + std::move(multipart_receiver)); +} + +inline bool +Server::read_content_core(Stream &strm, Request &req, Response &res, + ContentReceiver receiver, + MultipartContentHeader multipart_header, + ContentReceiver multipart_receiver) const { + detail::MultipartFormDataParser multipart_form_data_parser; + ContentReceiverWithProgress out; + + if (req.is_multipart_form_data()) { + const auto &content_type = req.get_header_value("Content-Type"); + std::string boundary; + if (!detail::parse_multipart_boundary(content_type, boundary)) { + res.status = StatusCode::BadRequest_400; + return false; + } + + multipart_form_data_parser.set_boundary(std::move(boundary)); + out = [&](const char *buf, size_t n, uint64_t /*off*/, uint64_t /*len*/) { + /* For debug + size_t pos = 0; + while (pos < n) { + auto read_size = (std::min)(1, n - pos); + auto ret = multipart_form_data_parser.parse( + buf + pos, read_size, multipart_receiver, multipart_header); + if (!ret) { return false; } + pos += read_size; + } + return true; + */ + return multipart_form_data_parser.parse(buf, n, multipart_receiver, + multipart_header); + }; + } else { + out = [receiver](const char *buf, size_t n, uint64_t /*off*/, + uint64_t /*len*/) { return receiver(buf, n); }; + } + + if (req.method == "DELETE" && !req.has_header("Content-Length")) { + return true; + } + + if (!detail::read_content(strm, req, payload_max_length_, res.status, nullptr, + out, true)) { + return false; + } + + if (req.is_multipart_form_data()) { + if (!multipart_form_data_parser.is_valid()) { + res.status = StatusCode::BadRequest_400; + return false; + } + } + + return true; +} + +inline bool Server::handle_file_request(const Request &req, Response &res, + bool head) { + for (const auto &entry : base_dirs_) { + // Prefix match + if (!req.path.compare(0, entry.mount_point.size(), entry.mount_point)) { + std::string sub_path = "/" + req.path.substr(entry.mount_point.size()); + if (detail::is_valid_path(sub_path)) { + auto path = entry.base_dir + sub_path; + if (path.back() == '/') { path += "index.html"; } + + detail::FileStat stat(path); + + if (stat.is_dir()) { + res.set_redirect(sub_path + "/", StatusCode::MovedPermanently_301); + return true; + } + + if (stat.is_file()) { + for (const auto &kv : entry.headers) { + res.set_header(kv.first, kv.second); + } + + auto mm = std::make_shared(path.c_str()); + if (!mm->is_open()) { return false; } + + res.set_content_provider( + mm->size(), + detail::find_content_type(path, file_extension_and_mimetype_map_, + default_file_mimetype_), + [mm](size_t offset, size_t length, DataSink &sink) -> bool { + sink.write(mm->data() + offset, length); + return true; + }); + + if (!head && file_request_handler_) { + file_request_handler_(req, res); + } + + return true; + } + } + } + } + return false; +} + +inline socket_t +Server::create_server_socket(const std::string &host, int port, + int socket_flags, + SocketOptions socket_options) const { + return detail::create_socket( + host, std::string(), port, address_family_, socket_flags, tcp_nodelay_, + ipv6_v6only_, std::move(socket_options), + [](socket_t sock, struct addrinfo &ai, bool & /*quit*/) -> bool { + if (::bind(sock, ai.ai_addr, static_cast(ai.ai_addrlen))) { + return false; + } + if (::listen(sock, CPPHTTPLIB_LISTEN_BACKLOG)) { return false; } + return true; + }); +} + +inline int Server::bind_internal(const std::string &host, int port, + int socket_flags) { + if (is_decommisioned) { return -1; } + + if (!is_valid()) { return -1; } + + svr_sock_ = create_server_socket(host, port, socket_flags, socket_options_); + if (svr_sock_ == INVALID_SOCKET) { return -1; } + + if (port == 0) { + struct sockaddr_storage addr; + socklen_t addr_len = sizeof(addr); + if (getsockname(svr_sock_, reinterpret_cast(&addr), + &addr_len) == -1) { + return -1; + } + if (addr.ss_family == AF_INET) { + return ntohs(reinterpret_cast(&addr)->sin_port); + } else if (addr.ss_family == AF_INET6) { + return ntohs(reinterpret_cast(&addr)->sin6_port); + } else { + return -1; + } + } else { + return port; + } +} + +inline bool Server::listen_internal() { + if (is_decommisioned) { return false; } + + auto ret = true; + is_running_ = true; + auto se = detail::scope_exit([&]() { is_running_ = false; }); + + { + std::unique_ptr task_queue(new_task_queue()); + + while (svr_sock_ != INVALID_SOCKET) { +#ifndef _WIN32 + if (idle_interval_sec_ > 0 || idle_interval_usec_ > 0) { +#endif + auto val = detail::select_read(svr_sock_, idle_interval_sec_, + idle_interval_usec_); + if (val == 0) { // Timeout + task_queue->on_idle(); + continue; + } +#ifndef _WIN32 + } +#endif + +#if defined _WIN32 + // sockets conneced via WASAccept inherit flags NO_HANDLE_INHERIT, + // OVERLAPPED + socket_t sock = WSAAccept(svr_sock_, nullptr, nullptr, nullptr, 0); +#elif defined SOCK_CLOEXEC + socket_t sock = accept4(svr_sock_, nullptr, nullptr, SOCK_CLOEXEC); +#else + socket_t sock = accept(svr_sock_, nullptr, nullptr); +#endif + + if (sock == INVALID_SOCKET) { + if (errno == EMFILE) { + // The per-process limit of open file descriptors has been reached. + // Try to accept new connections after a short sleep. + std::this_thread::sleep_for(std::chrono::microseconds{1}); + continue; + } else if (errno == EINTR || errno == EAGAIN) { + continue; + } + if (svr_sock_ != INVALID_SOCKET) { + detail::close_socket(svr_sock_); + ret = false; + } else { + ; // The server socket was closed by user. + } + break; + } + + { +#ifdef _WIN32 + auto timeout = static_cast(read_timeout_sec_ * 1000 + + read_timeout_usec_ / 1000); + setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, + reinterpret_cast(&timeout), sizeof(timeout)); +#else + timeval tv; + tv.tv_sec = static_cast(read_timeout_sec_); + tv.tv_usec = static_cast(read_timeout_usec_); + setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, + reinterpret_cast(&tv), sizeof(tv)); +#endif + } + { + +#ifdef _WIN32 + auto timeout = static_cast(write_timeout_sec_ * 1000 + + write_timeout_usec_ / 1000); + setsockopt(sock, SOL_SOCKET, SO_SNDTIMEO, + reinterpret_cast(&timeout), sizeof(timeout)); +#else + timeval tv; + tv.tv_sec = static_cast(write_timeout_sec_); + tv.tv_usec = static_cast(write_timeout_usec_); + setsockopt(sock, SOL_SOCKET, SO_SNDTIMEO, + reinterpret_cast(&tv), sizeof(tv)); +#endif + } + + if (!task_queue->enqueue( + [this, sock]() { process_and_close_socket(sock); })) { + detail::shutdown_socket(sock); + detail::close_socket(sock); + } + } + + task_queue->shutdown(); + } + + is_decommisioned = !ret; + return ret; +} + +inline bool Server::routing(Request &req, Response &res, Stream &strm) { + if (pre_routing_handler_ && + pre_routing_handler_(req, res) == HandlerResponse::Handled) { + return true; + } + + // File handler + auto is_head_request = req.method == "HEAD"; + if ((req.method == "GET" || is_head_request) && + handle_file_request(req, res, is_head_request)) { + return true; + } + + if (detail::expect_content(req)) { + // Content reader handler + { + ContentReader reader( + [&](ContentReceiver receiver) { + return read_content_with_content_receiver( + strm, req, res, std::move(receiver), nullptr, nullptr); + }, + [&](MultipartContentHeader header, ContentReceiver receiver) { + return read_content_with_content_receiver(strm, req, res, nullptr, + std::move(header), + std::move(receiver)); + }); + + if (req.method == "POST") { + if (dispatch_request_for_content_reader( + req, res, std::move(reader), + post_handlers_for_content_reader_)) { + return true; + } + } else if (req.method == "PUT") { + if (dispatch_request_for_content_reader( + req, res, std::move(reader), + put_handlers_for_content_reader_)) { + return true; + } + } else if (req.method == "PATCH") { + if (dispatch_request_for_content_reader( + req, res, std::move(reader), + patch_handlers_for_content_reader_)) { + return true; + } + } else if (req.method == "DELETE") { + if (dispatch_request_for_content_reader( + req, res, std::move(reader), + delete_handlers_for_content_reader_)) { + return true; + } + } + } + + // Read content into `req.body` + if (!read_content(strm, req, res)) { return false; } + } + + // Regular handler + if (req.method == "GET" || req.method == "HEAD") { + return dispatch_request(req, res, get_handlers_); + } else if (req.method == "POST") { + return dispatch_request(req, res, post_handlers_); + } else if (req.method == "PUT") { + return dispatch_request(req, res, put_handlers_); + } else if (req.method == "DELETE") { + return dispatch_request(req, res, delete_handlers_); + } else if (req.method == "OPTIONS") { + return dispatch_request(req, res, options_handlers_); + } else if (req.method == "PATCH") { + return dispatch_request(req, res, patch_handlers_); + } + + res.status = StatusCode::BadRequest_400; + return false; +} + +inline bool Server::dispatch_request(Request &req, Response &res, + const Handlers &handlers) const { + for (const auto &x : handlers) { + const auto &matcher = x.first; + const auto &handler = x.second; + + if (matcher->match(req)) { + handler(req, res); + return true; + } + } + return false; +} + +inline void Server::apply_ranges(const Request &req, Response &res, + std::string &content_type, + std::string &boundary) const { + if (req.ranges.size() > 1 && res.status == StatusCode::PartialContent_206) { + auto it = res.headers.find("Content-Type"); + if (it != res.headers.end()) { + content_type = it->second; + res.headers.erase(it); + } + + boundary = detail::make_multipart_data_boundary(); + + res.set_header("Content-Type", + "multipart/byteranges; boundary=" + boundary); + } + + auto type = detail::encoding_type(req, res); + + if (res.body.empty()) { + if (res.content_length_ > 0) { + size_t length = 0; + if (req.ranges.empty() || res.status != StatusCode::PartialContent_206) { + length = res.content_length_; + } else if (req.ranges.size() == 1) { + auto offset_and_length = detail::get_range_offset_and_length( + req.ranges[0], res.content_length_); + + length = offset_and_length.second; + + auto content_range = detail::make_content_range_header_field( + offset_and_length, res.content_length_); + res.set_header("Content-Range", content_range); + } else { + length = detail::get_multipart_ranges_data_length( + req, boundary, content_type, res.content_length_); + } + res.set_header("Content-Length", std::to_string(length)); + } else { + if (res.content_provider_) { + if (res.is_chunked_content_provider_) { + res.set_header("Transfer-Encoding", "chunked"); + if (type == detail::EncodingType::Gzip) { + res.set_header("Content-Encoding", "gzip"); + } else if (type == detail::EncodingType::Brotli) { + res.set_header("Content-Encoding", "br"); + } + } + } + } + } else { + if (req.ranges.empty() || res.status != StatusCode::PartialContent_206) { + ; + } else if (req.ranges.size() == 1) { + auto offset_and_length = + detail::get_range_offset_and_length(req.ranges[0], res.body.size()); + auto offset = offset_and_length.first; + auto length = offset_and_length.second; + + auto content_range = detail::make_content_range_header_field( + offset_and_length, res.body.size()); + res.set_header("Content-Range", content_range); + + assert(offset + length <= res.body.size()); + res.body = res.body.substr(offset, length); + } else { + std::string data; + detail::make_multipart_ranges_data(req, res, boundary, content_type, + res.body.size(), data); + res.body.swap(data); + } + + if (type != detail::EncodingType::None) { + std::unique_ptr compressor; + std::string content_encoding; + + if (type == detail::EncodingType::Gzip) { +#ifdef CPPHTTPLIB_ZLIB_SUPPORT + compressor = detail::make_unique(); + content_encoding = "gzip"; +#endif + } else if (type == detail::EncodingType::Brotli) { +#ifdef CPPHTTPLIB_BROTLI_SUPPORT + compressor = detail::make_unique(); + content_encoding = "br"; +#endif + } + + if (compressor) { + std::string compressed; + if (compressor->compress(res.body.data(), res.body.size(), true, + [&](const char *data, size_t data_len) { + compressed.append(data, data_len); + return true; + })) { + res.body.swap(compressed); + res.set_header("Content-Encoding", content_encoding); + } + } + } + + auto length = std::to_string(res.body.size()); + res.set_header("Content-Length", length); + } +} + +inline bool Server::dispatch_request_for_content_reader( + Request &req, Response &res, ContentReader content_reader, + const HandlersForContentReader &handlers) const { + for (const auto &x : handlers) { + const auto &matcher = x.first; + const auto &handler = x.second; + + if (matcher->match(req)) { + handler(req, res, content_reader); + return true; + } + } + return false; +} + +inline bool +Server::process_request(Stream &strm, const std::string &remote_addr, + int remote_port, const std::string &local_addr, + int local_port, bool close_connection, + bool &connection_closed, + const std::function &setup_request) { + std::array buf{}; + + detail::stream_line_reader line_reader(strm, buf.data(), buf.size()); + + // Connection has been closed on client + if (!line_reader.getline()) { return false; } + + Request req; + + Response res; + res.version = "HTTP/1.1"; + res.headers = default_headers_; + +#ifdef _WIN32 + // TODO: Increase FD_SETSIZE statically (libzmq), dynamically (MySQL). +#else +#ifndef CPPHTTPLIB_USE_POLL + // Socket file descriptor exceeded FD_SETSIZE... + if (strm.socket() >= FD_SETSIZE) { + Headers dummy; + detail::read_headers(strm, dummy); + res.status = StatusCode::InternalServerError_500; + return write_response(strm, close_connection, req, res); + } +#endif +#endif + + // Check if the request URI doesn't exceed the limit + if (line_reader.size() > CPPHTTPLIB_REQUEST_URI_MAX_LENGTH) { + Headers dummy; + detail::read_headers(strm, dummy); + res.status = StatusCode::UriTooLong_414; + return write_response(strm, close_connection, req, res); + } + + // Request line and headers + if (!parse_request_line(line_reader.ptr(), req) || + !detail::read_headers(strm, req.headers)) { + res.status = StatusCode::BadRequest_400; + return write_response(strm, close_connection, req, res); + } + + if (req.get_header_value("Connection") == "close") { + connection_closed = true; + } + + if (req.version == "HTTP/1.0" && + req.get_header_value("Connection") != "Keep-Alive") { + connection_closed = true; + } + + req.remote_addr = remote_addr; + req.remote_port = remote_port; + req.set_header("REMOTE_ADDR", req.remote_addr); + req.set_header("REMOTE_PORT", std::to_string(req.remote_port)); + + req.local_addr = local_addr; + req.local_port = local_port; + req.set_header("LOCAL_ADDR", req.local_addr); + req.set_header("LOCAL_PORT", std::to_string(req.local_port)); + + if (req.has_header("Range")) { + const auto &range_header_value = req.get_header_value("Range"); + if (!detail::parse_range_header(range_header_value, req.ranges)) { + res.status = StatusCode::RangeNotSatisfiable_416; + return write_response(strm, close_connection, req, res); + } + } + + if (setup_request) { setup_request(req); } + + if (req.get_header_value("Expect") == "100-continue") { + int status = StatusCode::Continue_100; + if (expect_100_continue_handler_) { + status = expect_100_continue_handler_(req, res); + } + switch (status) { + case StatusCode::Continue_100: + case StatusCode::ExpectationFailed_417: + detail::write_response_line(strm, status); + strm.write("\r\n"); + break; + default: + connection_closed = true; + return write_response(strm, true, req, res); + } + } + + // Routing + auto routed = false; +#ifdef CPPHTTPLIB_NO_EXCEPTIONS + routed = routing(req, res, strm); +#else + try { + routed = routing(req, res, strm); + } catch (std::exception &e) { + if (exception_handler_) { + auto ep = std::current_exception(); + exception_handler_(req, res, ep); + routed = true; + } else { + res.status = StatusCode::InternalServerError_500; + std::string val; + auto s = e.what(); + for (size_t i = 0; s[i]; i++) { + switch (s[i]) { + case '\r': val += "\\r"; break; + case '\n': val += "\\n"; break; + default: val += s[i]; break; + } + } + res.set_header("EXCEPTION_WHAT", val); + } + } catch (...) { + if (exception_handler_) { + auto ep = std::current_exception(); + exception_handler_(req, res, ep); + routed = true; + } else { + res.status = StatusCode::InternalServerError_500; + res.set_header("EXCEPTION_WHAT", "UNKNOWN"); + } + } +#endif + if (routed) { + if (res.status == -1) { + res.status = req.ranges.empty() ? StatusCode::OK_200 + : StatusCode::PartialContent_206; + } + + if (detail::range_error(req, res)) { + res.body.clear(); + res.content_length_ = 0; + res.content_provider_ = nullptr; + res.status = StatusCode::RangeNotSatisfiable_416; + return write_response(strm, close_connection, req, res); + } + + // Serve file content by using a content provider + if (!res.file_content_path_.empty()) { + const auto &path = res.file_content_path_; + auto mm = std::make_shared(path.c_str()); + if (!mm->is_open()) { + res.body.clear(); + res.content_length_ = 0; + res.content_provider_ = nullptr; + res.status = StatusCode::NotFound_404; + return write_response(strm, close_connection, req, res); + } + + auto content_type = res.file_content_content_type_; + if (content_type.empty()) { + content_type = detail::find_content_type( + path, file_extension_and_mimetype_map_, default_file_mimetype_); + } + + res.set_content_provider( + mm->size(), content_type, + [mm](size_t offset, size_t length, DataSink &sink) -> bool { + sink.write(mm->data() + offset, length); + return true; + }); + } + + return write_response_with_content(strm, close_connection, req, res); + } else { + if (res.status == -1) { res.status = StatusCode::NotFound_404; } + + return write_response(strm, close_connection, req, res); + } +} + +inline bool Server::is_valid() const { return true; } + +inline bool Server::process_and_close_socket(socket_t sock) { + std::string remote_addr; + int remote_port = 0; + detail::get_remote_ip_and_port(sock, remote_addr, remote_port); + + std::string local_addr; + int local_port = 0; + detail::get_local_ip_and_port(sock, local_addr, local_port); + + auto ret = detail::process_server_socket( + svr_sock_, sock, keep_alive_max_count_, keep_alive_timeout_sec_, + read_timeout_sec_, read_timeout_usec_, write_timeout_sec_, + write_timeout_usec_, + [&](Stream &strm, bool close_connection, bool &connection_closed) { + return process_request(strm, remote_addr, remote_port, local_addr, + local_port, close_connection, connection_closed, + nullptr); + }); + + detail::shutdown_socket(sock); + detail::close_socket(sock); + return ret; +} + +// HTTP client implementation +inline ClientImpl::ClientImpl(const std::string &host) + : ClientImpl(host, 80, std::string(), std::string()) {} + +inline ClientImpl::ClientImpl(const std::string &host, int port) + : ClientImpl(host, port, std::string(), std::string()) {} + +inline ClientImpl::ClientImpl(const std::string &host, int port, + const std::string &client_cert_path, + const std::string &client_key_path) + : host_(detail::escape_abstract_namespace_unix_domain(host)), port_(port), + host_and_port_(adjust_host_string(host_) + ":" + std::to_string(port)), + client_cert_path_(client_cert_path), client_key_path_(client_key_path) {} + +inline ClientImpl::~ClientImpl() { + std::lock_guard guard(socket_mutex_); + shutdown_socket(socket_); + close_socket(socket_); +} + +inline bool ClientImpl::is_valid() const { return true; } + +inline void ClientImpl::copy_settings(const ClientImpl &rhs) { + client_cert_path_ = rhs.client_cert_path_; + client_key_path_ = rhs.client_key_path_; + connection_timeout_sec_ = rhs.connection_timeout_sec_; + read_timeout_sec_ = rhs.read_timeout_sec_; + read_timeout_usec_ = rhs.read_timeout_usec_; + write_timeout_sec_ = rhs.write_timeout_sec_; + write_timeout_usec_ = rhs.write_timeout_usec_; + basic_auth_username_ = rhs.basic_auth_username_; + basic_auth_password_ = rhs.basic_auth_password_; + bearer_token_auth_token_ = rhs.bearer_token_auth_token_; +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + digest_auth_username_ = rhs.digest_auth_username_; + digest_auth_password_ = rhs.digest_auth_password_; +#endif + keep_alive_ = rhs.keep_alive_; + follow_location_ = rhs.follow_location_; + url_encode_ = rhs.url_encode_; + address_family_ = rhs.address_family_; + tcp_nodelay_ = rhs.tcp_nodelay_; + ipv6_v6only_ = rhs.ipv6_v6only_; + socket_options_ = rhs.socket_options_; + compress_ = rhs.compress_; + decompress_ = rhs.decompress_; + interface_ = rhs.interface_; + proxy_host_ = rhs.proxy_host_; + proxy_port_ = rhs.proxy_port_; + proxy_basic_auth_username_ = rhs.proxy_basic_auth_username_; + proxy_basic_auth_password_ = rhs.proxy_basic_auth_password_; + proxy_bearer_token_auth_token_ = rhs.proxy_bearer_token_auth_token_; +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + proxy_digest_auth_username_ = rhs.proxy_digest_auth_username_; + proxy_digest_auth_password_ = rhs.proxy_digest_auth_password_; +#endif +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + ca_cert_file_path_ = rhs.ca_cert_file_path_; + ca_cert_dir_path_ = rhs.ca_cert_dir_path_; + ca_cert_store_ = rhs.ca_cert_store_; +#endif +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + server_certificate_verification_ = rhs.server_certificate_verification_; + server_hostname_verification_ = rhs.server_hostname_verification_; + server_certificate_verifier_ = rhs.server_certificate_verifier_; +#endif + logger_ = rhs.logger_; +} + +inline socket_t ClientImpl::create_client_socket(Error &error) const { + if (!proxy_host_.empty() && proxy_port_ != -1) { + return detail::create_client_socket( + proxy_host_, std::string(), proxy_port_, address_family_, tcp_nodelay_, + ipv6_v6only_, socket_options_, connection_timeout_sec_, + connection_timeout_usec_, read_timeout_sec_, read_timeout_usec_, + write_timeout_sec_, write_timeout_usec_, interface_, error); + } + + // Check is custom IP specified for host_ + std::string ip; + auto it = addr_map_.find(host_); + if (it != addr_map_.end()) { ip = it->second; } + + return detail::create_client_socket( + host_, ip, port_, address_family_, tcp_nodelay_, ipv6_v6only_, + socket_options_, connection_timeout_sec_, connection_timeout_usec_, + read_timeout_sec_, read_timeout_usec_, write_timeout_sec_, + write_timeout_usec_, interface_, error); +} + +inline bool ClientImpl::create_and_connect_socket(Socket &socket, + Error &error) { + auto sock = create_client_socket(error); + if (sock == INVALID_SOCKET) { return false; } + socket.sock = sock; + return true; +} + +inline void ClientImpl::shutdown_ssl(Socket & /*socket*/, + bool /*shutdown_gracefully*/) { + // If there are any requests in flight from threads other than us, then it's + // a thread-unsafe race because individual ssl* objects are not thread-safe. + assert(socket_requests_in_flight_ == 0 || + socket_requests_are_from_thread_ == std::this_thread::get_id()); +} + +inline void ClientImpl::shutdown_socket(Socket &socket) const { + if (socket.sock == INVALID_SOCKET) { return; } + detail::shutdown_socket(socket.sock); +} + +inline void ClientImpl::close_socket(Socket &socket) { + // If there are requests in flight in another thread, usually closing + // the socket will be fine and they will simply receive an error when + // using the closed socket, but it is still a bug since rarely the OS + // may reassign the socket id to be used for a new socket, and then + // suddenly they will be operating on a live socket that is different + // than the one they intended! + assert(socket_requests_in_flight_ == 0 || + socket_requests_are_from_thread_ == std::this_thread::get_id()); + + // It is also a bug if this happens while SSL is still active +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + assert(socket.ssl == nullptr); +#endif + if (socket.sock == INVALID_SOCKET) { return; } + detail::close_socket(socket.sock); + socket.sock = INVALID_SOCKET; +} + +inline bool ClientImpl::read_response_line(Stream &strm, const Request &req, + Response &res) const { + std::array buf{}; + + detail::stream_line_reader line_reader(strm, buf.data(), buf.size()); + + if (!line_reader.getline()) { return false; } + +#ifdef CPPHTTPLIB_ALLOW_LF_AS_LINE_TERMINATOR + const static std::regex re("(HTTP/1\\.[01]) (\\d{3})(?: (.*?))?\r?\n"); +#else + const static std::regex re("(HTTP/1\\.[01]) (\\d{3})(?: (.*?))?\r\n"); +#endif + + std::cmatch m; + if (!std::regex_match(line_reader.ptr(), m, re)) { + return req.method == "CONNECT"; + } + res.version = std::string(m[1]); + res.status = std::stoi(std::string(m[2])); + res.reason = std::string(m[3]); + + // Ignore '100 Continue' + while (res.status == StatusCode::Continue_100) { + if (!line_reader.getline()) { return false; } // CRLF + if (!line_reader.getline()) { return false; } // next response line + + if (!std::regex_match(line_reader.ptr(), m, re)) { return false; } + res.version = std::string(m[1]); + res.status = std::stoi(std::string(m[2])); + res.reason = std::string(m[3]); + } + + return true; +} + +inline bool ClientImpl::send(Request &req, Response &res, Error &error) { + std::lock_guard request_mutex_guard(request_mutex_); + auto ret = send_(req, res, error); + if (error == Error::SSLPeerCouldBeClosed_) { + assert(!ret); + ret = send_(req, res, error); + } + return ret; +} + +inline bool ClientImpl::send_(Request &req, Response &res, Error &error) { + { + std::lock_guard guard(socket_mutex_); + + // Set this to false immediately - if it ever gets set to true by the end of + // the request, we know another thread instructed us to close the socket. + socket_should_be_closed_when_request_is_done_ = false; + + auto is_alive = false; + if (socket_.is_open()) { + is_alive = detail::is_socket_alive(socket_.sock); + if (!is_alive) { + // Attempt to avoid sigpipe by shutting down nongracefully if it seems + // like the other side has already closed the connection Also, there + // cannot be any requests in flight from other threads since we locked + // request_mutex_, so safe to close everything immediately + const bool shutdown_gracefully = false; + shutdown_ssl(socket_, shutdown_gracefully); + shutdown_socket(socket_); + close_socket(socket_); + } + } + + if (!is_alive) { + if (!create_and_connect_socket(socket_, error)) { return false; } + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + // TODO: refactoring + if (is_ssl()) { + auto &scli = static_cast(*this); + if (!proxy_host_.empty() && proxy_port_ != -1) { + auto success = false; + if (!scli.connect_with_proxy(socket_, res, success, error)) { + return success; + } + } + + if (!scli.initialize_ssl(socket_, error)) { return false; } + } +#endif + } + + // Mark the current socket as being in use so that it cannot be closed by + // anyone else while this request is ongoing, even though we will be + // releasing the mutex. + if (socket_requests_in_flight_ > 1) { + assert(socket_requests_are_from_thread_ == std::this_thread::get_id()); + } + socket_requests_in_flight_ += 1; + socket_requests_are_from_thread_ = std::this_thread::get_id(); + } + + for (const auto &header : default_headers_) { + if (req.headers.find(header.first) == req.headers.end()) { + req.headers.insert(header); + } + } + + auto ret = false; + auto close_connection = !keep_alive_; + + auto se = detail::scope_exit([&]() { + // Briefly lock mutex in order to mark that a request is no longer ongoing + std::lock_guard guard(socket_mutex_); + socket_requests_in_flight_ -= 1; + if (socket_requests_in_flight_ <= 0) { + assert(socket_requests_in_flight_ == 0); + socket_requests_are_from_thread_ = std::thread::id(); + } + + if (socket_should_be_closed_when_request_is_done_ || close_connection || + !ret) { + shutdown_ssl(socket_, true); + shutdown_socket(socket_); + close_socket(socket_); + } + }); + + ret = process_socket(socket_, [&](Stream &strm) { + return handle_request(strm, req, res, close_connection, error); + }); + + if (!ret) { + if (error == Error::Success) { error = Error::Unknown; } + } + + return ret; +} + +inline Result ClientImpl::send(const Request &req) { + auto req2 = req; + return send_(std::move(req2)); +} + +inline Result ClientImpl::send_(Request &&req) { + auto res = detail::make_unique(); + auto error = Error::Success; + auto ret = send(req, *res, error); + return Result{ret ? std::move(res) : nullptr, error, std::move(req.headers)}; +} + +inline bool ClientImpl::handle_request(Stream &strm, Request &req, + Response &res, bool close_connection, + Error &error) { + if (req.path.empty()) { + error = Error::Connection; + return false; + } + + auto req_save = req; + + bool ret; + + if (!is_ssl() && !proxy_host_.empty() && proxy_port_ != -1) { + auto req2 = req; + req2.path = "http://" + host_and_port_ + req.path; + ret = process_request(strm, req2, res, close_connection, error); + req = req2; + req.path = req_save.path; + } else { + ret = process_request(strm, req, res, close_connection, error); + } + + if (!ret) { return false; } + + if (res.get_header_value("Connection") == "close" || + (res.version == "HTTP/1.0" && res.reason != "Connection established")) { + // TODO this requires a not-entirely-obvious chain of calls to be correct + // for this to be safe. + + // This is safe to call because handle_request is only called by send_ + // which locks the request mutex during the process. It would be a bug + // to call it from a different thread since it's a thread-safety issue + // to do these things to the socket if another thread is using the socket. + std::lock_guard guard(socket_mutex_); + shutdown_ssl(socket_, true); + shutdown_socket(socket_); + close_socket(socket_); + } + + if (300 < res.status && res.status < 400 && follow_location_) { + req = req_save; + ret = redirect(req, res, error); + } + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + if ((res.status == StatusCode::Unauthorized_401 || + res.status == StatusCode::ProxyAuthenticationRequired_407) && + req.authorization_count_ < 5) { + auto is_proxy = res.status == StatusCode::ProxyAuthenticationRequired_407; + const auto &username = + is_proxy ? proxy_digest_auth_username_ : digest_auth_username_; + const auto &password = + is_proxy ? proxy_digest_auth_password_ : digest_auth_password_; + + if (!username.empty() && !password.empty()) { + std::map auth; + if (detail::parse_www_authenticate(res, auth, is_proxy)) { + Request new_req = req; + new_req.authorization_count_ += 1; + new_req.headers.erase(is_proxy ? "Proxy-Authorization" + : "Authorization"); + new_req.headers.insert(detail::make_digest_authentication_header( + req, auth, new_req.authorization_count_, detail::random_string(10), + username, password, is_proxy)); + + Response new_res; + + ret = send(new_req, new_res, error); + if (ret) { res = new_res; } + } + } + } +#endif + + return ret; +} + +inline bool ClientImpl::redirect(Request &req, Response &res, Error &error) { + if (req.redirect_count_ == 0) { + error = Error::ExceedRedirectCount; + return false; + } + + auto location = res.get_header_value("location"); + if (location.empty()) { return false; } + + const static std::regex re( + R"((?:(https?):)?(?://(?:\[([a-fA-F\d:]+)\]|([^:/?#]+))(?::(\d+))?)?([^?#]*)(\?[^#]*)?(?:#.*)?)"); + + std::smatch m; + if (!std::regex_match(location, m, re)) { return false; } + + auto scheme = is_ssl() ? "https" : "http"; + + auto next_scheme = m[1].str(); + auto next_host = m[2].str(); + if (next_host.empty()) { next_host = m[3].str(); } + auto port_str = m[4].str(); + auto next_path = m[5].str(); + auto next_query = m[6].str(); + + auto next_port = port_; + if (!port_str.empty()) { + next_port = std::stoi(port_str); + } else if (!next_scheme.empty()) { + next_port = next_scheme == "https" ? 443 : 80; + } + + if (next_scheme.empty()) { next_scheme = scheme; } + if (next_host.empty()) { next_host = host_; } + if (next_path.empty()) { next_path = "/"; } + + auto path = detail::decode_url(next_path, true) + next_query; + + if (next_scheme == scheme && next_host == host_ && next_port == port_) { + return detail::redirect(*this, req, res, path, location, error); + } else { + if (next_scheme == "https") { +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + SSLClient cli(next_host, next_port); + cli.copy_settings(*this); + if (ca_cert_store_) { cli.set_ca_cert_store(ca_cert_store_); } + return detail::redirect(cli, req, res, path, location, error); +#else + return false; +#endif + } else { + ClientImpl cli(next_host, next_port); + cli.copy_settings(*this); + return detail::redirect(cli, req, res, path, location, error); + } + } +} + +inline bool ClientImpl::write_content_with_provider(Stream &strm, + const Request &req, + Error &error) const { + auto is_shutting_down = []() { return false; }; + + if (req.is_chunked_content_provider_) { + // TODO: Brotli support + std::unique_ptr compressor; +#ifdef CPPHTTPLIB_ZLIB_SUPPORT + if (compress_) { + compressor = detail::make_unique(); + } else +#endif + { + compressor = detail::make_unique(); + } + + return detail::write_content_chunked(strm, req.content_provider_, + is_shutting_down, *compressor, error); + } else { + return detail::write_content(strm, req.content_provider_, 0, + req.content_length_, is_shutting_down, error); + } +} + +inline bool ClientImpl::write_request(Stream &strm, Request &req, + bool close_connection, Error &error) { + // Prepare additional headers + if (close_connection) { + if (!req.has_header("Connection")) { + req.set_header("Connection", "close"); + } + } + + if (!req.has_header("Host")) { + if (is_ssl()) { + if (port_ == 443) { + req.set_header("Host", host_); + } else { + req.set_header("Host", host_and_port_); + } + } else { + if (port_ == 80) { + req.set_header("Host", host_); + } else { + req.set_header("Host", host_and_port_); + } + } + } + + if (!req.has_header("Accept")) { req.set_header("Accept", "*/*"); } + +#ifndef CPPHTTPLIB_NO_DEFAULT_USER_AGENT + if (!req.has_header("User-Agent")) { + auto agent = std::string("cpp-httplib/") + CPPHTTPLIB_VERSION; + req.set_header("User-Agent", agent); + } +#endif + + if (req.body.empty()) { + if (req.content_provider_) { + if (!req.is_chunked_content_provider_) { + if (!req.has_header("Content-Length")) { + auto length = std::to_string(req.content_length_); + req.set_header("Content-Length", length); + } + } + } else { + if (req.method == "POST" || req.method == "PUT" || + req.method == "PATCH") { + req.set_header("Content-Length", "0"); + } + } + } else { + if (!req.has_header("Content-Type")) { + req.set_header("Content-Type", "text/plain"); + } + + if (!req.has_header("Content-Length")) { + auto length = std::to_string(req.body.size()); + req.set_header("Content-Length", length); + } + } + + if (!basic_auth_password_.empty() || !basic_auth_username_.empty()) { + if (!req.has_header("Authorization")) { + req.headers.insert(make_basic_authentication_header( + basic_auth_username_, basic_auth_password_, false)); + } + } + + if (!proxy_basic_auth_username_.empty() && + !proxy_basic_auth_password_.empty()) { + if (!req.has_header("Proxy-Authorization")) { + req.headers.insert(make_basic_authentication_header( + proxy_basic_auth_username_, proxy_basic_auth_password_, true)); + } + } + + if (!bearer_token_auth_token_.empty()) { + if (!req.has_header("Authorization")) { + req.headers.insert(make_bearer_token_authentication_header( + bearer_token_auth_token_, false)); + } + } + + if (!proxy_bearer_token_auth_token_.empty()) { + if (!req.has_header("Proxy-Authorization")) { + req.headers.insert(make_bearer_token_authentication_header( + proxy_bearer_token_auth_token_, true)); + } + } + + // Request line and headers + { + detail::BufferStream bstrm; + + const auto &path = url_encode_ ? detail::encode_url(req.path) : req.path; + detail::write_request_line(bstrm, req.method, path); + + header_writer_(bstrm, req.headers); + + // Flush buffer + auto &data = bstrm.get_buffer(); + if (!detail::write_data(strm, data.data(), data.size())) { + error = Error::Write; + return false; + } + } + + // Body + if (req.body.empty()) { + return write_content_with_provider(strm, req, error); + } + + if (!detail::write_data(strm, req.body.data(), req.body.size())) { + error = Error::Write; + return false; + } + + return true; +} + +inline std::unique_ptr ClientImpl::send_with_content_provider( + Request &req, const char *body, size_t content_length, + ContentProvider content_provider, + ContentProviderWithoutLength content_provider_without_length, + const std::string &content_type, Error &error) { + if (!content_type.empty()) { req.set_header("Content-Type", content_type); } + +#ifdef CPPHTTPLIB_ZLIB_SUPPORT + if (compress_) { req.set_header("Content-Encoding", "gzip"); } +#endif + +#ifdef CPPHTTPLIB_ZLIB_SUPPORT + if (compress_ && !content_provider_without_length) { + // TODO: Brotli support + detail::gzip_compressor compressor; + + if (content_provider) { + auto ok = true; + size_t offset = 0; + DataSink data_sink; + + data_sink.write = [&](const char *data, size_t data_len) -> bool { + if (ok) { + auto last = offset + data_len == content_length; + + auto ret = compressor.compress( + data, data_len, last, + [&](const char *compressed_data, size_t compressed_data_len) { + req.body.append(compressed_data, compressed_data_len); + return true; + }); + + if (ret) { + offset += data_len; + } else { + ok = false; + } + } + return ok; + }; + + while (ok && offset < content_length) { + if (!content_provider(offset, content_length - offset, data_sink)) { + error = Error::Canceled; + return nullptr; + } + } + } else { + if (!compressor.compress(body, content_length, true, + [&](const char *data, size_t data_len) { + req.body.append(data, data_len); + return true; + })) { + error = Error::Compression; + return nullptr; + } + } + } else +#endif + { + if (content_provider) { + req.content_length_ = content_length; + req.content_provider_ = std::move(content_provider); + req.is_chunked_content_provider_ = false; + } else if (content_provider_without_length) { + req.content_length_ = 0; + req.content_provider_ = detail::ContentProviderAdapter( + std::move(content_provider_without_length)); + req.is_chunked_content_provider_ = true; + req.set_header("Transfer-Encoding", "chunked"); + } else { + req.body.assign(body, content_length); + } + } + + auto res = detail::make_unique(); + return send(req, *res, error) ? std::move(res) : nullptr; +} + +inline Result ClientImpl::send_with_content_provider( + const std::string &method, const std::string &path, const Headers &headers, + const char *body, size_t content_length, ContentProvider content_provider, + ContentProviderWithoutLength content_provider_without_length, + const std::string &content_type, Progress progress) { + Request req; + req.method = method; + req.headers = headers; + req.path = path; + req.progress = progress; + + auto error = Error::Success; + + auto res = send_with_content_provider( + req, body, content_length, std::move(content_provider), + std::move(content_provider_without_length), content_type, error); + + return Result{std::move(res), error, std::move(req.headers)}; +} + +inline std::string +ClientImpl::adjust_host_string(const std::string &host) const { + if (host.find(':') != std::string::npos) { return "[" + host + "]"; } + return host; +} + +inline bool ClientImpl::process_request(Stream &strm, Request &req, + Response &res, bool close_connection, + Error &error) { + // Send request + if (!write_request(strm, req, close_connection, error)) { return false; } + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + if (is_ssl()) { + auto is_proxy_enabled = !proxy_host_.empty() && proxy_port_ != -1; + if (!is_proxy_enabled) { + char buf[1]; + if (SSL_peek(socket_.ssl, buf, 1) == 0 && + SSL_get_error(socket_.ssl, 0) == SSL_ERROR_ZERO_RETURN) { + error = Error::SSLPeerCouldBeClosed_; + return false; + } + } + } +#endif + + // Receive response and headers + if (!read_response_line(strm, req, res) || + !detail::read_headers(strm, res.headers)) { + error = Error::Read; + return false; + } + + // Body + if ((res.status != StatusCode::NoContent_204) && req.method != "HEAD" && + req.method != "CONNECT") { + auto redirect = 300 < res.status && res.status < 400 && follow_location_; + + if (req.response_handler && !redirect) { + if (!req.response_handler(res)) { + error = Error::Canceled; + return false; + } + } + + auto out = + req.content_receiver + ? static_cast( + [&](const char *buf, size_t n, uint64_t off, uint64_t len) { + if (redirect) { return true; } + auto ret = req.content_receiver(buf, n, off, len); + if (!ret) { error = Error::Canceled; } + return ret; + }) + : static_cast( + [&](const char *buf, size_t n, uint64_t /*off*/, + uint64_t /*len*/) { + if (res.body.size() + n > res.body.max_size()) { + return false; + } + res.body.append(buf, n); + return true; + }); + + auto progress = [&](uint64_t current, uint64_t total) { + if (!req.progress || redirect) { return true; } + auto ret = req.progress(current, total); + if (!ret) { error = Error::Canceled; } + return ret; + }; + + if (res.has_header("Content-Length")) { + if (!req.content_receiver) { + auto len = std::min(res.get_header_value_u64("Content-Length"), + res.body.max_size()); + if (len > 0) { res.body.reserve(len); } + } + } + + int dummy_status; + if (!detail::read_content(strm, res, (std::numeric_limits::max)(), + dummy_status, std::move(progress), std::move(out), + decompress_)) { + if (error != Error::Canceled) { error = Error::Read; } + return false; + } + } + + // Log + if (logger_) { logger_(req, res); } + + return true; +} + +inline ContentProviderWithoutLength ClientImpl::get_multipart_content_provider( + const std::string &boundary, const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items) const { + size_t cur_item = 0; + size_t cur_start = 0; + // cur_item and cur_start are copied to within the std::function and maintain + // state between successive calls + return [&, cur_item, cur_start](size_t offset, + DataSink &sink) mutable -> bool { + if (!offset && !items.empty()) { + sink.os << detail::serialize_multipart_formdata(items, boundary, false); + return true; + } else if (cur_item < provider_items.size()) { + if (!cur_start) { + const auto &begin = detail::serialize_multipart_formdata_item_begin( + provider_items[cur_item], boundary); + offset += begin.size(); + cur_start = offset; + sink.os << begin; + } + + DataSink cur_sink; + auto has_data = true; + cur_sink.write = sink.write; + cur_sink.done = [&]() { has_data = false; }; + + if (!provider_items[cur_item].provider(offset - cur_start, cur_sink)) { + return false; + } + + if (!has_data) { + sink.os << detail::serialize_multipart_formdata_item_end(); + cur_item++; + cur_start = 0; + } + return true; + } else { + sink.os << detail::serialize_multipart_formdata_finish(boundary); + sink.done(); + return true; + } + }; +} + +inline bool +ClientImpl::process_socket(const Socket &socket, + std::function callback) { + return detail::process_client_socket( + socket.sock, read_timeout_sec_, read_timeout_usec_, write_timeout_sec_, + write_timeout_usec_, std::move(callback)); +} + +inline bool ClientImpl::is_ssl() const { return false; } + +inline Result ClientImpl::Get(const std::string &path) { + return Get(path, Headers(), Progress()); +} + +inline Result ClientImpl::Get(const std::string &path, Progress progress) { + return Get(path, Headers(), std::move(progress)); +} + +inline Result ClientImpl::Get(const std::string &path, const Headers &headers) { + return Get(path, headers, Progress()); +} + +inline Result ClientImpl::Get(const std::string &path, const Headers &headers, + Progress progress) { + Request req; + req.method = "GET"; + req.path = path; + req.headers = headers; + req.progress = std::move(progress); + + return send_(std::move(req)); +} + +inline Result ClientImpl::Get(const std::string &path, + ContentReceiver content_receiver) { + return Get(path, Headers(), nullptr, std::move(content_receiver), nullptr); +} + +inline Result ClientImpl::Get(const std::string &path, + ContentReceiver content_receiver, + Progress progress) { + return Get(path, Headers(), nullptr, std::move(content_receiver), + std::move(progress)); +} + +inline Result ClientImpl::Get(const std::string &path, const Headers &headers, + ContentReceiver content_receiver) { + return Get(path, headers, nullptr, std::move(content_receiver), nullptr); +} + +inline Result ClientImpl::Get(const std::string &path, const Headers &headers, + ContentReceiver content_receiver, + Progress progress) { + return Get(path, headers, nullptr, std::move(content_receiver), + std::move(progress)); +} + +inline Result ClientImpl::Get(const std::string &path, + ResponseHandler response_handler, + ContentReceiver content_receiver) { + return Get(path, Headers(), std::move(response_handler), + std::move(content_receiver), nullptr); +} + +inline Result ClientImpl::Get(const std::string &path, const Headers &headers, + ResponseHandler response_handler, + ContentReceiver content_receiver) { + return Get(path, headers, std::move(response_handler), + std::move(content_receiver), nullptr); +} + +inline Result ClientImpl::Get(const std::string &path, + ResponseHandler response_handler, + ContentReceiver content_receiver, + Progress progress) { + return Get(path, Headers(), std::move(response_handler), + std::move(content_receiver), std::move(progress)); +} + +inline Result ClientImpl::Get(const std::string &path, const Headers &headers, + ResponseHandler response_handler, + ContentReceiver content_receiver, + Progress progress) { + Request req; + req.method = "GET"; + req.path = path; + req.headers = headers; + req.response_handler = std::move(response_handler); + req.content_receiver = + [content_receiver](const char *data, size_t data_length, + uint64_t /*offset*/, uint64_t /*total_length*/) { + return content_receiver(data, data_length); + }; + req.progress = std::move(progress); + + return send_(std::move(req)); +} + +inline Result ClientImpl::Get(const std::string &path, const Params ¶ms, + const Headers &headers, Progress progress) { + if (params.empty()) { return Get(path, headers); } + + std::string path_with_query = append_query_params(path, params); + return Get(path_with_query, headers, std::move(progress)); +} + +inline Result ClientImpl::Get(const std::string &path, const Params ¶ms, + const Headers &headers, + ContentReceiver content_receiver, + Progress progress) { + return Get(path, params, headers, nullptr, std::move(content_receiver), + std::move(progress)); +} + +inline Result ClientImpl::Get(const std::string &path, const Params ¶ms, + const Headers &headers, + ResponseHandler response_handler, + ContentReceiver content_receiver, + Progress progress) { + if (params.empty()) { + return Get(path, headers, std::move(response_handler), + std::move(content_receiver), std::move(progress)); + } + + std::string path_with_query = append_query_params(path, params); + return Get(path_with_query, headers, std::move(response_handler), + std::move(content_receiver), std::move(progress)); +} + +inline Result ClientImpl::Head(const std::string &path) { + return Head(path, Headers()); +} + +inline Result ClientImpl::Head(const std::string &path, + const Headers &headers) { + Request req; + req.method = "HEAD"; + req.headers = headers; + req.path = path; + + return send_(std::move(req)); +} + +inline Result ClientImpl::Post(const std::string &path) { + return Post(path, std::string(), std::string()); +} + +inline Result ClientImpl::Post(const std::string &path, + const Headers &headers) { + return Post(path, headers, nullptr, 0, std::string()); +} + +inline Result ClientImpl::Post(const std::string &path, const char *body, + size_t content_length, + const std::string &content_type) { + return Post(path, Headers(), body, content_length, content_type, nullptr); +} + +inline Result ClientImpl::Post(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type) { + return send_with_content_provider("POST", path, headers, body, content_length, + nullptr, nullptr, content_type, nullptr); +} + +inline Result ClientImpl::Post(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type, + Progress progress) { + return send_with_content_provider("POST", path, headers, body, content_length, + nullptr, nullptr, content_type, progress); +} + +inline Result ClientImpl::Post(const std::string &path, const std::string &body, + const std::string &content_type) { + return Post(path, Headers(), body, content_type); +} + +inline Result ClientImpl::Post(const std::string &path, const std::string &body, + const std::string &content_type, + Progress progress) { + return Post(path, Headers(), body, content_type, progress); +} + +inline Result ClientImpl::Post(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type) { + return send_with_content_provider("POST", path, headers, body.data(), + body.size(), nullptr, nullptr, content_type, + nullptr); +} + +inline Result ClientImpl::Post(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type, + Progress progress) { + return send_with_content_provider("POST", path, headers, body.data(), + body.size(), nullptr, nullptr, content_type, + progress); +} + +inline Result ClientImpl::Post(const std::string &path, const Params ¶ms) { + return Post(path, Headers(), params); +} + +inline Result ClientImpl::Post(const std::string &path, size_t content_length, + ContentProvider content_provider, + const std::string &content_type) { + return Post(path, Headers(), content_length, std::move(content_provider), + content_type); +} + +inline Result ClientImpl::Post(const std::string &path, + ContentProviderWithoutLength content_provider, + const std::string &content_type) { + return Post(path, Headers(), std::move(content_provider), content_type); +} + +inline Result ClientImpl::Post(const std::string &path, const Headers &headers, + size_t content_length, + ContentProvider content_provider, + const std::string &content_type) { + return send_with_content_provider("POST", path, headers, nullptr, + content_length, std::move(content_provider), + nullptr, content_type, nullptr); +} + +inline Result ClientImpl::Post(const std::string &path, const Headers &headers, + ContentProviderWithoutLength content_provider, + const std::string &content_type) { + return send_with_content_provider("POST", path, headers, nullptr, 0, nullptr, + std::move(content_provider), content_type, + nullptr); +} + +inline Result ClientImpl::Post(const std::string &path, const Headers &headers, + const Params ¶ms) { + auto query = detail::params_to_query_str(params); + return Post(path, headers, query, "application/x-www-form-urlencoded"); +} + +inline Result ClientImpl::Post(const std::string &path, const Headers &headers, + const Params ¶ms, Progress progress) { + auto query = detail::params_to_query_str(params); + return Post(path, headers, query, "application/x-www-form-urlencoded", + progress); +} + +inline Result ClientImpl::Post(const std::string &path, + const MultipartFormDataItems &items) { + return Post(path, Headers(), items); +} + +inline Result ClientImpl::Post(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items) { + const auto &boundary = detail::make_multipart_data_boundary(); + const auto &content_type = + detail::serialize_multipart_formdata_get_content_type(boundary); + const auto &body = detail::serialize_multipart_formdata(items, boundary); + return Post(path, headers, body, content_type); +} + +inline Result ClientImpl::Post(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const std::string &boundary) { + if (!detail::is_multipart_boundary_chars_valid(boundary)) { + return Result{nullptr, Error::UnsupportedMultipartBoundaryChars}; + } + + const auto &content_type = + detail::serialize_multipart_formdata_get_content_type(boundary); + const auto &body = detail::serialize_multipart_formdata(items, boundary); + return Post(path, headers, body, content_type); +} + +inline Result +ClientImpl::Post(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items) { + const auto &boundary = detail::make_multipart_data_boundary(); + const auto &content_type = + detail::serialize_multipart_formdata_get_content_type(boundary); + return send_with_content_provider( + "POST", path, headers, nullptr, 0, nullptr, + get_multipart_content_provider(boundary, items, provider_items), + content_type, nullptr); +} + +inline Result ClientImpl::Put(const std::string &path) { + return Put(path, std::string(), std::string()); +} + +inline Result ClientImpl::Put(const std::string &path, const char *body, + size_t content_length, + const std::string &content_type) { + return Put(path, Headers(), body, content_length, content_type); +} + +inline Result ClientImpl::Put(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type) { + return send_with_content_provider("PUT", path, headers, body, content_length, + nullptr, nullptr, content_type, nullptr); +} + +inline Result ClientImpl::Put(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type, + Progress progress) { + return send_with_content_provider("PUT", path, headers, body, content_length, + nullptr, nullptr, content_type, progress); +} + +inline Result ClientImpl::Put(const std::string &path, const std::string &body, + const std::string &content_type) { + return Put(path, Headers(), body, content_type); +} + +inline Result ClientImpl::Put(const std::string &path, const std::string &body, + const std::string &content_type, + Progress progress) { + return Put(path, Headers(), body, content_type, progress); +} + +inline Result ClientImpl::Put(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type) { + return send_with_content_provider("PUT", path, headers, body.data(), + body.size(), nullptr, nullptr, content_type, + nullptr); +} + +inline Result ClientImpl::Put(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type, + Progress progress) { + return send_with_content_provider("PUT", path, headers, body.data(), + body.size(), nullptr, nullptr, content_type, + progress); +} + +inline Result ClientImpl::Put(const std::string &path, size_t content_length, + ContentProvider content_provider, + const std::string &content_type) { + return Put(path, Headers(), content_length, std::move(content_provider), + content_type); +} + +inline Result ClientImpl::Put(const std::string &path, + ContentProviderWithoutLength content_provider, + const std::string &content_type) { + return Put(path, Headers(), std::move(content_provider), content_type); +} + +inline Result ClientImpl::Put(const std::string &path, const Headers &headers, + size_t content_length, + ContentProvider content_provider, + const std::string &content_type) { + return send_with_content_provider("PUT", path, headers, nullptr, + content_length, std::move(content_provider), + nullptr, content_type, nullptr); +} + +inline Result ClientImpl::Put(const std::string &path, const Headers &headers, + ContentProviderWithoutLength content_provider, + const std::string &content_type) { + return send_with_content_provider("PUT", path, headers, nullptr, 0, nullptr, + std::move(content_provider), content_type, + nullptr); +} + +inline Result ClientImpl::Put(const std::string &path, const Params ¶ms) { + return Put(path, Headers(), params); +} + +inline Result ClientImpl::Put(const std::string &path, const Headers &headers, + const Params ¶ms) { + auto query = detail::params_to_query_str(params); + return Put(path, headers, query, "application/x-www-form-urlencoded"); +} + +inline Result ClientImpl::Put(const std::string &path, const Headers &headers, + const Params ¶ms, Progress progress) { + auto query = detail::params_to_query_str(params); + return Put(path, headers, query, "application/x-www-form-urlencoded", + progress); +} + +inline Result ClientImpl::Put(const std::string &path, + const MultipartFormDataItems &items) { + return Put(path, Headers(), items); +} + +inline Result ClientImpl::Put(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items) { + const auto &boundary = detail::make_multipart_data_boundary(); + const auto &content_type = + detail::serialize_multipart_formdata_get_content_type(boundary); + const auto &body = detail::serialize_multipart_formdata(items, boundary); + return Put(path, headers, body, content_type); +} + +inline Result ClientImpl::Put(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const std::string &boundary) { + if (!detail::is_multipart_boundary_chars_valid(boundary)) { + return Result{nullptr, Error::UnsupportedMultipartBoundaryChars}; + } + + const auto &content_type = + detail::serialize_multipart_formdata_get_content_type(boundary); + const auto &body = detail::serialize_multipart_formdata(items, boundary); + return Put(path, headers, body, content_type); +} + +inline Result +ClientImpl::Put(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items) { + const auto &boundary = detail::make_multipart_data_boundary(); + const auto &content_type = + detail::serialize_multipart_formdata_get_content_type(boundary); + return send_with_content_provider( + "PUT", path, headers, nullptr, 0, nullptr, + get_multipart_content_provider(boundary, items, provider_items), + content_type, nullptr); +} +inline Result ClientImpl::Patch(const std::string &path) { + return Patch(path, std::string(), std::string()); +} + +inline Result ClientImpl::Patch(const std::string &path, const char *body, + size_t content_length, + const std::string &content_type) { + return Patch(path, Headers(), body, content_length, content_type); +} + +inline Result ClientImpl::Patch(const std::string &path, const char *body, + size_t content_length, + const std::string &content_type, + Progress progress) { + return Patch(path, Headers(), body, content_length, content_type, progress); +} + +inline Result ClientImpl::Patch(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type) { + return Patch(path, headers, body, content_length, content_type, nullptr); +} + +inline Result ClientImpl::Patch(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type, + Progress progress) { + return send_with_content_provider("PATCH", path, headers, body, + content_length, nullptr, nullptr, + content_type, progress); +} + +inline Result ClientImpl::Patch(const std::string &path, + const std::string &body, + const std::string &content_type) { + return Patch(path, Headers(), body, content_type); +} + +inline Result ClientImpl::Patch(const std::string &path, + const std::string &body, + const std::string &content_type, + Progress progress) { + return Patch(path, Headers(), body, content_type, progress); +} + +inline Result ClientImpl::Patch(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type) { + return Patch(path, headers, body, content_type, nullptr); +} + +inline Result ClientImpl::Patch(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type, + Progress progress) { + return send_with_content_provider("PATCH", path, headers, body.data(), + body.size(), nullptr, nullptr, content_type, + progress); +} + +inline Result ClientImpl::Patch(const std::string &path, size_t content_length, + ContentProvider content_provider, + const std::string &content_type) { + return Patch(path, Headers(), content_length, std::move(content_provider), + content_type); +} + +inline Result ClientImpl::Patch(const std::string &path, + ContentProviderWithoutLength content_provider, + const std::string &content_type) { + return Patch(path, Headers(), std::move(content_provider), content_type); +} + +inline Result ClientImpl::Patch(const std::string &path, const Headers &headers, + size_t content_length, + ContentProvider content_provider, + const std::string &content_type) { + return send_with_content_provider("PATCH", path, headers, nullptr, + content_length, std::move(content_provider), + nullptr, content_type, nullptr); +} + +inline Result ClientImpl::Patch(const std::string &path, const Headers &headers, + ContentProviderWithoutLength content_provider, + const std::string &content_type) { + return send_with_content_provider("PATCH", path, headers, nullptr, 0, nullptr, + std::move(content_provider), content_type, + nullptr); +} + +inline Result ClientImpl::Delete(const std::string &path) { + return Delete(path, Headers(), std::string(), std::string()); +} + +inline Result ClientImpl::Delete(const std::string &path, + const Headers &headers) { + return Delete(path, headers, std::string(), std::string()); +} + +inline Result ClientImpl::Delete(const std::string &path, const char *body, + size_t content_length, + const std::string &content_type) { + return Delete(path, Headers(), body, content_length, content_type); +} + +inline Result ClientImpl::Delete(const std::string &path, const char *body, + size_t content_length, + const std::string &content_type, + Progress progress) { + return Delete(path, Headers(), body, content_length, content_type, progress); +} + +inline Result ClientImpl::Delete(const std::string &path, + const Headers &headers, const char *body, + size_t content_length, + const std::string &content_type) { + return Delete(path, headers, body, content_length, content_type, nullptr); +} + +inline Result ClientImpl::Delete(const std::string &path, + const Headers &headers, const char *body, + size_t content_length, + const std::string &content_type, + Progress progress) { + Request req; + req.method = "DELETE"; + req.headers = headers; + req.path = path; + req.progress = progress; + + if (!content_type.empty()) { req.set_header("Content-Type", content_type); } + req.body.assign(body, content_length); + + return send_(std::move(req)); +} + +inline Result ClientImpl::Delete(const std::string &path, + const std::string &body, + const std::string &content_type) { + return Delete(path, Headers(), body.data(), body.size(), content_type); +} + +inline Result ClientImpl::Delete(const std::string &path, + const std::string &body, + const std::string &content_type, + Progress progress) { + return Delete(path, Headers(), body.data(), body.size(), content_type, + progress); +} + +inline Result ClientImpl::Delete(const std::string &path, + const Headers &headers, + const std::string &body, + const std::string &content_type) { + return Delete(path, headers, body.data(), body.size(), content_type); +} + +inline Result ClientImpl::Delete(const std::string &path, + const Headers &headers, + const std::string &body, + const std::string &content_type, + Progress progress) { + return Delete(path, headers, body.data(), body.size(), content_type, + progress); +} + +inline Result ClientImpl::Options(const std::string &path) { + return Options(path, Headers()); +} + +inline Result ClientImpl::Options(const std::string &path, + const Headers &headers) { + Request req; + req.method = "OPTIONS"; + req.headers = headers; + req.path = path; + + return send_(std::move(req)); +} + +inline void ClientImpl::stop() { + std::lock_guard guard(socket_mutex_); + + // If there is anything ongoing right now, the ONLY thread-safe thing we can + // do is to shutdown_socket, so that threads using this socket suddenly + // discover they can't read/write any more and error out. Everything else + // (closing the socket, shutting ssl down) is unsafe because these actions are + // not thread-safe. + if (socket_requests_in_flight_ > 0) { + shutdown_socket(socket_); + + // Aside from that, we set a flag for the socket to be closed when we're + // done. + socket_should_be_closed_when_request_is_done_ = true; + return; + } + + // Otherwise, still holding the mutex, we can shut everything down ourselves + shutdown_ssl(socket_, true); + shutdown_socket(socket_); + close_socket(socket_); +} + +inline std::string ClientImpl::host() const { return host_; } + +inline int ClientImpl::port() const { return port_; } + +inline size_t ClientImpl::is_socket_open() const { + std::lock_guard guard(socket_mutex_); + return socket_.is_open(); +} + +inline socket_t ClientImpl::socket() const { return socket_.sock; } + +inline void ClientImpl::set_connection_timeout(time_t sec, time_t usec) { + connection_timeout_sec_ = sec; + connection_timeout_usec_ = usec; +} + +inline void ClientImpl::set_read_timeout(time_t sec, time_t usec) { + read_timeout_sec_ = sec; + read_timeout_usec_ = usec; +} + +inline void ClientImpl::set_write_timeout(time_t sec, time_t usec) { + write_timeout_sec_ = sec; + write_timeout_usec_ = usec; +} + +inline void ClientImpl::set_basic_auth(const std::string &username, + const std::string &password) { + basic_auth_username_ = username; + basic_auth_password_ = password; +} + +inline void ClientImpl::set_bearer_token_auth(const std::string &token) { + bearer_token_auth_token_ = token; +} + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +inline void ClientImpl::set_digest_auth(const std::string &username, + const std::string &password) { + digest_auth_username_ = username; + digest_auth_password_ = password; +} +#endif + +inline void ClientImpl::set_keep_alive(bool on) { keep_alive_ = on; } + +inline void ClientImpl::set_follow_location(bool on) { follow_location_ = on; } + +inline void ClientImpl::set_url_encode(bool on) { url_encode_ = on; } + +inline void +ClientImpl::set_hostname_addr_map(std::map addr_map) { + addr_map_ = std::move(addr_map); +} + +inline void ClientImpl::set_default_headers(Headers headers) { + default_headers_ = std::move(headers); +} + +inline void ClientImpl::set_header_writer( + std::function const &writer) { + header_writer_ = writer; +} + +inline void ClientImpl::set_address_family(int family) { + address_family_ = family; +} + +inline void ClientImpl::set_tcp_nodelay(bool on) { tcp_nodelay_ = on; } + +inline void ClientImpl::set_ipv6_v6only(bool on) { ipv6_v6only_ = on; } + +inline void ClientImpl::set_socket_options(SocketOptions socket_options) { + socket_options_ = std::move(socket_options); +} + +inline void ClientImpl::set_compress(bool on) { compress_ = on; } + +inline void ClientImpl::set_decompress(bool on) { decompress_ = on; } + +inline void ClientImpl::set_interface(const std::string &intf) { + interface_ = intf; +} + +inline void ClientImpl::set_proxy(const std::string &host, int port) { + proxy_host_ = host; + proxy_port_ = port; +} + +inline void ClientImpl::set_proxy_basic_auth(const std::string &username, + const std::string &password) { + proxy_basic_auth_username_ = username; + proxy_basic_auth_password_ = password; +} + +inline void ClientImpl::set_proxy_bearer_token_auth(const std::string &token) { + proxy_bearer_token_auth_token_ = token; +} + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +inline void ClientImpl::set_proxy_digest_auth(const std::string &username, + const std::string &password) { + proxy_digest_auth_username_ = username; + proxy_digest_auth_password_ = password; +} + +inline void ClientImpl::set_ca_cert_path(const std::string &ca_cert_file_path, + const std::string &ca_cert_dir_path) { + ca_cert_file_path_ = ca_cert_file_path; + ca_cert_dir_path_ = ca_cert_dir_path; +} + +inline void ClientImpl::set_ca_cert_store(X509_STORE *ca_cert_store) { + if (ca_cert_store && ca_cert_store != ca_cert_store_) { + ca_cert_store_ = ca_cert_store; + } +} + +inline X509_STORE *ClientImpl::create_ca_cert_store(const char *ca_cert, + std::size_t size) const { + auto mem = BIO_new_mem_buf(ca_cert, static_cast(size)); + auto se = detail::scope_exit([&] { BIO_free_all(mem); }); + if (!mem) { return nullptr; } + + auto inf = PEM_X509_INFO_read_bio(mem, nullptr, nullptr, nullptr); + if (!inf) { return nullptr; } + + auto cts = X509_STORE_new(); + if (cts) { + for (auto i = 0; i < static_cast(sk_X509_INFO_num(inf)); i++) { + auto itmp = sk_X509_INFO_value(inf, i); + if (!itmp) { continue; } + + if (itmp->x509) { X509_STORE_add_cert(cts, itmp->x509); } + if (itmp->crl) { X509_STORE_add_crl(cts, itmp->crl); } + } + } + + sk_X509_INFO_pop_free(inf, X509_INFO_free); + return cts; +} + +inline void ClientImpl::enable_server_certificate_verification(bool enabled) { + server_certificate_verification_ = enabled; +} + +inline void ClientImpl::enable_server_hostname_verification(bool enabled) { + server_hostname_verification_ = enabled; +} + +inline void ClientImpl::set_server_certificate_verifier( + std::function verifier) { + server_certificate_verifier_ = verifier; +} +#endif + +inline void ClientImpl::set_logger(Logger logger) { + logger_ = std::move(logger); +} + +/* + * SSL Implementation + */ +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +namespace detail { + +template +inline SSL *ssl_new(socket_t sock, SSL_CTX *ctx, std::mutex &ctx_mutex, + U SSL_connect_or_accept, V setup) { + SSL *ssl = nullptr; + { + std::lock_guard guard(ctx_mutex); + ssl = SSL_new(ctx); + } + + if (ssl) { + set_nonblocking(sock, true); + auto bio = BIO_new_socket(static_cast(sock), BIO_NOCLOSE); + BIO_set_nbio(bio, 1); + SSL_set_bio(ssl, bio, bio); + + if (!setup(ssl) || SSL_connect_or_accept(ssl) != 1) { + SSL_shutdown(ssl); + { + std::lock_guard guard(ctx_mutex); + SSL_free(ssl); + } + set_nonblocking(sock, false); + return nullptr; + } + BIO_set_nbio(bio, 0); + set_nonblocking(sock, false); + } + + return ssl; +} + +inline void ssl_delete(std::mutex &ctx_mutex, SSL *ssl, socket_t sock, + bool shutdown_gracefully) { + // sometimes we may want to skip this to try to avoid SIGPIPE if we know + // the remote has closed the network connection + // Note that it is not always possible to avoid SIGPIPE, this is merely a + // best-efforts. + if (shutdown_gracefully) { +#ifdef _WIN32 + SSL_shutdown(ssl); +#else + timeval tv; + tv.tv_sec = 1; + tv.tv_usec = 0; + setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, + reinterpret_cast(&tv), sizeof(tv)); + + auto ret = SSL_shutdown(ssl); + while (ret == 0) { + std::this_thread::sleep_for(std::chrono::milliseconds{100}); + ret = SSL_shutdown(ssl); + } +#endif + } + + std::lock_guard guard(ctx_mutex); + SSL_free(ssl); +} + +template +bool ssl_connect_or_accept_nonblocking(socket_t sock, SSL *ssl, + U ssl_connect_or_accept, + time_t timeout_sec, + time_t timeout_usec) { + auto res = 0; + while ((res = ssl_connect_or_accept(ssl)) != 1) { + auto err = SSL_get_error(ssl, res); + switch (err) { + case SSL_ERROR_WANT_READ: + if (select_read(sock, timeout_sec, timeout_usec) > 0) { continue; } + break; + case SSL_ERROR_WANT_WRITE: + if (select_write(sock, timeout_sec, timeout_usec) > 0) { continue; } + break; + default: break; + } + return false; + } + return true; +} + +template +inline bool process_server_socket_ssl( + const std::atomic &svr_sock, SSL *ssl, socket_t sock, + size_t keep_alive_max_count, time_t keep_alive_timeout_sec, + time_t read_timeout_sec, time_t read_timeout_usec, time_t write_timeout_sec, + time_t write_timeout_usec, T callback) { + return process_server_socket_core( + svr_sock, sock, keep_alive_max_count, keep_alive_timeout_sec, + [&](bool close_connection, bool &connection_closed) { + SSLSocketStream strm(sock, ssl, read_timeout_sec, read_timeout_usec, + write_timeout_sec, write_timeout_usec); + return callback(strm, close_connection, connection_closed); + }); +} + +template +inline bool +process_client_socket_ssl(SSL *ssl, socket_t sock, time_t read_timeout_sec, + time_t read_timeout_usec, time_t write_timeout_sec, + time_t write_timeout_usec, T callback) { + SSLSocketStream strm(sock, ssl, read_timeout_sec, read_timeout_usec, + write_timeout_sec, write_timeout_usec); + return callback(strm); +} + +class SSLInit { +public: + SSLInit() { + OPENSSL_init_ssl( + OPENSSL_INIT_LOAD_SSL_STRINGS | OPENSSL_INIT_LOAD_CRYPTO_STRINGS, NULL); + } +}; + +// SSL socket stream implementation +inline SSLSocketStream::SSLSocketStream(socket_t sock, SSL *ssl, + time_t read_timeout_sec, + time_t read_timeout_usec, + time_t write_timeout_sec, + time_t write_timeout_usec) + : sock_(sock), ssl_(ssl), read_timeout_sec_(read_timeout_sec), + read_timeout_usec_(read_timeout_usec), + write_timeout_sec_(write_timeout_sec), + write_timeout_usec_(write_timeout_usec) { + SSL_clear_mode(ssl, SSL_MODE_AUTO_RETRY); +} + +inline SSLSocketStream::~SSLSocketStream() = default; + +inline bool SSLSocketStream::is_readable() const { + return detail::select_read(sock_, read_timeout_sec_, read_timeout_usec_) > 0; +} + +inline bool SSLSocketStream::is_writable() const { + return select_write(sock_, write_timeout_sec_, write_timeout_usec_) > 0 && + is_socket_alive(sock_); +} + +inline ssize_t SSLSocketStream::read(char *ptr, size_t size) { + if (SSL_pending(ssl_) > 0) { + return SSL_read(ssl_, ptr, static_cast(size)); + } else if (is_readable()) { + auto ret = SSL_read(ssl_, ptr, static_cast(size)); + if (ret < 0) { + auto err = SSL_get_error(ssl_, ret); + auto n = 1000; +#ifdef _WIN32 + while (--n >= 0 && (err == SSL_ERROR_WANT_READ || + (err == SSL_ERROR_SYSCALL && + WSAGetLastError() == WSAETIMEDOUT))) { +#else + while (--n >= 0 && err == SSL_ERROR_WANT_READ) { +#endif + if (SSL_pending(ssl_) > 0) { + return SSL_read(ssl_, ptr, static_cast(size)); + } else if (is_readable()) { + std::this_thread::sleep_for(std::chrono::microseconds{10}); + ret = SSL_read(ssl_, ptr, static_cast(size)); + if (ret >= 0) { return ret; } + err = SSL_get_error(ssl_, ret); + } else { + return -1; + } + } + } + return ret; + } + return -1; +} + +inline ssize_t SSLSocketStream::write(const char *ptr, size_t size) { + if (is_writable()) { + auto handle_size = static_cast( + std::min(size, (std::numeric_limits::max)())); + + auto ret = SSL_write(ssl_, ptr, static_cast(handle_size)); + if (ret < 0) { + auto err = SSL_get_error(ssl_, ret); + auto n = 1000; +#ifdef _WIN32 + while (--n >= 0 && (err == SSL_ERROR_WANT_WRITE || + (err == SSL_ERROR_SYSCALL && + WSAGetLastError() == WSAETIMEDOUT))) { +#else + while (--n >= 0 && err == SSL_ERROR_WANT_WRITE) { +#endif + if (is_writable()) { + std::this_thread::sleep_for(std::chrono::microseconds{10}); + ret = SSL_write(ssl_, ptr, static_cast(handle_size)); + if (ret >= 0) { return ret; } + err = SSL_get_error(ssl_, ret); + } else { + return -1; + } + } + } + return ret; + } + return -1; +} + +inline void SSLSocketStream::get_remote_ip_and_port(std::string &ip, + int &port) const { + detail::get_remote_ip_and_port(sock_, ip, port); +} + +inline void SSLSocketStream::get_local_ip_and_port(std::string &ip, + int &port) const { + detail::get_local_ip_and_port(sock_, ip, port); +} + +inline socket_t SSLSocketStream::socket() const { return sock_; } + +static SSLInit sslinit_; + +} // namespace detail + +// SSL HTTP server implementation +inline SSLServer::SSLServer(const char *cert_path, const char *private_key_path, + const char *client_ca_cert_file_path, + const char *client_ca_cert_dir_path, + const char *private_key_password) { + ctx_ = SSL_CTX_new(TLS_server_method()); + + if (ctx_) { + SSL_CTX_set_options(ctx_, + SSL_OP_NO_COMPRESSION | + SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION); + + SSL_CTX_set_min_proto_version(ctx_, TLS1_2_VERSION); + + if (private_key_password != nullptr && (private_key_password[0] != '\0')) { + SSL_CTX_set_default_passwd_cb_userdata( + ctx_, + reinterpret_cast(const_cast(private_key_password))); + } + + if (SSL_CTX_use_certificate_chain_file(ctx_, cert_path) != 1 || + SSL_CTX_use_PrivateKey_file(ctx_, private_key_path, SSL_FILETYPE_PEM) != + 1 || + SSL_CTX_check_private_key(ctx_) != 1) { + SSL_CTX_free(ctx_); + ctx_ = nullptr; + } else if (client_ca_cert_file_path || client_ca_cert_dir_path) { + SSL_CTX_load_verify_locations(ctx_, client_ca_cert_file_path, + client_ca_cert_dir_path); + + SSL_CTX_set_verify( + ctx_, SSL_VERIFY_PEER | SSL_VERIFY_FAIL_IF_NO_PEER_CERT, nullptr); + } + } +} + +inline SSLServer::SSLServer(X509 *cert, EVP_PKEY *private_key, + X509_STORE *client_ca_cert_store) { + ctx_ = SSL_CTX_new(TLS_server_method()); + + if (ctx_) { + SSL_CTX_set_options(ctx_, + SSL_OP_NO_COMPRESSION | + SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION); + + SSL_CTX_set_min_proto_version(ctx_, TLS1_2_VERSION); + + if (SSL_CTX_use_certificate(ctx_, cert) != 1 || + SSL_CTX_use_PrivateKey(ctx_, private_key) != 1) { + SSL_CTX_free(ctx_); + ctx_ = nullptr; + } else if (client_ca_cert_store) { + SSL_CTX_set_cert_store(ctx_, client_ca_cert_store); + + SSL_CTX_set_verify( + ctx_, SSL_VERIFY_PEER | SSL_VERIFY_FAIL_IF_NO_PEER_CERT, nullptr); + } + } +} + +inline SSLServer::SSLServer( + const std::function &setup_ssl_ctx_callback) { + ctx_ = SSL_CTX_new(TLS_method()); + if (ctx_) { + if (!setup_ssl_ctx_callback(*ctx_)) { + SSL_CTX_free(ctx_); + ctx_ = nullptr; + } + } +} + +inline SSLServer::~SSLServer() { + if (ctx_) { SSL_CTX_free(ctx_); } +} + +inline bool SSLServer::is_valid() const { return ctx_; } + +inline SSL_CTX *SSLServer::ssl_context() const { return ctx_; } + +inline void SSLServer::update_certs(X509 *cert, EVP_PKEY *private_key, + X509_STORE *client_ca_cert_store) { + + std::lock_guard guard(ctx_mutex_); + + SSL_CTX_use_certificate(ctx_, cert); + SSL_CTX_use_PrivateKey(ctx_, private_key); + + if (client_ca_cert_store != nullptr) { + SSL_CTX_set_cert_store(ctx_, client_ca_cert_store); + } +} + +inline bool SSLServer::process_and_close_socket(socket_t sock) { + auto ssl = detail::ssl_new( + sock, ctx_, ctx_mutex_, + [&](SSL *ssl2) { + return detail::ssl_connect_or_accept_nonblocking( + sock, ssl2, SSL_accept, read_timeout_sec_, read_timeout_usec_); + }, + [](SSL * /*ssl2*/) { return true; }); + + auto ret = false; + if (ssl) { + std::string remote_addr; + int remote_port = 0; + detail::get_remote_ip_and_port(sock, remote_addr, remote_port); + + std::string local_addr; + int local_port = 0; + detail::get_local_ip_and_port(sock, local_addr, local_port); + + ret = detail::process_server_socket_ssl( + svr_sock_, ssl, sock, keep_alive_max_count_, keep_alive_timeout_sec_, + read_timeout_sec_, read_timeout_usec_, write_timeout_sec_, + write_timeout_usec_, + [&](Stream &strm, bool close_connection, bool &connection_closed) { + return process_request(strm, remote_addr, remote_port, local_addr, + local_port, close_connection, + connection_closed, + [&](Request &req) { req.ssl = ssl; }); + }); + + // Shutdown gracefully if the result seemed successful, non-gracefully if + // the connection appeared to be closed. + const bool shutdown_gracefully = ret; + detail::ssl_delete(ctx_mutex_, ssl, sock, shutdown_gracefully); + } + + detail::shutdown_socket(sock); + detail::close_socket(sock); + return ret; +} + +// SSL HTTP client implementation +inline SSLClient::SSLClient(const std::string &host) + : SSLClient(host, 443, std::string(), std::string()) {} + +inline SSLClient::SSLClient(const std::string &host, int port) + : SSLClient(host, port, std::string(), std::string()) {} + +inline SSLClient::SSLClient(const std::string &host, int port, + const std::string &client_cert_path, + const std::string &client_key_path, + const std::string &private_key_password) + : ClientImpl(host, port, client_cert_path, client_key_path) { + ctx_ = SSL_CTX_new(TLS_client_method()); + + SSL_CTX_set_min_proto_version(ctx_, TLS1_2_VERSION); + + detail::split(&host_[0], &host_[host_.size()], '.', + [&](const char *b, const char *e) { + host_components_.emplace_back(b, e); + }); + + if (!client_cert_path.empty() && !client_key_path.empty()) { + if (!private_key_password.empty()) { + SSL_CTX_set_default_passwd_cb_userdata( + ctx_, reinterpret_cast( + const_cast(private_key_password.c_str()))); + } + + if (SSL_CTX_use_certificate_file(ctx_, client_cert_path.c_str(), + SSL_FILETYPE_PEM) != 1 || + SSL_CTX_use_PrivateKey_file(ctx_, client_key_path.c_str(), + SSL_FILETYPE_PEM) != 1) { + SSL_CTX_free(ctx_); + ctx_ = nullptr; + } + } +} + +inline SSLClient::SSLClient(const std::string &host, int port, + X509 *client_cert, EVP_PKEY *client_key, + const std::string &private_key_password) + : ClientImpl(host, port) { + ctx_ = SSL_CTX_new(TLS_client_method()); + + detail::split(&host_[0], &host_[host_.size()], '.', + [&](const char *b, const char *e) { + host_components_.emplace_back(b, e); + }); + + if (client_cert != nullptr && client_key != nullptr) { + if (!private_key_password.empty()) { + SSL_CTX_set_default_passwd_cb_userdata( + ctx_, reinterpret_cast( + const_cast(private_key_password.c_str()))); + } + + if (SSL_CTX_use_certificate(ctx_, client_cert) != 1 || + SSL_CTX_use_PrivateKey(ctx_, client_key) != 1) { + SSL_CTX_free(ctx_); + ctx_ = nullptr; + } + } +} + +inline SSLClient::~SSLClient() { + if (ctx_) { SSL_CTX_free(ctx_); } + // Make sure to shut down SSL since shutdown_ssl will resolve to the + // base function rather than the derived function once we get to the + // base class destructor, and won't free the SSL (causing a leak). + shutdown_ssl_impl(socket_, true); +} + +inline bool SSLClient::is_valid() const { return ctx_; } + +inline void SSLClient::set_ca_cert_store(X509_STORE *ca_cert_store) { + if (ca_cert_store) { + if (ctx_) { + if (SSL_CTX_get_cert_store(ctx_) != ca_cert_store) { + // Free memory allocated for old cert and use new store `ca_cert_store` + SSL_CTX_set_cert_store(ctx_, ca_cert_store); + } + } else { + X509_STORE_free(ca_cert_store); + } + } +} + +inline void SSLClient::load_ca_cert_store(const char *ca_cert, + std::size_t size) { + set_ca_cert_store(ClientImpl::create_ca_cert_store(ca_cert, size)); +} + +inline long SSLClient::get_openssl_verify_result() const { + return verify_result_; +} + +inline SSL_CTX *SSLClient::ssl_context() const { return ctx_; } + +inline bool SSLClient::create_and_connect_socket(Socket &socket, Error &error) { + return is_valid() && ClientImpl::create_and_connect_socket(socket, error); +} + +// Assumes that socket_mutex_ is locked and that there are no requests in flight +inline bool SSLClient::connect_with_proxy(Socket &socket, Response &res, + bool &success, Error &error) { + success = true; + Response proxy_res; + if (!detail::process_client_socket( + socket.sock, read_timeout_sec_, read_timeout_usec_, + write_timeout_sec_, write_timeout_usec_, [&](Stream &strm) { + Request req2; + req2.method = "CONNECT"; + req2.path = host_and_port_; + return process_request(strm, req2, proxy_res, false, error); + })) { + // Thread-safe to close everything because we are assuming there are no + // requests in flight + shutdown_ssl(socket, true); + shutdown_socket(socket); + close_socket(socket); + success = false; + return false; + } + + if (proxy_res.status == StatusCode::ProxyAuthenticationRequired_407) { + if (!proxy_digest_auth_username_.empty() && + !proxy_digest_auth_password_.empty()) { + std::map auth; + if (detail::parse_www_authenticate(proxy_res, auth, true)) { + proxy_res = Response(); + if (!detail::process_client_socket( + socket.sock, read_timeout_sec_, read_timeout_usec_, + write_timeout_sec_, write_timeout_usec_, [&](Stream &strm) { + Request req3; + req3.method = "CONNECT"; + req3.path = host_and_port_; + req3.headers.insert(detail::make_digest_authentication_header( + req3, auth, 1, detail::random_string(10), + proxy_digest_auth_username_, proxy_digest_auth_password_, + true)); + return process_request(strm, req3, proxy_res, false, error); + })) { + // Thread-safe to close everything because we are assuming there are + // no requests in flight + shutdown_ssl(socket, true); + shutdown_socket(socket); + close_socket(socket); + success = false; + return false; + } + } + } + } + + // If status code is not 200, proxy request is failed. + // Set error to ProxyConnection and return proxy response + // as the response of the request + if (proxy_res.status != StatusCode::OK_200) { + error = Error::ProxyConnection; + res = std::move(proxy_res); + // Thread-safe to close everything because we are assuming there are + // no requests in flight + shutdown_ssl(socket, true); + shutdown_socket(socket); + close_socket(socket); + return false; + } + + return true; +} + +inline bool SSLClient::load_certs() { + auto ret = true; + + std::call_once(initialize_cert_, [&]() { + std::lock_guard guard(ctx_mutex_); + if (!ca_cert_file_path_.empty()) { + if (!SSL_CTX_load_verify_locations(ctx_, ca_cert_file_path_.c_str(), + nullptr)) { + ret = false; + } + } else if (!ca_cert_dir_path_.empty()) { + if (!SSL_CTX_load_verify_locations(ctx_, nullptr, + ca_cert_dir_path_.c_str())) { + ret = false; + } + } else { + auto loaded = false; +#ifdef _WIN32 + loaded = + detail::load_system_certs_on_windows(SSL_CTX_get_cert_store(ctx_)); +#elif defined(CPPHTTPLIB_USE_CERTS_FROM_MACOSX_KEYCHAIN) && defined(__APPLE__) +#if TARGET_OS_OSX + loaded = detail::load_system_certs_on_macos(SSL_CTX_get_cert_store(ctx_)); +#endif // TARGET_OS_OSX +#endif // _WIN32 + if (!loaded) { SSL_CTX_set_default_verify_paths(ctx_); } + } + }); + + return ret; +} + +inline bool SSLClient::initialize_ssl(Socket &socket, Error &error) { + auto ssl = detail::ssl_new( + socket.sock, ctx_, ctx_mutex_, + [&](SSL *ssl2) { + if (server_certificate_verification_) { + if (!load_certs()) { + error = Error::SSLLoadingCerts; + return false; + } + SSL_set_verify(ssl2, SSL_VERIFY_NONE, nullptr); + } + + if (!detail::ssl_connect_or_accept_nonblocking( + socket.sock, ssl2, SSL_connect, connection_timeout_sec_, + connection_timeout_usec_)) { + error = Error::SSLConnection; + return false; + } + + if (server_certificate_verification_) { + if (server_certificate_verifier_) { + if (!server_certificate_verifier_(ssl2)) { + error = Error::SSLServerVerification; + return false; + } + } else { + verify_result_ = SSL_get_verify_result(ssl2); + + if (verify_result_ != X509_V_OK) { + error = Error::SSLServerVerification; + return false; + } + + auto server_cert = SSL_get1_peer_certificate(ssl2); + auto se = detail::scope_exit([&] { X509_free(server_cert); }); + + if (server_cert == nullptr) { + error = Error::SSLServerVerification; + return false; + } + + if (server_hostname_verification_) { + if (!verify_host(server_cert)) { + error = Error::SSLServerHostnameVerification; + return false; + } + } + } + } + + return true; + }, + [&](SSL *ssl2) { +#if defined(OPENSSL_IS_BORINGSSL) + SSL_set_tlsext_host_name(ssl2, host_.c_str()); +#else + // NOTE: Direct call instead of using the OpenSSL macro to suppress + // -Wold-style-cast warning + SSL_ctrl(ssl2, SSL_CTRL_SET_TLSEXT_HOSTNAME, TLSEXT_NAMETYPE_host_name, + static_cast(const_cast(host_.c_str()))); +#endif + return true; + }); + + if (ssl) { + socket.ssl = ssl; + return true; + } + + shutdown_socket(socket); + close_socket(socket); + return false; +} + +inline void SSLClient::shutdown_ssl(Socket &socket, bool shutdown_gracefully) { + shutdown_ssl_impl(socket, shutdown_gracefully); +} + +inline void SSLClient::shutdown_ssl_impl(Socket &socket, + bool shutdown_gracefully) { + if (socket.sock == INVALID_SOCKET) { + assert(socket.ssl == nullptr); + return; + } + if (socket.ssl) { + detail::ssl_delete(ctx_mutex_, socket.ssl, socket.sock, + shutdown_gracefully); + socket.ssl = nullptr; + } + assert(socket.ssl == nullptr); +} + +inline bool +SSLClient::process_socket(const Socket &socket, + std::function callback) { + assert(socket.ssl); + return detail::process_client_socket_ssl( + socket.ssl, socket.sock, read_timeout_sec_, read_timeout_usec_, + write_timeout_sec_, write_timeout_usec_, std::move(callback)); +} + +inline bool SSLClient::is_ssl() const { return true; } + +inline bool SSLClient::verify_host(X509 *server_cert) const { + /* Quote from RFC2818 section 3.1 "Server Identity" + + If a subjectAltName extension of type dNSName is present, that MUST + be used as the identity. Otherwise, the (most specific) Common Name + field in the Subject field of the certificate MUST be used. Although + the use of the Common Name is existing practice, it is deprecated and + Certification Authorities are encouraged to use the dNSName instead. + + Matching is performed using the matching rules specified by + [RFC2459]. If more than one identity of a given type is present in + the certificate (e.g., more than one dNSName name, a match in any one + of the set is considered acceptable.) Names may contain the wildcard + character * which is considered to match any single domain name + component or component fragment. E.g., *.a.com matches foo.a.com but + not bar.foo.a.com. f*.com matches foo.com but not bar.com. + + In some cases, the URI is specified as an IP address rather than a + hostname. In this case, the iPAddress subjectAltName must be present + in the certificate and must exactly match the IP in the URI. + + */ + return verify_host_with_subject_alt_name(server_cert) || + verify_host_with_common_name(server_cert); +} + +inline bool +SSLClient::verify_host_with_subject_alt_name(X509 *server_cert) const { + auto ret = false; + + auto type = GEN_DNS; + + struct in6_addr addr6 {}; + struct in_addr addr {}; + size_t addr_len = 0; + +#ifndef __MINGW32__ + if (inet_pton(AF_INET6, host_.c_str(), &addr6)) { + type = GEN_IPADD; + addr_len = sizeof(struct in6_addr); + } else if (inet_pton(AF_INET, host_.c_str(), &addr)) { + type = GEN_IPADD; + addr_len = sizeof(struct in_addr); + } +#endif + + auto alt_names = static_cast( + X509_get_ext_d2i(server_cert, NID_subject_alt_name, nullptr, nullptr)); + + if (alt_names) { + auto dsn_matched = false; + auto ip_matched = false; + + auto count = sk_GENERAL_NAME_num(alt_names); + + for (decltype(count) i = 0; i < count && !dsn_matched; i++) { + auto val = sk_GENERAL_NAME_value(alt_names, i); + if (val->type == type) { + auto name = + reinterpret_cast(ASN1_STRING_get0_data(val->d.ia5)); + auto name_len = static_cast(ASN1_STRING_length(val->d.ia5)); + + switch (type) { + case GEN_DNS: dsn_matched = check_host_name(name, name_len); break; + + case GEN_IPADD: + if (!memcmp(&addr6, name, addr_len) || + !memcmp(&addr, name, addr_len)) { + ip_matched = true; + } + break; + } + } + } + + if (dsn_matched || ip_matched) { ret = true; } + } + + GENERAL_NAMES_free(const_cast( + reinterpret_cast(alt_names))); + return ret; +} + +inline bool SSLClient::verify_host_with_common_name(X509 *server_cert) const { + const auto subject_name = X509_get_subject_name(server_cert); + + if (subject_name != nullptr) { + char name[BUFSIZ]; + auto name_len = X509_NAME_get_text_by_NID(subject_name, NID_commonName, + name, sizeof(name)); + + if (name_len != -1) { + return check_host_name(name, static_cast(name_len)); + } + } + + return false; +} + +inline bool SSLClient::check_host_name(const char *pattern, + size_t pattern_len) const { + if (host_.size() == pattern_len && host_ == pattern) { return true; } + + // Wildcard match + // https://bugs.launchpad.net/ubuntu/+source/firefox-3.0/+bug/376484 + std::vector pattern_components; + detail::split(&pattern[0], &pattern[pattern_len], '.', + [&](const char *b, const char *e) { + pattern_components.emplace_back(b, e); + }); + + if (host_components_.size() != pattern_components.size()) { return false; } + + auto itr = pattern_components.begin(); + for (const auto &h : host_components_) { + auto &p = *itr; + if (p != h && p != "*") { + auto partial_match = (p.size() > 0 && p[p.size() - 1] == '*' && + !p.compare(0, p.size() - 1, h)); + if (!partial_match) { return false; } + } + ++itr; + } + + return true; +} +#endif + +// Universal client implementation +inline Client::Client(const std::string &scheme_host_port) + : Client(scheme_host_port, std::string(), std::string()) {} + +inline Client::Client(const std::string &scheme_host_port, + const std::string &client_cert_path, + const std::string &client_key_path) { + const static std::regex re( + R"((?:([a-z]+):\/\/)?(?:\[([a-fA-F\d:]+)\]|([^:/?#]+))(?::(\d+))?)"); + + std::smatch m; + if (std::regex_match(scheme_host_port, m, re)) { + auto scheme = m[1].str(); + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + if (!scheme.empty() && (scheme != "http" && scheme != "https")) { +#else + if (!scheme.empty() && scheme != "http") { +#endif +#ifndef CPPHTTPLIB_NO_EXCEPTIONS + std::string msg = "'" + scheme + "' scheme is not supported."; + throw std::invalid_argument(msg); +#endif + return; + } + + auto is_ssl = scheme == "https"; + + auto host = m[2].str(); + if (host.empty()) { host = m[3].str(); } + + auto port_str = m[4].str(); + auto port = !port_str.empty() ? std::stoi(port_str) : (is_ssl ? 443 : 80); + + if (is_ssl) { +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT + cli_ = detail::make_unique(host, port, client_cert_path, + client_key_path); + is_ssl_ = is_ssl; +#endif + } else { + cli_ = detail::make_unique(host, port, client_cert_path, + client_key_path); + } + } else { + // NOTE: Update TEST(UniversalClientImplTest, Ipv6LiteralAddress) + // if port param below changes. + cli_ = detail::make_unique(scheme_host_port, 80, + client_cert_path, client_key_path); + } +} // namespace detail + +inline Client::Client(const std::string &host, int port) + : cli_(detail::make_unique(host, port)) {} + +inline Client::Client(const std::string &host, int port, + const std::string &client_cert_path, + const std::string &client_key_path) + : cli_(detail::make_unique(host, port, client_cert_path, + client_key_path)) {} + +inline Client::~Client() = default; + +inline bool Client::is_valid() const { + return cli_ != nullptr && cli_->is_valid(); +} + +inline Result Client::Get(const std::string &path) { return cli_->Get(path); } +inline Result Client::Get(const std::string &path, const Headers &headers) { + return cli_->Get(path, headers); +} +inline Result Client::Get(const std::string &path, Progress progress) { + return cli_->Get(path, std::move(progress)); +} +inline Result Client::Get(const std::string &path, const Headers &headers, + Progress progress) { + return cli_->Get(path, headers, std::move(progress)); +} +inline Result Client::Get(const std::string &path, + ContentReceiver content_receiver) { + return cli_->Get(path, std::move(content_receiver)); +} +inline Result Client::Get(const std::string &path, const Headers &headers, + ContentReceiver content_receiver) { + return cli_->Get(path, headers, std::move(content_receiver)); +} +inline Result Client::Get(const std::string &path, + ContentReceiver content_receiver, Progress progress) { + return cli_->Get(path, std::move(content_receiver), std::move(progress)); +} +inline Result Client::Get(const std::string &path, const Headers &headers, + ContentReceiver content_receiver, Progress progress) { + return cli_->Get(path, headers, std::move(content_receiver), + std::move(progress)); +} +inline Result Client::Get(const std::string &path, + ResponseHandler response_handler, + ContentReceiver content_receiver) { + return cli_->Get(path, std::move(response_handler), + std::move(content_receiver)); +} +inline Result Client::Get(const std::string &path, const Headers &headers, + ResponseHandler response_handler, + ContentReceiver content_receiver) { + return cli_->Get(path, headers, std::move(response_handler), + std::move(content_receiver)); +} +inline Result Client::Get(const std::string &path, + ResponseHandler response_handler, + ContentReceiver content_receiver, Progress progress) { + return cli_->Get(path, std::move(response_handler), + std::move(content_receiver), std::move(progress)); +} +inline Result Client::Get(const std::string &path, const Headers &headers, + ResponseHandler response_handler, + ContentReceiver content_receiver, Progress progress) { + return cli_->Get(path, headers, std::move(response_handler), + std::move(content_receiver), std::move(progress)); +} +inline Result Client::Get(const std::string &path, const Params ¶ms, + const Headers &headers, Progress progress) { + return cli_->Get(path, params, headers, std::move(progress)); +} +inline Result Client::Get(const std::string &path, const Params ¶ms, + const Headers &headers, + ContentReceiver content_receiver, Progress progress) { + return cli_->Get(path, params, headers, std::move(content_receiver), + std::move(progress)); +} +inline Result Client::Get(const std::string &path, const Params ¶ms, + const Headers &headers, + ResponseHandler response_handler, + ContentReceiver content_receiver, Progress progress) { + return cli_->Get(path, params, headers, std::move(response_handler), + std::move(content_receiver), std::move(progress)); +} + +inline Result Client::Head(const std::string &path) { return cli_->Head(path); } +inline Result Client::Head(const std::string &path, const Headers &headers) { + return cli_->Head(path, headers); +} + +inline Result Client::Post(const std::string &path) { return cli_->Post(path); } +inline Result Client::Post(const std::string &path, const Headers &headers) { + return cli_->Post(path, headers); +} +inline Result Client::Post(const std::string &path, const char *body, + size_t content_length, + const std::string &content_type) { + return cli_->Post(path, body, content_length, content_type); +} +inline Result Client::Post(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type) { + return cli_->Post(path, headers, body, content_length, content_type); +} +inline Result Client::Post(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type, Progress progress) { + return cli_->Post(path, headers, body, content_length, content_type, + progress); +} +inline Result Client::Post(const std::string &path, const std::string &body, + const std::string &content_type) { + return cli_->Post(path, body, content_type); +} +inline Result Client::Post(const std::string &path, const std::string &body, + const std::string &content_type, Progress progress) { + return cli_->Post(path, body, content_type, progress); +} +inline Result Client::Post(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type) { + return cli_->Post(path, headers, body, content_type); +} +inline Result Client::Post(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type, Progress progress) { + return cli_->Post(path, headers, body, content_type, progress); +} +inline Result Client::Post(const std::string &path, size_t content_length, + ContentProvider content_provider, + const std::string &content_type) { + return cli_->Post(path, content_length, std::move(content_provider), + content_type); +} +inline Result Client::Post(const std::string &path, + ContentProviderWithoutLength content_provider, + const std::string &content_type) { + return cli_->Post(path, std::move(content_provider), content_type); +} +inline Result Client::Post(const std::string &path, const Headers &headers, + size_t content_length, + ContentProvider content_provider, + const std::string &content_type) { + return cli_->Post(path, headers, content_length, std::move(content_provider), + content_type); +} +inline Result Client::Post(const std::string &path, const Headers &headers, + ContentProviderWithoutLength content_provider, + const std::string &content_type) { + return cli_->Post(path, headers, std::move(content_provider), content_type); +} +inline Result Client::Post(const std::string &path, const Params ¶ms) { + return cli_->Post(path, params); +} +inline Result Client::Post(const std::string &path, const Headers &headers, + const Params ¶ms) { + return cli_->Post(path, headers, params); +} +inline Result Client::Post(const std::string &path, const Headers &headers, + const Params ¶ms, Progress progress) { + return cli_->Post(path, headers, params, progress); +} +inline Result Client::Post(const std::string &path, + const MultipartFormDataItems &items) { + return cli_->Post(path, items); +} +inline Result Client::Post(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items) { + return cli_->Post(path, headers, items); +} +inline Result Client::Post(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const std::string &boundary) { + return cli_->Post(path, headers, items, boundary); +} +inline Result +Client::Post(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items) { + return cli_->Post(path, headers, items, provider_items); +} +inline Result Client::Put(const std::string &path) { return cli_->Put(path); } +inline Result Client::Put(const std::string &path, const char *body, + size_t content_length, + const std::string &content_type) { + return cli_->Put(path, body, content_length, content_type); +} +inline Result Client::Put(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type) { + return cli_->Put(path, headers, body, content_length, content_type); +} +inline Result Client::Put(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type, Progress progress) { + return cli_->Put(path, headers, body, content_length, content_type, progress); +} +inline Result Client::Put(const std::string &path, const std::string &body, + const std::string &content_type) { + return cli_->Put(path, body, content_type); +} +inline Result Client::Put(const std::string &path, const std::string &body, + const std::string &content_type, Progress progress) { + return cli_->Put(path, body, content_type, progress); +} +inline Result Client::Put(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type) { + return cli_->Put(path, headers, body, content_type); +} +inline Result Client::Put(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type, Progress progress) { + return cli_->Put(path, headers, body, content_type, progress); +} +inline Result Client::Put(const std::string &path, size_t content_length, + ContentProvider content_provider, + const std::string &content_type) { + return cli_->Put(path, content_length, std::move(content_provider), + content_type); +} +inline Result Client::Put(const std::string &path, + ContentProviderWithoutLength content_provider, + const std::string &content_type) { + return cli_->Put(path, std::move(content_provider), content_type); +} +inline Result Client::Put(const std::string &path, const Headers &headers, + size_t content_length, + ContentProvider content_provider, + const std::string &content_type) { + return cli_->Put(path, headers, content_length, std::move(content_provider), + content_type); +} +inline Result Client::Put(const std::string &path, const Headers &headers, + ContentProviderWithoutLength content_provider, + const std::string &content_type) { + return cli_->Put(path, headers, std::move(content_provider), content_type); +} +inline Result Client::Put(const std::string &path, const Params ¶ms) { + return cli_->Put(path, params); +} +inline Result Client::Put(const std::string &path, const Headers &headers, + const Params ¶ms) { + return cli_->Put(path, headers, params); +} +inline Result Client::Put(const std::string &path, const Headers &headers, + const Params ¶ms, Progress progress) { + return cli_->Put(path, headers, params, progress); +} +inline Result Client::Put(const std::string &path, + const MultipartFormDataItems &items) { + return cli_->Put(path, items); +} +inline Result Client::Put(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items) { + return cli_->Put(path, headers, items); +} +inline Result Client::Put(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const std::string &boundary) { + return cli_->Put(path, headers, items, boundary); +} +inline Result +Client::Put(const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items) { + return cli_->Put(path, headers, items, provider_items); +} +inline Result Client::Patch(const std::string &path) { + return cli_->Patch(path); +} +inline Result Client::Patch(const std::string &path, const char *body, + size_t content_length, + const std::string &content_type) { + return cli_->Patch(path, body, content_length, content_type); +} +inline Result Client::Patch(const std::string &path, const char *body, + size_t content_length, + const std::string &content_type, + Progress progress) { + return cli_->Patch(path, body, content_length, content_type, progress); +} +inline Result Client::Patch(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type) { + return cli_->Patch(path, headers, body, content_length, content_type); +} +inline Result Client::Patch(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type, + Progress progress) { + return cli_->Patch(path, headers, body, content_length, content_type, + progress); +} +inline Result Client::Patch(const std::string &path, const std::string &body, + const std::string &content_type) { + return cli_->Patch(path, body, content_type); +} +inline Result Client::Patch(const std::string &path, const std::string &body, + const std::string &content_type, + Progress progress) { + return cli_->Patch(path, body, content_type, progress); +} +inline Result Client::Patch(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type) { + return cli_->Patch(path, headers, body, content_type); +} +inline Result Client::Patch(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type, + Progress progress) { + return cli_->Patch(path, headers, body, content_type, progress); +} +inline Result Client::Patch(const std::string &path, size_t content_length, + ContentProvider content_provider, + const std::string &content_type) { + return cli_->Patch(path, content_length, std::move(content_provider), + content_type); +} +inline Result Client::Patch(const std::string &path, + ContentProviderWithoutLength content_provider, + const std::string &content_type) { + return cli_->Patch(path, std::move(content_provider), content_type); +} +inline Result Client::Patch(const std::string &path, const Headers &headers, + size_t content_length, + ContentProvider content_provider, + const std::string &content_type) { + return cli_->Patch(path, headers, content_length, std::move(content_provider), + content_type); +} +inline Result Client::Patch(const std::string &path, const Headers &headers, + ContentProviderWithoutLength content_provider, + const std::string &content_type) { + return cli_->Patch(path, headers, std::move(content_provider), content_type); +} +inline Result Client::Delete(const std::string &path) { + return cli_->Delete(path); +} +inline Result Client::Delete(const std::string &path, const Headers &headers) { + return cli_->Delete(path, headers); +} +inline Result Client::Delete(const std::string &path, const char *body, + size_t content_length, + const std::string &content_type) { + return cli_->Delete(path, body, content_length, content_type); +} +inline Result Client::Delete(const std::string &path, const char *body, + size_t content_length, + const std::string &content_type, + Progress progress) { + return cli_->Delete(path, body, content_length, content_type, progress); +} +inline Result Client::Delete(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type) { + return cli_->Delete(path, headers, body, content_length, content_type); +} +inline Result Client::Delete(const std::string &path, const Headers &headers, + const char *body, size_t content_length, + const std::string &content_type, + Progress progress) { + return cli_->Delete(path, headers, body, content_length, content_type, + progress); +} +inline Result Client::Delete(const std::string &path, const std::string &body, + const std::string &content_type) { + return cli_->Delete(path, body, content_type); +} +inline Result Client::Delete(const std::string &path, const std::string &body, + const std::string &content_type, + Progress progress) { + return cli_->Delete(path, body, content_type, progress); +} +inline Result Client::Delete(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type) { + return cli_->Delete(path, headers, body, content_type); +} +inline Result Client::Delete(const std::string &path, const Headers &headers, + const std::string &body, + const std::string &content_type, + Progress progress) { + return cli_->Delete(path, headers, body, content_type, progress); +} +inline Result Client::Options(const std::string &path) { + return cli_->Options(path); +} +inline Result Client::Options(const std::string &path, const Headers &headers) { + return cli_->Options(path, headers); +} + +inline bool Client::send(Request &req, Response &res, Error &error) { + return cli_->send(req, res, error); +} + +inline Result Client::send(const Request &req) { return cli_->send(req); } + +inline void Client::stop() { cli_->stop(); } + +inline std::string Client::host() const { return cli_->host(); } + +inline int Client::port() const { return cli_->port(); } + +inline size_t Client::is_socket_open() const { return cli_->is_socket_open(); } + +inline socket_t Client::socket() const { return cli_->socket(); } + +inline void +Client::set_hostname_addr_map(std::map addr_map) { + cli_->set_hostname_addr_map(std::move(addr_map)); +} + +inline void Client::set_default_headers(Headers headers) { + cli_->set_default_headers(std::move(headers)); +} + +inline void Client::set_header_writer( + std::function const &writer) { + cli_->set_header_writer(writer); +} + +inline void Client::set_address_family(int family) { + cli_->set_address_family(family); +} + +inline void Client::set_tcp_nodelay(bool on) { cli_->set_tcp_nodelay(on); } + +inline void Client::set_socket_options(SocketOptions socket_options) { + cli_->set_socket_options(std::move(socket_options)); +} + +inline void Client::set_connection_timeout(time_t sec, time_t usec) { + cli_->set_connection_timeout(sec, usec); +} + +inline void Client::set_read_timeout(time_t sec, time_t usec) { + cli_->set_read_timeout(sec, usec); +} + +inline void Client::set_write_timeout(time_t sec, time_t usec) { + cli_->set_write_timeout(sec, usec); +} + +inline void Client::set_basic_auth(const std::string &username, + const std::string &password) { + cli_->set_basic_auth(username, password); +} +inline void Client::set_bearer_token_auth(const std::string &token) { + cli_->set_bearer_token_auth(token); +} +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +inline void Client::set_digest_auth(const std::string &username, + const std::string &password) { + cli_->set_digest_auth(username, password); +} +#endif + +inline void Client::set_keep_alive(bool on) { cli_->set_keep_alive(on); } +inline void Client::set_follow_location(bool on) { + cli_->set_follow_location(on); +} + +inline void Client::set_url_encode(bool on) { cli_->set_url_encode(on); } + +inline void Client::set_compress(bool on) { cli_->set_compress(on); } + +inline void Client::set_decompress(bool on) { cli_->set_decompress(on); } + +inline void Client::set_interface(const std::string &intf) { + cli_->set_interface(intf); +} + +inline void Client::set_proxy(const std::string &host, int port) { + cli_->set_proxy(host, port); +} +inline void Client::set_proxy_basic_auth(const std::string &username, + const std::string &password) { + cli_->set_proxy_basic_auth(username, password); +} +inline void Client::set_proxy_bearer_token_auth(const std::string &token) { + cli_->set_proxy_bearer_token_auth(token); +} +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +inline void Client::set_proxy_digest_auth(const std::string &username, + const std::string &password) { + cli_->set_proxy_digest_auth(username, password); +} +#endif + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +inline void Client::enable_server_certificate_verification(bool enabled) { + cli_->enable_server_certificate_verification(enabled); +} + +inline void Client::enable_server_hostname_verification(bool enabled) { + cli_->enable_server_hostname_verification(enabled); +} + +inline void Client::set_server_certificate_verifier( + std::function verifier) { + cli_->set_server_certificate_verifier(verifier); +} +#endif + +inline void Client::set_logger(Logger logger) { + cli_->set_logger(std::move(logger)); +} + +#ifdef CPPHTTPLIB_OPENSSL_SUPPORT +inline void Client::set_ca_cert_path(const std::string &ca_cert_file_path, + const std::string &ca_cert_dir_path) { + cli_->set_ca_cert_path(ca_cert_file_path, ca_cert_dir_path); +} + +inline void Client::set_ca_cert_store(X509_STORE *ca_cert_store) { + if (is_ssl_) { + static_cast(*cli_).set_ca_cert_store(ca_cert_store); + } else { + cli_->set_ca_cert_store(ca_cert_store); + } +} + +inline void Client::load_ca_cert_store(const char *ca_cert, std::size_t size) { + set_ca_cert_store(cli_->create_ca_cert_store(ca_cert, size)); +} + +inline long Client::get_openssl_verify_result() const { + if (is_ssl_) { + return static_cast(*cli_).get_openssl_verify_result(); + } + return -1; // NOTE: -1 doesn't match any of X509_V_ERR_??? +} + +inline SSL_CTX *Client::ssl_context() const { + if (is_ssl_) { return static_cast(*cli_).ssl_context(); } + return nullptr; +} +#endif + +// ---------------------------------------------------------------------------- + +} // namespace httplib + +#if defined(_WIN32) && defined(CPPHTTPLIB_USE_POLL) +#undef poll +#endif + +#endif // CPPHTTPLIB_HTTPLIB_H diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h new file mode 100644 index 00000000..0709a61e --- /dev/null +++ b/include/miniocpp/rdma.h @@ -0,0 +1,262 @@ +// MinIO C++ Library for Amazon S3 Compatible Cloud Storage +// Copyright 2022-2024 MinIO, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// SPDX-License-Identifier: Apache-2.0 + +#ifndef MINIO_CPP_RDMA_H_INCLUDED +#define MINIO_CPP_RDMA_H_INCLUDED + +#include "error.h" +#include "utils.h" +#include "credentials.h" +#include "signer.h" +#include "rdma-httplib.h" +#include "nvidia-cufile.h" +#include "nvidia-cuobjclient.h" + +#define IO_DESC_STR \ + "0102030405060708:01020304:01020304:0102:010203:1:0102030405060708090a0b0c0d0e0f10:0102030405060708:0102030405060708" + +// SHA256 hash of empty string (for RDMA requests with no body) +inline constexpr const char* kEmptySha256 = "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855"; +inline constexpr const char* kUnsignedPayload = "UNSIGNED-PAYLOAD"; + +// S3 RDMA Protocol Headers (AWS S3 RDMA spec) +inline constexpr const char* kAmzRDMAToken = "x-amz-rdma-token"; +inline constexpr const char* kAmzRDMAReply = "x-amz-rdma-reply"; +inline constexpr const char* kAmzRDMABytesTransferred = "x-amz-rdma-bytes-transferred"; + +// RDMA Reply Status Codes (aligned with HTTP status codes) +inline constexpr int kRDMAReplySuccess = 200; +inline constexpr int kRDMAReplyNoContent = 204; +inline constexpr int kRDMAReplyPartialContent = 206; +inline constexpr int kRDMAReplyNotImplemented = 501; + +// These functions are invoked by cufile rdma layer either user shadow pages or direct gpu va address +// depending on whether nvidia-fs driver or nv peer mem is present +inline static ssize_t objectPut(const void *handle, const char* buf, size_t size, loff_t offset, const cufileRDMAInfo_t *infop) +{ + void *ctx = cuObjClient::getCtx(handle); + s3_rdma_client_ctx_t *sctx = static_cast(ctx); + char io_str[sizeof IO_DESC_STR]; + unsigned io_len = sizeof io_str; + + if (infop == nullptr) { + std::cerr << "obtained NULL descr" << std::endl; + return -1; + } + + const std::string descr = std::string(infop->desc_str, infop->desc_len); + snprintf(io_str, io_len,"%s:%016lx:%016lx;", + infop->desc_str, (uint64_t)buf, (uint64_t)size); + + minio::utils::UtcTime date = minio::utils::UtcTime::Now(); + minio::creds::Credentials creds = sctx->provider->Fetch(); + minio::utils::Multimap query_params; + minio::http::Url url; + std::string region = "us-east-1"; + + if (sctx->uploadId != "") { + query_params.Add("uploadId", sctx->uploadId); + if (sctx->partNumber == 0) { + std::cerr << "partNumber cannot be zero" << std::endl; + return -1; + } + if (sctx->partNumber > 10000) { + std::cerr << "partNumber cannot be > 10000" << std::endl; + return -1; + } + query_params.Add("partNumber", std::to_string(sctx->partNumber)); + } + + if (minio::error::Error err = sctx->url.BuildUrl(url, minio::http::Method::kPut, + region, query_params, + sctx->bucket, sctx->object)) { + std::cerr << "failed to build url. error=" << err + << ". This should not happen" << std::endl; + return -1; + } + + std::string host = url.HostHeaderValue(); + + // Build headers for SignV4S3 + minio::utils::Multimap sign_headers; + sign_headers.Add("Host", host); + sign_headers.Add("x-amz-date", date.ToAmzDate()); + sign_headers.Add("x-amz-content-sha256", kUnsignedPayload); + sign_headers.Add(kAmzRDMAToken, io_str); + sign_headers.Add("Content-Type", "application/octet-stream"); + sign_headers.Add("Content-Length", "0"); + + // Add session token if present + if (!creds.session_token.empty()) { + sign_headers.Add("X-Amz-Security-Token", creds.session_token); + } + + // Sign the request with SignV4S3 (adds Authorization header) + minio::signer::SignV4S3(minio::http::Method::kPut, url.path, region, + sign_headers, query_params, + creds.access_key, creds.secret_key, + kUnsignedPayload, date); + + // Convert Multimap to httplib::Headers + httplib::Headers headers; + std::list keys = sign_headers.Keys(); + for (const auto& key : keys) { + std::list values = sign_headers.Get(key); + for (const auto& value : values) { + headers.emplace(key, value); + } + } + + std::string path = url.path; + std::string query_string = query_params.ToQueryString(); + std::string full_path = query_string.empty() ? path : path + "?" + query_string; + + url.path = ""; + url.query_string = ""; + httplib::Client cli(url.String()); + + auto res = cli.Put(full_path, headers, "", ""); + if (res.error() != httplib::Error::Success) { + std::cout << "Upload failed with error " << res.error() << std::endl; + return -1; + } + + // Check HTTP status first - 200 OK with ETag means success + std::string etag = res->get_header_value("ETag"); + if (res->status == 200 && !etag.empty()) { + // Success - got 200 OK with ETag, RDMA transfer completed + sctx->etag = minio::utils::Trim(etag, '"'); + return size; + } + + // Check x-amz-rdma-reply header per AWS S3 RDMA protocol spec + std::string rdma_reply = res->get_header_value(kAmzRDMAReply); + if (rdma_reply.empty() || rdma_reply == "501") { + // RDMA declined by server - fallback needed + std::cerr << "RDMA declined by server, fallback needed" << std::endl; + return -2; + } + + int reply_code = std::stoi(rdma_reply); + if (reply_code != kRDMAReplySuccess && reply_code != kRDMAReplyNoContent) { + std::cerr << "Unexpected RDMA reply: " << reply_code << std::endl; + return -1; + } + + sctx->etag = minio::utils::Trim(etag, '"'); + return size; +} + +inline static ssize_t objectGet(const void *handle, char* buf, size_t size, loff_t offset, const cufileRDMAInfo_t *infop) +{ + void *ctx = cuObjClient::getCtx(handle); + s3_rdma_client_ctx_t *sctx = static_cast(ctx); + char io_str[sizeof IO_DESC_STR]; + unsigned io_len = sizeof io_str; + + if (infop == nullptr) { + std::cerr << "obtained NULL descr" << std::endl; + return -1; + } + + const std::string descr = std::string(infop->desc_str, infop->desc_len); + snprintf(io_str, io_len,"%s:%016lx:%016lx;", + infop->desc_str, (uint64_t)buf, (uint64_t)size); + + minio::utils::UtcTime date = minio::utils::UtcTime::Now(); + minio::creds::Credentials creds = sctx->provider->Fetch(); + minio::utils::Multimap query_params; + minio::http::Url url; + std::string region = "us-east-1"; + + if (minio::error::Error err = sctx->url.BuildUrl(url, minio::http::Method::kGet, + region, query_params, + sctx->bucket, sctx->object)) { + std::cerr << "failed to build url. error=" << err + << ". This should not happen" << std::endl; + return -1; + } + + std::string host = url.HostHeaderValue(); + + // Build headers for SignV4S3 + minio::utils::Multimap sign_headers; + sign_headers.Add("Host", host); + sign_headers.Add("x-amz-date", date.ToAmzDate()); + sign_headers.Add("x-amz-content-sha256", kUnsignedPayload); + sign_headers.Add(kAmzRDMAToken, io_str); + + // Add session token if present + if (!creds.session_token.empty()) { + sign_headers.Add("X-Amz-Security-Token", creds.session_token); + } + + // Sign the request with SignV4S3 (adds Authorization header) + minio::signer::SignV4S3(minio::http::Method::kGet, url.path, region, + sign_headers, query_params, + creds.access_key, creds.secret_key, + kUnsignedPayload, date); + + // Convert Multimap to httplib::Headers + httplib::Headers headers; + std::list hdr_keys = sign_headers.Keys(); + for (const auto& key : hdr_keys) { + std::list values = sign_headers.Get(key); + for (const auto& value : values) { + headers.emplace(key, value); + } + } + + std::string path = url.path; + url.path = ""; + url.query_string = ""; + httplib::Client cli(url.String()); + + auto res = cli.Get(path, headers); + if (res.error() != httplib::Error::Success) { + std::cerr << "Download failed with error " << res.error() << std::endl; + return -1; + } + + // Check x-amz-rdma-reply header per AWS S3 RDMA protocol spec + std::string rdma_reply = res->get_header_value(kAmzRDMAReply); + if (rdma_reply.empty() || rdma_reply == "501") { + // RDMA declined by server - fallback needed + std::cerr << "RDMA declined by server" << std::endl; + return -2; + } + + int reply_code = std::stoi(rdma_reply); + if (reply_code != kRDMAReplySuccess && reply_code != kRDMAReplyPartialContent) { + std::cerr << "Unexpected RDMA reply: " << reply_code << std::endl; + return -1; + } + + // Verify bytes transferred per spec + std::string bytes_str = res->get_header_value(kAmzRDMABytesTransferred); + if (!bytes_str.empty()) { + ssize_t bytes_transferred = std::stoll(bytes_str); + if (bytes_transferred != static_cast(size)) { + std::cerr << "RDMA bytes mismatch: expected " << size + << ", got " << bytes_transferred << std::endl; + } + } + + return size; +} + +#endif // _MINIO_CPP_RDMA_H_INCLUDED diff --git a/include/miniocpp/response.h b/include/miniocpp/response.h index 7ede8edf..60d3b502 100644 --- a/include/miniocpp/response.h +++ b/include/miniocpp/response.h @@ -42,6 +42,7 @@ struct Response { std::string host_id; std::string bucket_name; std::string object_name; + std::string etag; private: error::Error err_; diff --git a/include/miniocpp/utils.h b/include/miniocpp/utils.h index a354e0ab..a7ac7210 100644 --- a/include/miniocpp/utils.h +++ b/include/miniocpp/utils.h @@ -37,10 +37,11 @@ namespace minio::utils { -inline constexpr unsigned int kMaxMultipartCount = 10000; // 10000 parts -inline constexpr uint64_t kMaxObjectSize = 5'497'558'138'880; // 5TiB -inline constexpr uint64_t kMaxPartSize = 5'368'709'120; // 5GiB -inline constexpr unsigned int kMinPartSize = 5 * 1024 * 1024; // 5MiB +inline constexpr unsigned int kMaxMultipartCount = 10000; // 10000 parts +inline constexpr unsigned int kOptPartSize = 64 * 1024 * 1024; // 64MiB +inline constexpr unsigned int kMinPartSize = 5 * 1024 * 1024; // 5MiB +inline constexpr uint64_t kMaxPartSize = kMinPartSize * 1024; // 5GiB +inline constexpr uint64_t kMaxObjectSize = kMaxPartSize * 1024; // 5TiB // GetEnv copies the environment variable name into var bool GetEnv(std::string& var, const char* name); diff --git a/src/args.cc b/src/args.cc index e361d77e..94d286dc 100644 --- a/src/args.cc +++ b/src/args.cc @@ -224,6 +224,22 @@ error::Error DownloadObjectArgs::Validate() const { return error::SUCCESS; } +error::Error GetObjectRDMAArgs::Validate() const { + if (!this->buf) { + return error::Error("buffer must be set"); + } + + return error::SUCCESS; +} + +error::Error PutObjectRDMAArgs::Validate() const { + if (!this->buf) { + return error::Error("buffer must be set"); + } + + return error::SUCCESS; +} + error::Error GetObjectArgs::Validate() const { if (error::Error err = ObjectConditionalReadArgs::Validate()) { return err; diff --git a/src/baseclient.cc b/src/baseclient.cc index 0b46aa40..687b6531 100644 --- a/src/baseclient.cc +++ b/src/baseclient.cc @@ -43,6 +43,10 @@ #include "miniocpp/types.h" #include "miniocpp/utils.h" +// RDMA specific includes +#include "miniocpp/rdma.h" +#include "miniocpp/nvidia-cuobjclient.h" + // We want exactly `minio::s3::BaseClient::GetObject()` symbol and nothing else. #if defined(GetObject) #undef GetObject @@ -65,27 +69,27 @@ BaseClient::BaseClient(BaseUrl base_url, creds::Provider* provider) : base_url_(std::move(base_url)), provider_(provider) { if (!base_url_) { std::cerr << "valid base url must be provided; " << base_url_.Error() - << std::endl; + << std::endl; std::terminate(); } } error::Error BaseClient::SetAppInfo(std::string_view app_name, - std::string_view app_version) { + std::string_view app_version) { if (app_name.empty() || app_version.empty()) { return error::Error("Application name/version cannot be empty"); } user_agent_ = std::string(DEFAULT_USER_AGENT) + " " + std::string(app_name) + - "/" + std::string(app_version); + "/" + std::string(app_version); return error::SUCCESS; } void BaseClient::HandleRedirectResponse(std::string& code, std::string& message, - int status_code, http::Method method, - const utils::Multimap& headers, - const std::string& bucket_name, - bool retry) { + int status_code, http::Method method, + const utils::Multimap& headers, + const std::string& bucket_name, + bool retry) { switch (status_code) { case 301: code = "PermanentRedirect"; @@ -119,10 +123,10 @@ void BaseClient::HandleRedirectResponse(std::string& code, std::string& message, } Response BaseClient::GetErrorResponse(http::Response resp, - std::string_view resource, - http::Method method, - const std::string& bucket_name, - const std::string& object_name) { + std::string_view resource, + http::Method method, + const std::string& bucket_name, + const std::string& object_name) { if (!resp.error.empty()) { return error::make(resp.error); } @@ -131,14 +135,14 @@ Response BaseClient::GetErrorResponse(http::Response resp, std::list values = resp.headers.Get("Content-Type"); for (auto& value : values) { if (utils::Contains(utils::ToLower(value), "application/xml")) { - return Response::ParseXML(resp.body, resp.status_code, resp.headers); + return Response::ParseXML(resp.body, resp.status_code, resp.headers); } } auto response = - error::make("invalid response received; status code: " + - std::to_string(resp.status_code) + - "; content-type: " + utils::Join(values, ",")); + error::make("invalid response received; status code: " + + std::to_string(resp.status_code) + + "; content-type: " + utils::Join(values, ",")); response.status_code = resp.status_code; response.headers = resp.headers; return response; @@ -153,7 +157,7 @@ Response BaseClient::GetErrorResponse(http::Response resp, case 307: case 400: HandleRedirectResponse(response.code, response.message, resp.status_code, - method, resp.headers, bucket_name, true); + method, resp.headers, bucket_name, true); break; case 403: response.code = "AccessDenied"; @@ -161,39 +165,39 @@ Response BaseClient::GetErrorResponse(http::Response resp, break; case 404: if (!object_name.empty()) { - response.code = "NoSuchKey"; - response.message = "Object does not exist"; + response.code = "NoSuchKey"; + response.message = "Object does not exist"; } else if (bucket_name.empty()) { - response.code = "NoSuchBucket"; - response.message = "Bucket does not exist"; + response.code = "NoSuchBucket"; + response.message = "Bucket does not exist"; } else { - response.code = "ResourceNotFound"; - response.message = "Request resource not found"; + response.code = "ResourceNotFound"; + response.message = "Request resource not found"; } break; case 405: response.code = "MethodNotAllowed"; response.message = - "The specified method is not allowed against this resource"; + "The specified method is not allowed against this resource"; break; case 409: if (bucket_name.empty()) { - response.code = "NoSuchBucket"; - response.message = "Bucket does not exist"; + response.code = "NoSuchBucket"; + response.message = "Bucket does not exist"; } else { - response.code = "ResourceConflict"; - response.message = "Request resource conflicts"; + response.code = "ResourceConflict"; + response.message = "Request resource conflicts"; } break; case 501: response.code = "MethodNotAllowed"; response.message = - "The specified method is not allowed against this resource"; + "The specified method is not allowed against this resource"; break; default: { auto response = - error::make("server failed with HTTP status code " + - std::to_string(resp.status_code)); + error::make("server failed with HTTP status code " + + std::to_string(resp.status_code)); response.status_code = resp.status_code; response.headers = resp.headers; return response; @@ -225,7 +229,7 @@ Response BaseClient::execute(Request& req) { } Response resp = GetErrorResponse(response, request.url.path, req.method, - req.bucket_name, req.object_name); + req.bucket_name, req.object_name); if (resp.code == "NoSuchBucket" || resp.code == "RetryHead") { region_map_.erase(req.bucket_name); } @@ -244,7 +248,7 @@ Response BaseClient::Execute(Request& req) { std::string code; std::string message; HandleRedirectResponse(code, message, resp.status_code, req.method, - resp.headers, req.bucket_name); + resp.headers, req.bucket_name); resp.code = code; resp.message = message; @@ -252,12 +256,12 @@ Response BaseClient::Execute(Request& req) { } GetRegionResponse BaseClient::GetRegion(const std::string& bucket_name, - const std::string& region) { + const std::string& region) { std::string base_region = base_url_.region; if (!region.empty()) { if (!base_region.empty() && base_region != region) { return error::make("region must be " + base_region + - ", but passed " + region); + ", but passed " + region); } return GetRegionResponse(region); @@ -276,7 +280,7 @@ GetRegionResponse BaseClient::GetRegion(const std::string& bucket_name, return GetRegionResponse(stored_region); } Request req(http::Method::kGet, "us-east-1", base_url_, utils::Multimap(), - utils::Multimap()); + utils::Multimap()); req.query_params.Add("location", ""); req.bucket_name = bucket_name; @@ -318,7 +322,7 @@ AbortMultipartUploadResponse BaseClient::AbortMultipartUpload( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; req.query_params.Add("uploadId", args.upload_id); @@ -335,17 +339,17 @@ BucketExistsResponse BaseClient::BucketExists(BucketExistsArgs args) { region = resp.region; } else { return (resp.code == "NoSuchBucket") ? BucketExistsResponse(false) - : BucketExistsResponse(resp); + : BucketExistsResponse(resp); } Request req(http::Method::kHead, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; if (Response resp = Execute(req)) { return BucketExistsResponse(true); } else { return (resp.code == "NoSuchBucket") ? BucketExistsResponse(false) - : BucketExistsResponse(resp); + : BucketExistsResponse(resp); } } @@ -363,7 +367,7 @@ CompleteMultipartUploadResponse BaseClient::CompleteMultipartUpload( } Request req(http::Method::kPost, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; req.query_params.Add("uploadId", args.upload_id); @@ -409,7 +413,7 @@ CreateMultipartUploadResponse BaseClient::CreateMultipartUpload( } Request req(http::Method::kPost, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; req.query_params.Add("uploads", ""); @@ -422,7 +426,7 @@ CreateMultipartUploadResponse BaseClient::CreateMultipartUpload( return error::make("unable to parse XML"); } auto text = - xdoc.select_node("/InitiateMultipartUploadResult/UploadId/text()"); + xdoc.select_node("/InitiateMultipartUploadResult/UploadId/text()"); return CreateMultipartUploadResponse(std::string(text.node().value())); } else { return CreateMultipartUploadResponse(resp); @@ -443,7 +447,7 @@ DeleteBucketEncryptionResponse BaseClient::DeleteBucketEncryption( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("encryption", ""); @@ -472,7 +476,7 @@ DisableObjectLegalHoldResponse BaseClient::DisableObjectLegalHold( std::string body = "OFF"; Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -499,7 +503,7 @@ DeleteBucketLifecycleResponse BaseClient::DeleteBucketLifecycle( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("lifecycle", ""); @@ -536,7 +540,7 @@ DeleteBucketPolicyResponse BaseClient::DeleteBucketPolicy( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("policy", ""); @@ -557,7 +561,7 @@ DeleteBucketReplicationResponse BaseClient::DeleteBucketReplication( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("replication", ""); @@ -585,7 +589,7 @@ DeleteBucketTagsResponse BaseClient::DeleteBucketTags( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("tagging", ""); @@ -606,7 +610,7 @@ DeleteObjectLockConfigResponse BaseClient::DeleteObjectLockConfig( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("object-lock", ""); @@ -627,7 +631,7 @@ DeleteObjectTagsResponse BaseClient::DeleteObjectTags( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -654,7 +658,7 @@ EnableObjectLegalHoldResponse BaseClient::EnableObjectLegalHold( std::string body = "ON"; Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -681,7 +685,7 @@ GetBucketEncryptionResponse BaseClient::GetBucketEncryption( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("encryption", ""); @@ -706,7 +710,7 @@ GetBucketLifecycleResponse BaseClient::GetBucketLifecycle( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("lifecycle", ""); @@ -736,7 +740,7 @@ GetBucketNotificationResponse BaseClient::GetBucketNotification( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("notification", ""); @@ -760,7 +764,7 @@ GetBucketPolicyResponse BaseClient::GetBucketPolicy(GetBucketPolicyArgs args) { } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("policy", ""); @@ -785,7 +789,7 @@ GetBucketReplicationResponse BaseClient::GetBucketReplication( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("replication", ""); @@ -809,7 +813,7 @@ GetBucketTagsResponse BaseClient::GetBucketTags(GetBucketTagsArgs args) { } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("tagging", ""); @@ -834,7 +838,7 @@ GetBucketVersioningResponse BaseClient::GetBucketVersioning( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("versioning", ""); @@ -873,7 +877,7 @@ GetObjectResponse BaseClient::GetObject(GetObjectArgs args) { if (args.ssec != nullptr && !base_url_.https) { return error::make( - "SSE-C operation must be performed over a secure connection"); + "SSE-C operation must be performed over a secure connection"); } std::string region; @@ -884,7 +888,7 @@ GetObjectResponse BaseClient::GetObject(GetObjectArgs args) { } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -913,7 +917,7 @@ GetObjectLockConfigResponse BaseClient::GetObjectLockConfig( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("object-lock", ""); @@ -964,7 +968,7 @@ GetObjectRetentionResponse BaseClient::GetObjectRetention( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1011,7 +1015,7 @@ GetObjectTagsResponse BaseClient::GetObjectTags(GetObjectTagsArgs args) { } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1045,9 +1049,9 @@ GetPresignedObjectUrlResponse BaseClient::GetPresignedObjectUrl( http::Url url; if (error::Error err = base_url_.BuildUrl( - url, args.method, region, query_params, args.bucket, args.object)) { + url, args.method, region, query_params, args.bucket, args.object)) { std::cerr << "failed to build url. error=" << err - << ". This should not happen" << std::endl; + << ". This should not happen" << std::endl; std::terminate(); } @@ -1062,8 +1066,8 @@ GetPresignedObjectUrlResponse BaseClient::GetPresignedObjectUrl( std::string host = url.HostHeaderValue(); signer::PresignV4(args.method, host, url.path, region, query_params, - creds.access_key, creds.secret_key, date, - args.expiry_seconds); + creds.access_key, creds.secret_key, date, + args.expiry_seconds); url.query_string = query_params.ToQueryString(); } @@ -1074,12 +1078,12 @@ GetPresignedPostFormDataResponse BaseClient::GetPresignedPostFormData( PostPolicy policy) { if (!policy) { return error::make( - "valid policy must be provided"); + "valid policy must be provided"); } if (provider_ == nullptr) { return error::make( - "Anonymous access does not require pre-signed post form-data"); + "Anonymous access does not require pre-signed post form-data"); } std::string region; @@ -1092,8 +1096,8 @@ GetPresignedPostFormDataResponse BaseClient::GetPresignedPostFormData( creds::Credentials creds = provider_->Fetch(); std::map data; if (error::Error err = - policy.FormData(data, creds.access_key, creds.secret_key, - creds.session_token, region)) { + policy.FormData(data, creds.access_key, creds.secret_key, + creds.session_token, region)) { return GetPresignedPostFormDataResponse(err); } return GetPresignedPostFormDataResponse(data); @@ -1113,7 +1117,7 @@ IsObjectLegalHoldEnabledResponse BaseClient::IsObjectLegalHoldEnabled( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1141,7 +1145,7 @@ IsObjectLegalHoldEnabledResponse BaseClient::IsObjectLegalHoldEnabled( ListBucketsResponse BaseClient::ListBuckets(ListBucketsArgs args) { Request req(http::Method::kGet, base_url_.region, base_url_, - args.extra_headers, args.extra_query_params); + args.extra_headers, args.extra_query_params); Response resp = Execute(req); if (!resp) { return ListBucketsResponse(resp); @@ -1161,7 +1165,7 @@ ListenBucketNotificationResponse BaseClient::ListenBucketNotification( if (!base_url_.aws_domain_suffix.empty()) { return error::make( - "ListenBucketNotification API is not supported in Amazon S3"); + "ListenBucketNotification API is not supported in Amazon S3"); } std::string region; @@ -1172,7 +1176,7 @@ ListenBucketNotificationResponse BaseClient::ListenBucketNotification( } Request req = Request(http::Method::kGet, region, base_url_, - args.extra_headers, args.extra_query_params); + args.extra_headers, args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("prefix", args.prefix); req.query_params.Add("suffix", args.suffix); @@ -1187,7 +1191,7 @@ ListenBucketNotificationResponse BaseClient::ListenBucketNotification( std::string data; auto func = args.func; req.datafunc = [&func = func, - &data = data](http::DataFunctionArgs args) -> bool { + &data = data](http::DataFunctionArgs args) -> bool { data += args.datachunk; while (true) { size_t pos = data.find('\n'); @@ -1203,13 +1207,13 @@ ListenBucketNotificationResponse BaseClient::ListenBucketNotification( nlohmann::json j_records = json["Records"]; std::list records; for (auto& j_record : j_records) { - records.push_back(NotificationRecord::ParseJSON(j_record)); + records.push_back(NotificationRecord::ParseJSON(j_record)); } if (records.size() <= 0) continue; if (!func(records)) { - return false; + return false; } } }; @@ -1230,7 +1234,7 @@ ListObjectsResponse BaseClient::ListObjectsV1(ListObjectsV1Args args) { } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.AddAll(GetCommonListObjectsQueryParams( args.delimiter, args.encoding_type, args.max_keys, args.prefix)); @@ -1257,7 +1261,7 @@ ListObjectsResponse BaseClient::ListObjectsV2(ListObjectsV2Args args) { } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("list-type", "2"); req.query_params.AddAll(GetCommonListObjectsQueryParams( @@ -1295,7 +1299,7 @@ ListObjectsResponse BaseClient::ListObjectVersions( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("versions", ""); req.query_params.AddAll(GetCommonListObjectsQueryParams( @@ -1323,7 +1327,7 @@ MakeBucketResponse BaseClient::MakeBucket(MakeBucketArgs args) { std::string base_region = base_url_.region; if (!base_region.empty() && !region.empty() && base_region != region) { return error::make("region must be " + base_region + - ", but passed " + region); + ", but passed " + region); } if (region.empty()) { @@ -1333,7 +1337,7 @@ MakeBucketResponse BaseClient::MakeBucket(MakeBucketArgs args) { region = "us-east-1"; } Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; if (args.object_lock) { req.headers.Add("x-amz-bucket-object-lock-enabled", "true"); @@ -1367,8 +1371,32 @@ PutObjectResponse BaseClient::PutObject(PutObjectApiArgs args) { return PutObjectResponse(resp); } + if (args.rdmaclient->isConnected()) { + // put the buffer + put operation. + // send the buffer + put operation. + s3_rdma_client_ctx putCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .uploadId = "", + .partNumber = 0, + .etag = "", + .url = base_url_, + .op = CUOBJ_PUT, + }; + + ssize_t ret = args.rdmaclient->cuObjPut(&putCtx, args.buf, args.size); + if (ret < 0) { + return error::make("failed to upload the object "+ args.object); + } + + PutObjectResponse resp; + resp.etag = putCtx.etag; + return resp; + } + Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; req.query_params.AddAll(args.query_params); @@ -1381,6 +1409,7 @@ PutObjectResponse BaseClient::PutObject(PutObjectApiArgs args) { if (!response) { return PutObjectResponse(response); } + PutObjectResponse resp; resp.etag = utils::Trim(response.headers.GetFront("etag"), '"'); resp.version_id = response.headers.GetFront("x-amz-version-id"); @@ -1405,7 +1434,7 @@ RemoveBucketResponse BaseClient::RemoveBucket(RemoveBucketArgs args) { } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; return RemoveBucketResponse(Execute(req)); @@ -1424,7 +1453,7 @@ RemoveObjectResponse BaseClient::RemoveObject(RemoveObjectArgs args) { } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1447,7 +1476,7 @@ RemoveObjectsResponse BaseClient::RemoveObjects(RemoveObjectsApiArgs args) { } Request req(http::Method::kPost, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("delete", ""); if (args.bypass_governance_mode) { @@ -1486,7 +1515,7 @@ SelectObjectContentResponse BaseClient::SelectObjectContent( if (args.ssec != nullptr && !base_url_.https) { return error::make( - "SSE-C operation must be performed over a secure connection"); + "SSE-C operation must be performed over a secure connection"); } std::string region; @@ -1497,7 +1526,7 @@ SelectObjectContentResponse BaseClient::SelectObjectContent( } Request req(http::Method::kPost, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; req.query_params.Add("select", ""); @@ -1539,7 +1568,7 @@ SetBucketEncryptionResponse BaseClient::SetBucketEncryption( std::string body = ss.str(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("encryption", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1564,7 +1593,7 @@ SetBucketLifecycleResponse BaseClient::SetBucketLifecycle( std::string body = args.config.ToXML(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("lifecycle", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1589,7 +1618,7 @@ SetBucketNotificationResponse BaseClient::SetBucketNotification( std::string body = args.config.ToXML(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("notification", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1611,7 +1640,7 @@ SetBucketPolicyResponse BaseClient::SetBucketPolicy(SetBucketPolicyArgs args) { } Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("policy", ""); req.body = args.policy; @@ -1636,7 +1665,7 @@ SetBucketReplicationResponse BaseClient::SetBucketReplication( std::string body = args.config.ToXML(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("replication", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1663,7 +1692,7 @@ SetBucketTagsResponse BaseClient::SetBucketTags(SetBucketTagsArgs args) { ss << ""; for (auto& [key, value] : args.tags) { ss << "" << "" << key << "" << "" << value - << "" << ""; + << "" << ""; } ss << ""; } @@ -1672,7 +1701,7 @@ SetBucketTagsResponse BaseClient::SetBucketTags(SetBucketTagsArgs args) { std::string body = ss.str(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("tagging", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1708,7 +1737,7 @@ SetBucketVersioningResponse BaseClient::SetBucketVersioning( std::string body = ss.str(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("versioning", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1739,13 +1768,13 @@ SetObjectLockConfigResponse BaseClient::SetObjectLockConfig( << ""; if (args.config.retention_duration_days) { ss << "" - << std::to_string(args.config.retention_duration_days.Get()) - << ""; + << std::to_string(args.config.retention_duration_days.Get()) + << ""; } if (args.config.retention_duration_years) { ss << "" - << std::to_string(args.config.retention_duration_years.Get()) - << ""; + << std::to_string(args.config.retention_duration_years.Get()) + << ""; } ss << ""; } @@ -1754,7 +1783,7 @@ SetObjectLockConfigResponse BaseClient::SetObjectLockConfig( std::string body = ss.str(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("object-lock", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1785,7 +1814,7 @@ SetObjectRetentionResponse BaseClient::SetObjectRetention( std::string body = ss.str(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1816,7 +1845,7 @@ SetObjectTagsResponse BaseClient::SetObjectTags(SetObjectTagsArgs args) { ss << ""; for (auto& [key, value] : args.tags) { ss << "" << "" << key << "" << "" << value - << "" << ""; + << "" << ""; } ss << ""; } @@ -1825,7 +1854,7 @@ SetObjectTagsResponse BaseClient::SetObjectTags(SetObjectTagsArgs args) { std::string body = ss.str(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1845,7 +1874,7 @@ StatObjectResponse BaseClient::StatObject(StatObjectArgs args) { if (args.ssec != nullptr && !base_url_.https) { return error::make( - "SSE-C operation must be performed over a secure connection"); + "SSE-C operation must be performed over a secure connection"); } std::string region; @@ -1856,7 +1885,7 @@ StatObjectResponse BaseClient::StatObject(StatObjectArgs args) { } Request req(http::Method::kHead, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1889,7 +1918,7 @@ StatObjectResponse BaseClient::StatObject(StatObjectArgs args) { value = response.headers.GetFront("x-amz-object-lock-retain-until-date"); if (!value.empty()) { resp.retention_retain_until_date = - utils::UtcTime::FromISO8601UTC(value.c_str()); + utils::UtcTime::FromISO8601UTC(value.c_str()); } value = response.headers.GetFront("x-amz-object-lock-legal-hold"); @@ -1917,6 +1946,29 @@ UploadPartResponse BaseClient::UploadPart(UploadPartArgs args) { return UploadPartResponse(err); } + if (args.rdmaclient->isConnected()) { + // put the buffer + put operation. + s3_rdma_client_ctx putCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .uploadId = args.upload_id, + .partNumber = args.part_number, + .etag = "", + .url = base_url_, + .op = CUOBJ_PUT, + }; + + ssize_t ret = args.rdmaclient->cuObjPut(&putCtx, args.buf, args.part_size); + if (ret < 0) { + return UploadPartResponse(error::Error("failed to upload to object with uploadId "+ args.object + "uploadId=" + args.upload_id)); + } + + UploadPartResponse resp; + resp.etag = putCtx.etag; + return resp; + } + utils::Multimap query_params; query_params.Add("partNumber", std::to_string(args.part_number)); query_params.Add("uploadId", args.upload_id); @@ -1948,7 +2000,7 @@ UploadPartCopyResponse BaseClient::UploadPartCopy(UploadPartCopyArgs args) { } Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; req.query_params.AddAll(args.extra_query_params); diff --git a/src/client.cc b/src/client.cc index f95e3001..126878d3 100644 --- a/src/client.cc +++ b/src/client.cc @@ -16,6 +16,7 @@ // SPDX-License-Identifier: Apache-2.0 #include "miniocpp/client.h" +#include #include #include @@ -37,779 +38,943 @@ #include "miniocpp/types.h" #include "miniocpp/utils.h" +// RDMA specific includes +#include "miniocpp/rdma.h" +#include "miniocpp/nvidia-cuobjclient.h" + namespace minio::s3 { -ListObjectsResult::ListObjectsResult(error::Error err) : failed_(true) { - this->resp_.contents.push_back(Item(std::move(err))); - this->itr_ = resp_.contents.begin(); -} + ListObjectsResult::ListObjectsResult(error::Error err) : failed_(true) { + this->resp_.contents.push_back(Item(std::move(err))); + this->itr_ = resp_.contents.begin(); + } -ListObjectsResult::ListObjectsResult(Client* const client, - const ListObjectsArgs& args) + ListObjectsResult::ListObjectsResult(Client* const client, + const ListObjectsArgs& args) : client_(client), args_(args) { - Populate(); -} + Populate(); + } -ListObjectsResult::ListObjectsResult(Client* const client, - ListObjectsArgs&& args) + ListObjectsResult::ListObjectsResult(Client* const client, + ListObjectsArgs&& args) : client_(client), args_(std::move(args)) { - Populate(); -} - -void ListObjectsResult::Populate() { - if (args_.include_versions) { - args_.key_marker = resp_.next_key_marker; - args_.version_id_marker = resp_.next_version_id_marker; - } else if (args_.use_api_v1) { - args_.marker = resp_.next_marker; - } else { - args_.start_after = resp_.start_after; - args_.continuation_token = resp_.next_continuation_token; + Populate(); } - std::string region; - if (GetRegionResponse resp = client_->GetRegion(args_.bucket, args_.region)) { - region = resp.region; - if (args_.recursive) { - args_.delimiter = ""; - } else if (args_.delimiter.empty()) { - args_.delimiter = "/"; - } - - if (args_.include_versions || !args_.version_id_marker.empty()) { - resp_ = client_->ListObjectVersions(ListObjectVersionsArgs(args_)); + void ListObjectsResult::Populate() { + if (args_.include_versions) { + args_.key_marker = resp_.next_key_marker; + args_.version_id_marker = resp_.next_version_id_marker; } else if (args_.use_api_v1) { - resp_ = client_->ListObjectsV1(ListObjectsV1Args(args_)); + args_.marker = resp_.next_marker; } else { - resp_ = client_->ListObjectsV2(ListObjectsV2Args(args_)); + args_.start_after = resp_.start_after; + args_.continuation_token = resp_.next_continuation_token; } - if (!resp_) { + std::string region; + if (GetRegionResponse resp = client_->GetRegion(args_.bucket, args_.region)) { + region = resp.region; + if (args_.recursive) { + args_.delimiter = ""; + } else if (args_.delimiter.empty()) { + args_.delimiter = "/"; + } + + if (args_.include_versions || !args_.version_id_marker.empty()) { + resp_ = client_->ListObjectVersions(ListObjectVersionsArgs(args_)); + } else if (args_.use_api_v1) { + resp_ = client_->ListObjectsV1(ListObjectsV1Args(args_)); + } else { + resp_ = client_->ListObjectsV2(ListObjectsV2Args(args_)); + } + + if (!resp_) { + failed_ = true; + resp_.contents.push_back(Item(resp_)); + } + } else { failed_ = true; - resp_.contents.push_back(Item(resp_)); + resp_.contents.push_back(Item(resp)); } - } else { - failed_ = true; - resp_.contents.push_back(Item(resp)); - } - itr_ = resp_.contents.begin(); -} + itr_ = resp_.contents.begin(); + } -RemoveObjectsResult::RemoveObjectsResult(error::Error err) { - done_ = true; - resp_.errors.push_back(DeleteError(err)); - itr_ = resp_.errors.begin(); -} + RemoveObjectsResult::RemoveObjectsResult(error::Error err) { + done_ = true; + resp_.errors.push_back(DeleteError(err)); + itr_ = resp_.errors.begin(); + } -RemoveObjectsResult::RemoveObjectsResult(Client* const client, - const RemoveObjectsArgs& args) + RemoveObjectsResult::RemoveObjectsResult(Client* const client, + const RemoveObjectsArgs& args) : client_(client), args_(args) { - Populate(); -} + Populate(); + } -RemoveObjectsResult::RemoveObjectsResult(Client* const client, - RemoveObjectsArgs&& args) + RemoveObjectsResult::RemoveObjectsResult(Client* const client, + RemoveObjectsArgs&& args) : client_(client), args_(args) { - Populate(); -} - -void RemoveObjectsResult::Populate() { - while (!done_ && resp_.errors.size() == 0) { - RemoveObjectsApiArgs args; - args.extra_headers = args_.extra_headers; - args.extra_query_params = args_.extra_query_params; - args.bucket = args_.bucket; - args.region = args_.region; - args.quiet = true; - args.bypass_governance_mode = args_.bypass_governance_mode; - - for (int i = 0; i < 1000; i++) { - DeleteObject object; - if (!args_.func(object)) { - break; + Populate(); + } + + void RemoveObjectsResult::Populate() { + while (!done_ && resp_.errors.size() == 0) { + RemoveObjectsApiArgs args; + args.extra_headers = args_.extra_headers; + args.extra_query_params = args_.extra_query_params; + args.bucket = args_.bucket; + args.region = args_.region; + args.quiet = true; + args.bypass_governance_mode = args_.bypass_governance_mode; + + for (int i = 0; i < 1000; i++) { + DeleteObject object; + if (!args_.func(object)) { + break; + } + args.objects.push_back(object); } - args.objects.push_back(object); - } - if (args.objects.size() != 0) { - resp_ = client_->BaseClient::RemoveObjects(args); - if (!resp_) { - resp_.errors.push_back(DeleteError(resp_)); + if (args.objects.size() != 0) { + resp_ = client_->BaseClient::RemoveObjects(args); + if (!resp_) { + resp_.errors.push_back(DeleteError(resp_)); + } + itr_ = resp_.errors.begin(); + } else { + done_ = true; } - itr_ = resp_.errors.begin(); - } else { - done_ = true; } } -} -Client::Client(BaseUrl& base_url, creds::Provider* const provider) + Client::Client(BaseUrl& base_url, creds::Provider* const provider) : BaseClient(base_url, provider) {} -StatObjectResponse Client::CalculatePartCount( - size_t& part_count, std::list sources) { - size_t object_size = 0; - size_t i = 0; - for (auto& source : sources) { - if (source.ssec != nullptr && !base_url_.https) { - std::string msg = "source " + source.bucket + "/" + source.object; - if (!source.version_id.empty()) { - msg += "?versionId=" + source.version_id; + StatObjectResponse Client::CalculatePartCount(size_t& part_count, std::list sources) { + size_t object_size = 0; + size_t i = 0; + for (auto& source : sources) { + if (source.ssec != nullptr && !base_url_.https) { + std::string msg = "source " + source.bucket + "/" + source.object; + if (!source.version_id.empty()) { + msg += "?versionId=" + source.version_id; + } + msg += ": SSE-C operation must be performed over a secure connection"; + return error::make(msg); } - msg += ": SSE-C operation must be performed over a secure connection"; - return error::make(msg); - } - i++; + i++; - std::string etag; - size_t size; + std::string etag; + size_t size; - StatObjectResponse resp = StatObject(source); - if (!resp) { - return resp; - } - etag = resp.etag; - size = resp.size; - if (error::Error err = source.BuildHeaders(size, etag)) { - return StatObjectResponse(err); - } - if (source.length != nullptr) { - size = *source.length; - } else if (source.offset != nullptr) { - size -= *source.offset; - } + StatObjectResponse resp = StatObject(source); + if (!resp) { + return resp; + } + etag = resp.etag; + size = resp.size; + if (error::Error err = source.BuildHeaders(size, etag)) { + return StatObjectResponse(err); + } + if (source.length != nullptr) { + size = *source.length; + } else if (source.offset != nullptr) { + size -= *source.offset; + } - if (size < utils::kMinPartSize && sources.size() != 1 && - i != sources.size()) { - std::string msg = "source " + source.bucket + "/" + source.object; - if (!source.version_id.empty()) msg += "?versionId=" + source.version_id; - msg += ": size " + std::to_string(size) + " must be greater than " + - std::to_string(utils::kMinPartSize); - return error::make(msg); - } + if (size < utils::kMinPartSize && sources.size() != 1 && + i != sources.size()) { + std::string msg = "source " + source.bucket + "/" + source.object; + if (!source.version_id.empty()) msg += "?versionId=" + source.version_id; + msg += ": size " + std::to_string(size) + " must be greater than " + + std::to_string(utils::kMinPartSize); + return error::make(msg); + } - object_size += size; - if (object_size > utils::kMaxObjectSize) { - return error::make( - "destination object size must be less than " + - std::to_string(utils::kMaxObjectSize)); - } + object_size += size; + if (object_size > utils::kMaxObjectSize) { + return error::make( + "destination object size must be less than " + + std::to_string(utils::kMaxObjectSize)); + } - if (size > utils::kMaxPartSize) { - size_t count = size / utils::kMaxPartSize; - size_t last_part_size = size - (count * utils::kMaxPartSize); - if (last_part_size > 0) { - count++; + if (size > utils::kMaxPartSize) { + size_t count = size / utils::kMaxPartSize; + size_t last_part_size = size - (count * utils::kMaxPartSize); + if (last_part_size > 0) { + count++; + } else { + last_part_size = utils::kMaxPartSize; + } + + if (last_part_size < utils::kMinPartSize && sources.size() != 1 && + i != sources.size()) { + std::string msg = "source " + source.bucket + "/" + source.object; + if (!source.version_id.empty()) { + msg += "?versionId=" + source.version_id; + } + msg += ": size " + std::to_string(size) + + " for multipart split upload of " + std::to_string(size) + + ", last part size is less than " + + std::to_string(utils::kMinPartSize); + return error::make(msg); + } + + part_count += count; } else { - last_part_size = utils::kMaxPartSize; + part_count++; } - if (last_part_size < utils::kMinPartSize && sources.size() != 1 && - i != sources.size()) { - std::string msg = "source " + source.bucket + "/" + source.object; - if (!source.version_id.empty()) { - msg += "?versionId=" + source.version_id; - } - msg += ": size " + std::to_string(size) + - " for multipart split upload of " + std::to_string(size) + - ", last part size is less than " + - std::to_string(utils::kMinPartSize); - return error::make(msg); + if (part_count > utils::kMaxMultipartCount) { + return error::make( + "Compose sources create more than allowed multipart count " + + std::to_string(utils::kMaxMultipartCount)); } + } - part_count += count; - } else { - part_count++; + return StatObjectResponse(error::SUCCESS); + } + + ComposeObjectResponse Client::ComposeObject(ComposeObjectArgs args, + std::string& upload_id) { + size_t part_count = 0; + { + StatObjectResponse resp = CalculatePartCount(part_count, args.sources); + if (!resp) { + return ComposeObjectResponse(resp); + } } - if (part_count > utils::kMaxMultipartCount) { - return error::make( - "Compose sources create more than allowed multipart count " + - std::to_string(utils::kMaxMultipartCount)); + ComposeSource& source = args.sources.front(); + if (part_count == 1 && source.offset == nullptr && source.length == nullptr) { + CopyObjectArgs coargs; + coargs.extra_headers = args.extra_headers; + coargs.extra_query_params = args.extra_query_params; + coargs.bucket = args.bucket; + coargs.region = args.region; + coargs.object = args.object; + coargs.sse = args.sse; + coargs.source = source; + + return ComposeObjectResponse(CopyObject(coargs)); } - } - return StatObjectResponse(error::SUCCESS); -} + utils::Multimap headers = args.Headers(); + + { + CreateMultipartUploadArgs cmu_args; + cmu_args.extra_query_params = args.extra_query_params; + cmu_args.bucket = args.bucket; + cmu_args.region = args.region; + cmu_args.object = args.object; + cmu_args.headers = headers; + if (CreateMultipartUploadResponse resp = CreateMultipartUpload(cmu_args)) { + upload_id = resp.upload_id; + } else { + return ComposeObjectResponse(resp); + } + } -ComposeObjectResponse Client::ComposeObject(ComposeObjectArgs args, - std::string& upload_id) { - size_t part_count = 0; - { - StatObjectResponse resp = CalculatePartCount(part_count, args.sources); - if (!resp) { - return ComposeObjectResponse(resp); + unsigned int part_number = 0; + utils::Multimap ssecheaders; + if (args.sse != nullptr) { + if (SseCustomerKey* ssec = dynamic_cast(args.sse)) { + ssecheaders = ssec->Headers(); + } } - } - ComposeSource& source = args.sources.front(); - if (part_count == 1 && source.offset == nullptr && source.length == nullptr) { - CopyObjectArgs coargs; - coargs.extra_headers = args.extra_headers; - coargs.extra_query_params = args.extra_query_params; - coargs.bucket = args.bucket; - coargs.region = args.region; - coargs.object = args.object; - coargs.sse = args.sse; - coargs.source = source; - - return ComposeObjectResponse(CopyObject(coargs)); - } + std::list parts; + for (auto& source : args.sources) { + size_t size = source.ObjectSize(); + if (source.length != nullptr) { + size = *source.length; + } else if (source.offset != nullptr) { + size -= *source.offset; + } - utils::Multimap headers = args.Headers(); + size_t offset = 0; + if (source.offset != nullptr) offset = *source.offset; + + utils::Multimap headers; + headers.AddAll(source.Headers()); + headers.AddAll(ssecheaders); + + if (size <= utils::kMaxPartSize) { + part_number++; + if (source.length != nullptr) { + headers.Add("x-amz-copy-source-range", + "bytes=" + std::to_string(offset) + "-" + + std::to_string(offset + *source.length - 1)); + } else if (source.offset != nullptr) { + headers.Add("x-amz-copy-source-range", + "bytes=" + std::to_string(offset) + "-" + + std::to_string(offset + size - 1)); + } + + UploadPartCopyArgs upc_args; + upc_args.bucket = args.bucket; + upc_args.region = args.region; + upc_args.object = args.object; + upc_args.headers = headers; + upc_args.upload_id = upload_id; + upc_args.part_number = part_number; + UploadPartCopyResponse resp = UploadPartCopy(upc_args); + if (!resp) { + return ComposeObjectResponse(resp); + } + parts.push_back(Part(part_number, std::move(resp.etag))); + } else { + while (size > 0) { + part_number++; + + size_t length = size; + if (length > utils::kMaxPartSize) length = utils::kMaxPartSize; + size_t end_bytes = offset + length - 1; + + utils::Multimap headerscopy; + headerscopy.AddAll(headers); + headerscopy.Add("x-amz-copy-source-range", + "bytes=" + std::to_string(offset) + "-" + + std::to_string(end_bytes)); + + UploadPartCopyArgs upc_args; + upc_args.bucket = args.bucket; + upc_args.region = args.region; + upc_args.object = args.object; + upc_args.headers = headerscopy; + upc_args.upload_id = upload_id; + upc_args.part_number = part_number; + { + UploadPartCopyResponse resp = UploadPartCopy(upc_args); + if (!resp) { + return ComposeObjectResponse(resp); + } + parts.push_back(Part(part_number, std::move(resp.etag))); + } + offset += length; + size -= length; + } + } + } - { - CreateMultipartUploadArgs cmu_args; - cmu_args.extra_query_params = args.extra_query_params; + CompleteMultipartUploadArgs cmu_args; cmu_args.bucket = args.bucket; cmu_args.region = args.region; cmu_args.object = args.object; - cmu_args.headers = headers; - if (CreateMultipartUploadResponse resp = CreateMultipartUpload(cmu_args)) { - upload_id = resp.upload_id; - } else { - return ComposeObjectResponse(resp); - } + cmu_args.upload_id = upload_id; + cmu_args.parts = parts; + return ComposeObjectResponse(CompleteMultipartUpload(cmu_args)); } - unsigned int part_number = 0; - utils::Multimap ssecheaders; - if (args.sse != nullptr) { - if (SseCustomerKey* ssec = dynamic_cast(args.sse)) { - ssecheaders = ssec->Headers(); - } + GetObjectResponse Client::GetObject(GetObjectArgs args) { + return BaseClient::GetObject(args); } - std::list parts; - for (auto& source : args.sources) { - size_t size = source.ObjectSize(); - if (source.length != nullptr) { - size = *source.length; - } else if (source.offset != nullptr) { - size -= *source.offset; + GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { + if (error::Error err = args.Validate()) { + return GetObjectResponse(err); } - size_t offset = 0; - if (source.offset != nullptr) offset = *source.offset; + std::string region; + if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { + region = resp.region; + } else { + return GetObjectResponse(resp); + } - utils::Multimap headers; - headers.AddAll(source.Headers()); - headers.AddAll(ssecheaders); + CUObjIOOps ops = { + .get = objectGet, + .put = objectPut + }; + cuObjClient rdmaclient(ops, CUOBJ_PROTO_RDMA_DC_V1); + + if (rdmaclient.isConnected()) { + int res = rdmaclient.cuMemObjGetDescriptor(args.buf, args.size); + if (res) { + return error::make("unable to register RDMA buffer for object "+ args.object); + } - if (size <= utils::kMaxPartSize) { - part_number++; - if (source.length != nullptr) { - headers.Add("x-amz-copy-source-range", - "bytes=" + std::to_string(offset) + "-" + - std::to_string(offset + *source.length - 1)); - } else if (source.offset != nullptr) { - headers.Add("x-amz-copy-source-range", - "bytes=" + std::to_string(offset) + "-" + - std::to_string(offset + size - 1)); - } - - UploadPartCopyArgs upc_args; - upc_args.bucket = args.bucket; - upc_args.region = args.region; - upc_args.object = args.object; - upc_args.headers = headers; - upc_args.upload_id = upload_id; - upc_args.part_number = part_number; - UploadPartCopyResponse resp = UploadPartCopy(upc_args); - if (!resp) { - return ComposeObjectResponse(resp); + // get the buffer + get operation. + s3_rdma_client_ctx getCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .uploadId = "", + .partNumber = 0, + .etag = "", + .url = base_url_, + .op = CUOBJ_GET, + }; + + ssize_t ret = rdmaclient.cuObjGet(&getCtx, args.buf, args.size); + if (ret < 0) { + rdmaclient.cuMemObjPutDescriptor(args.buf); + return error::make("failed to download to object "+ args.object); } - parts.push_back(Part(part_number, std::move(resp.etag))); - } else { - while (size > 0) { - part_number++; - - size_t length = size; - if (length > utils::kMaxPartSize) length = utils::kMaxPartSize; - size_t end_bytes = offset + length - 1; - - utils::Multimap headerscopy; - headerscopy.AddAll(headers); - headerscopy.Add("x-amz-copy-source-range", - "bytes=" + std::to_string(offset) + "-" + - std::to_string(end_bytes)); - - UploadPartCopyArgs upc_args; - upc_args.bucket = args.bucket; - upc_args.region = args.region; - upc_args.object = args.object; - upc_args.headers = headerscopy; - upc_args.upload_id = upload_id; - upc_args.part_number = part_number; - { - UploadPartCopyResponse resp = UploadPartCopy(upc_args); - if (!resp) { - return ComposeObjectResponse(resp); - } - parts.push_back(Part(part_number, std::move(resp.etag))); - } - offset += length; - size -= length; + + res = rdmaclient.cuMemObjPutDescriptor(args.buf); + if (res) { + return error::make("unable to deregister RDMA buffer for object "+ args.object); } - } - } - CompleteMultipartUploadArgs cmu_args; - cmu_args.bucket = args.bucket; - cmu_args.region = args.region; - cmu_args.object = args.object; - cmu_args.upload_id = upload_id; - cmu_args.parts = parts; - return ComposeObjectResponse(CompleteMultipartUpload(cmu_args)); -} - -PutObjectResponse Client::PutObject(PutObjectArgs args, std::string& upload_id, - char* buf) { - utils::Multimap headers = args.Headers(); - if (!headers.Contains("Content-Type")) { - if (args.content_type.empty()) { - headers.Add("Content-Type", "application/octet-stream"); - } else { - headers.Add("Content-Type", args.content_type); + GetObjectResponse resp; + resp.etag = getCtx.etag; + return resp; } - } - long object_size = args.object_size; - size_t part_size = args.part_size; - size_t uploaded_size = 0; - unsigned int part_number = 0; - std::string one_byte; - bool stop = false; - std::list parts; - long part_count = args.part_count; + GetObjectArgs targs; + std::stringstream ss(std::ios_base::in | std::ios_base::out); + ss.rdbuf()->pubsetbuf(args.buf, args.size); - double uploaded_bytes = 0; // for progress - double upload_speed = -1; // for progress + targs.bucket = args.bucket; + targs.object = args.object; + targs.datafunc = [&ss = ss](minio::http::DataFunctionArgs args) -> bool { + ss << args.datachunk; + return true; + }; - while (!stop) { - part_number++; + return BaseClient::GetObject(targs); + } - size_t bytes_read = 0; - if (part_count > 0) { - if (part_number == part_count) { - part_size = object_size - uploaded_size; - stop = true; - } + PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { + if (error::Error err = args.Validate()) { + return PutObjectResponse(err); + } - if (error::Error err = - utils::ReadPart(args.stream, buf, part_size, bytes_read)) { - return PutObjectResponse(err); + std::string region; + if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { + region = resp.region; + } else { + return PutObjectResponse(resp); + } + + CUObjIOOps ops = { + .get = objectGet, + .put = objectPut + }; + cuObjClient rdmaclient(ops, CUOBJ_PROTO_RDMA_DC_V1); + + if (rdmaclient.isConnected()) { + int res = rdmaclient.cuMemObjGetDescriptor(args.buf, args.size); + if (res) { + return error::make("unable to register RDMA buffer for object "+ args.object); } - if (bytes_read != part_size) { - return error::make( - "not enough data in the stream; expected: " + - std::to_string(part_size) + ", got: " + std::to_string(bytes_read) + - " bytes"); - } - } else { - char* b = buf; - size_t size = part_size + 1; + // put the buffer + put operation. + s3_rdma_client_ctx putCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .uploadId = "", + .partNumber = 0, + .etag = "", + .url = base_url_, + .op = CUOBJ_PUT, + }; - if (!one_byte.empty()) { - buf[0] = one_byte.front(); - b = buf + 1; - size--; - bytes_read = 1; - one_byte = ""; + ssize_t ret = rdmaclient.cuObjPut(&putCtx, args.buf, args.size); + if (ret < 0) { + rdmaclient.cuMemObjPutDescriptor(args.buf); + return error::make("failed to upload to object "+ args.object); } - size_t n = 0; - if (error::Error err = utils::ReadPart(args.stream, b, size, n)) { - return PutObjectResponse(err); + res = rdmaclient.cuMemObjPutDescriptor(args.buf); + if (res) { + return error::make("unable to deregister RDMA buffer for object "+ args.object); } - bytes_read += n; + PutObjectResponse resp; + resp.etag = putCtx.etag; + return resp; + } + + std::stringstream ss(std::ios_base::in | std::ios_base::out); + ss.rdbuf()->pubsetbuf(args.buf, args.size); + + minio::s3::PutObjectArgs aargs(ss, args.size, 16*1024*1024UL); + + return PutObject(aargs); + } - // If bytes read is less than or equals to part size, then we have reached - // last part. - if (bytes_read <= part_size) { - part_count = part_number; - part_size = bytes_read; - stop = true; + PutObjectResponse Client::PutObject(PutObjectArgs args, std::string& upload_id, + char* buf) { + utils::Multimap headers = args.Headers(); + if (!headers.Contains("Content-Type")) { + if (args.content_type.empty()) { + headers.Add("Content-Type", "application/octet-stream"); } else { - one_byte = buf[part_size + 1]; + headers.Add("Content-Type", args.content_type); } } - std::string_view data(buf, part_size); + long object_size = args.object_size; + size_t part_size = args.part_size; + size_t uploaded_size = 0; + unsigned int part_number = 0; + std::string one_byte; + bool stop = false; + std::list parts; + long part_count = args.part_count; + double uploaded_bytes = 0; // for progress + double upload_speed = -1; // for progress + + while (!stop) { + part_number++; - uploaded_size += part_size; + size_t bytes_read = 0; + if (part_count > 0) { + if (part_number == part_count) { + part_size = object_size - uploaded_size; + stop = true; + } + + if (error::Error err = + utils::ReadPart(args.stream, buf, part_size, bytes_read)) { + + return PutObjectResponse(err); + } + + if (bytes_read != part_size) { + return error::make( + "not enough data in the stream; expected: " + + std::to_string(part_size) + ", got: " + std::to_string(bytes_read) + + " bytes"); + } + } else { + char* b = buf; + size_t size = part_size + 1; + + if (!one_byte.empty()) { + buf[0] = one_byte.front(); + b = buf + 1; + size--; + bytes_read = 1; + one_byte = ""; + } + + size_t n = 0; + if (error::Error err = utils::ReadPart(args.stream, b, size, n)) { + return PutObjectResponse(err); + } + + bytes_read += n; + + // If bytes read is less than or equals to part size, then we have reached + // last part. + if (bytes_read <= part_size) { + part_count = part_number; + part_size = bytes_read; + stop = true; + } else { + one_byte = buf[part_size + 1]; + } + } - if (part_count == 1) { - PutObjectApiArgs api_args; - api_args.extra_query_params = args.extra_query_params; - api_args.bucket = args.bucket; - api_args.region = args.region; - api_args.object = args.object; - api_args.data = data; - api_args.progressfunc = args.progressfunc; - api_args.progress_userdata = args.progress_userdata; - api_args.headers = headers; + std::string_view data(buf, part_size); - return BaseClient::PutObject(api_args); - } + uploaded_size += part_size; - if (upload_id.empty()) { - CreateMultipartUploadArgs cmu_args; - cmu_args.extra_query_params = args.extra_query_params; - cmu_args.bucket = args.bucket; - cmu_args.region = args.region; - cmu_args.object = args.object; - cmu_args.headers = headers; - if (CreateMultipartUploadResponse resp = - CreateMultipartUpload(cmu_args)) { - upload_id = resp.upload_id; + if (part_count == 1) { + PutObjectApiArgs api_args; + api_args.extra_query_params = args.extra_query_params; + api_args.bucket = args.bucket; + api_args.region = args.region; + api_args.object = args.object; + api_args.data = data; + api_args.buf = buf; + api_args.size = part_size; + api_args.progressfunc = args.progressfunc; + api_args.progress_userdata = args.progress_userdata; + api_args.headers = headers; + + return BaseClient::PutObject(api_args); + } + + if (upload_id.empty()) { + CreateMultipartUploadArgs cmu_args; + cmu_args.extra_query_params = args.extra_query_params; + cmu_args.bucket = args.bucket; + cmu_args.region = args.region; + cmu_args.object = args.object; + cmu_args.headers = headers; + if (CreateMultipartUploadResponse resp = + CreateMultipartUpload(cmu_args)) { + upload_id = resp.upload_id; + } else { + return PutObjectResponse(resp); + } + } + + UploadPartArgs up_args; + up_args.bucket = args.bucket; + up_args.region = args.region; + up_args.object = args.object; + up_args.upload_id = upload_id; + up_args.part_number = part_number; + up_args.data = data; + up_args.buf = buf; + up_args.part_size = part_size; + if (args.progressfunc != nullptr) { + up_args.progressfunc = + [&object_size = object_size, &uploaded_bytes = uploaded_bytes, + &upload_speed = upload_speed, &progressfunc = args.progressfunc, + &progress_userdata = args.progress_userdata]( + http::ProgressFunctionArgs args) -> bool { + if (args.upload_speed > 0) { + if (upload_speed == -1) { + upload_speed = args.upload_speed; + } else { + upload_speed = (upload_speed + args.upload_speed) / 2; + } + return true; + } + + http::ProgressFunctionArgs actual_args; + actual_args.upload_total_bytes = static_cast(object_size); + actual_args.uploaded_bytes = uploaded_bytes + args.uploaded_bytes; + actual_args.userdata = progress_userdata; + return progressfunc(actual_args); + }; + } + if (args.sse != nullptr) { + if (SseCustomerKey* ssec = dynamic_cast(args.sse)) { + up_args.headers = ssec->Headers(); + } + } + + if (UploadPartResponse resp = UploadPart(up_args)) { + if (args.progressfunc != nullptr) { + uploaded_bytes += static_cast(data.length()); + http::ProgressFunctionArgs actual_args; + actual_args.upload_total_bytes = static_cast(object_size); + actual_args.uploaded_bytes = uploaded_bytes; + actual_args.userdata = args.progress_userdata; + if (!args.progressfunc(actual_args)) { + return UploadPartResponse( + error::Error("aborted by progress function")); + } + } + parts.push_back(Part(part_number, std::move(resp.etag))); } else { - return PutObjectResponse(resp); - } - } - - UploadPartArgs up_args; - up_args.bucket = args.bucket; - up_args.region = args.region; - up_args.object = args.object; - up_args.upload_id = upload_id; - up_args.part_number = part_number; - up_args.data = data; - if (args.progressfunc != nullptr) { - up_args.progressfunc = - [&object_size = object_size, &uploaded_bytes = uploaded_bytes, - &upload_speed = upload_speed, &progressfunc = args.progressfunc, - &progress_userdata = args.progress_userdata]( - http::ProgressFunctionArgs args) -> bool { - if (args.upload_speed > 0) { - if (upload_speed == -1) { - upload_speed = args.upload_speed; - } else { - upload_speed = (upload_speed + args.upload_speed) / 2; - } - return true; - } - - http::ProgressFunctionArgs actual_args; - actual_args.upload_total_bytes = static_cast(object_size); - actual_args.uploaded_bytes = uploaded_bytes + args.uploaded_bytes; - actual_args.userdata = progress_userdata; - return progressfunc(actual_args); - }; - } - if (args.sse != nullptr) { - if (SseCustomerKey* ssec = dynamic_cast(args.sse)) { - up_args.headers = ssec->Headers(); + return resp; } } - if (UploadPartResponse resp = UploadPart(up_args)) { - if (args.progressfunc != nullptr) { - uploaded_bytes += static_cast(data.length()); - http::ProgressFunctionArgs actual_args; - actual_args.upload_total_bytes = static_cast(object_size); - actual_args.uploaded_bytes = uploaded_bytes; - actual_args.userdata = args.progress_userdata; - if (!args.progressfunc(actual_args)) { - return UploadPartResponse( - error::Error("aborted by progress function")); - } - } - parts.push_back(Part(part_number, std::move(resp.etag))); - } else { - return resp; + CompleteMultipartUploadArgs cmu_args; + cmu_args.bucket = args.bucket; + cmu_args.region = args.region; + cmu_args.object = args.object; + cmu_args.upload_id = upload_id; + cmu_args.parts = parts; + CompleteMultipartUploadResponse resp = CompleteMultipartUpload(cmu_args); + if (resp && args.progressfunc != nullptr) { + http::ProgressFunctionArgs actual_args; + actual_args.upload_speed = upload_speed; + actual_args.userdata = args.progress_userdata; + // ignore the return value as we completed the upload + args.progressfunc(actual_args); } + return PutObjectResponse(resp); } - CompleteMultipartUploadArgs cmu_args; - cmu_args.bucket = args.bucket; - cmu_args.region = args.region; - cmu_args.object = args.object; - cmu_args.upload_id = upload_id; - cmu_args.parts = parts; - CompleteMultipartUploadResponse resp = CompleteMultipartUpload(cmu_args); - if (resp && args.progressfunc != nullptr) { - http::ProgressFunctionArgs actual_args; - actual_args.upload_speed = upload_speed; - actual_args.userdata = args.progress_userdata; - // ignore the return value as we completed the upload - args.progressfunc(actual_args); - } - return PutObjectResponse(resp); -} + ComposeObjectResponse Client::ComposeObject(ComposeObjectArgs args) { + if (error::Error err = args.Validate()) { + return ComposeObjectResponse(err); + } -ComposeObjectResponse Client::ComposeObject(ComposeObjectArgs args) { - if (error::Error err = args.Validate()) { - return ComposeObjectResponse(err); - } + if (args.sse != nullptr && args.sse->TlsRequired() && !base_url_.https) { + return error::make( + "SSE operation must be performed over a secure connection"); + } - if (args.sse != nullptr && args.sse->TlsRequired() && !base_url_.https) { - return error::make( - "SSE operation must be performed over a secure connection"); - } + std::string upload_id; + ComposeObjectResponse resp = ComposeObject(args, upload_id); + if (!resp && !upload_id.empty()) { + AbortMultipartUploadArgs amu_args; + amu_args.bucket = args.bucket; + amu_args.region = args.region; + amu_args.object = args.object; + amu_args.upload_id = upload_id; + AbortMultipartUpload(amu_args); + } - std::string upload_id; - ComposeObjectResponse resp = ComposeObject(args, upload_id); - if (!resp && !upload_id.empty()) { - AbortMultipartUploadArgs amu_args; - amu_args.bucket = args.bucket; - amu_args.region = args.region; - amu_args.object = args.object; - amu_args.upload_id = upload_id; - AbortMultipartUpload(amu_args); + return resp; } - return resp; -} + CopyObjectResponse Client::CopyObject(CopyObjectArgs args) { + if (error::Error err = args.Validate()) { + return CopyObjectResponse(err); + } -CopyObjectResponse Client::CopyObject(CopyObjectArgs args) { - if (error::Error err = args.Validate()) { - return CopyObjectResponse(err); - } + if (args.sse != nullptr && args.sse->TlsRequired() && !base_url_.https) { + return error::make( + "SSE operation must be performed over a secure connection"); + } - if (args.sse != nullptr && args.sse->TlsRequired() && !base_url_.https) { - return error::make( - "SSE operation must be performed over a secure connection"); - } + if (args.source.ssec != nullptr && !base_url_.https) { + return error::make( + "SSE-C operation must be performed over a secure connection"); + } - if (args.source.ssec != nullptr && !base_url_.https) { - return error::make( - "SSE-C operation must be performed over a secure connection"); - } + std::string etag; + size_t size; + { + StatObjectResponse resp = StatObject(args.source); + if (!resp) { + return CopyObjectResponse(resp); + } + etag = resp.etag; + size = resp.size; + } - std::string etag; - size_t size; - { - StatObjectResponse resp = StatObject(args.source); - if (!resp) { - return CopyObjectResponse(resp); + if (args.source.offset != nullptr || args.source.length != nullptr || + size > utils::kMaxPartSize) { + if (args.metadata_directive != nullptr && + *args.metadata_directive == Directive::kCopy) { + return error::make( + "COPY metadata directive is not applicable to source object size " + "greater than 5 GiB"); + } + + if (args.tagging_directive != nullptr && + *args.tagging_directive == Directive::kCopy) { + return error::make( + "COPY tagging directive is not applicable to source object size " + "greater than 5 GiB"); + } + + ComposeSource src; + src.extra_headers = args.source.extra_headers; + src.extra_query_params = args.source.extra_query_params; + src.bucket = args.source.bucket; + src.region = args.source.region; + src.object = args.source.object; + src.ssec = args.source.ssec; + src.offset = args.source.offset; + src.length = args.source.length; + src.match_etag = args.source.match_etag; + src.not_match_etag = args.source.not_match_etag; + src.modified_since = args.source.modified_since; + src.unmodified_since = args.source.unmodified_since; + + ComposeObjectArgs coargs; + coargs.extra_headers = args.extra_headers; + coargs.extra_query_params = args.extra_query_params; + coargs.bucket = args.bucket; + coargs.region = args.region; + coargs.object = args.object; + coargs.sse = args.sse; + coargs.sources.push_back(src); + + return CopyObjectResponse(ComposeObject(coargs)); } - etag = resp.etag; - size = resp.size; - } - if (args.source.offset != nullptr || args.source.length != nullptr || - size > utils::kMaxPartSize) { - if (args.metadata_directive != nullptr && - *args.metadata_directive == Directive::kCopy) { - return error::make( - "COPY metadata directive is not applicable to source object size " - "greater than 5 GiB"); + utils::Multimap headers; + headers.AddAll(args.extra_headers); + headers.AddAll(args.Headers()); + if (args.metadata_directive != nullptr) { + headers.Add("x-amz-metadata-directive", + DirectiveToString(*args.metadata_directive)); + } + if (args.tagging_directive != nullptr) { + headers.Add("x-amz-tagging-directive", + DirectiveToString(*args.tagging_directive)); } + headers.AddAll(args.source.CopyHeaders()); - if (args.tagging_directive != nullptr && - *args.tagging_directive == Directive::kCopy) { - return error::make( - "COPY tagging directive is not applicable to source object size " - "greater than 5 GiB"); - } - - ComposeSource src; - src.extra_headers = args.source.extra_headers; - src.extra_query_params = args.source.extra_query_params; - src.bucket = args.source.bucket; - src.region = args.source.region; - src.object = args.source.object; - src.ssec = args.source.ssec; - src.offset = args.source.offset; - src.length = args.source.length; - src.match_etag = args.source.match_etag; - src.not_match_etag = args.source.not_match_etag; - src.modified_since = args.source.modified_since; - src.unmodified_since = args.source.unmodified_since; - - ComposeObjectArgs coargs; - coargs.extra_headers = args.extra_headers; - coargs.extra_query_params = args.extra_query_params; - coargs.bucket = args.bucket; - coargs.region = args.region; - coargs.object = args.object; - coargs.sse = args.sse; - coargs.sources.push_back(src); - - return CopyObjectResponse(ComposeObject(coargs)); - } + std::string region; + if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { + region = resp.region; + } else { + return CopyObjectResponse(resp); + } - utils::Multimap headers; - headers.AddAll(args.extra_headers); - headers.AddAll(args.Headers()); - if (args.metadata_directive != nullptr) { - headers.Add("x-amz-metadata-directive", - DirectiveToString(*args.metadata_directive)); - } - if (args.tagging_directive != nullptr) { - headers.Add("x-amz-tagging-directive", - DirectiveToString(*args.tagging_directive)); - } - headers.AddAll(args.source.CopyHeaders()); + Request req(http::Method::kPut, region, base_url_, args.extra_headers, + args.extra_query_params); + req.bucket_name = args.bucket; + req.object_name = args.object; + req.headers.AddAll(headers); - std::string region; - if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { - region = resp.region; - } else { - return CopyObjectResponse(resp); - } + Response response = Execute(req); + if (!response) { + return CopyObjectResponse(response); + } - Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); - req.bucket_name = args.bucket; - req.object_name = args.object; - req.headers.AddAll(headers); + CopyObjectResponse resp; + resp.etag = utils::Trim(response.headers.GetFront("etag"), '"'); + resp.version_id = response.headers.GetFront("x-amz-version-id"); - Response response = Execute(req); - if (!response) { - return CopyObjectResponse(response); + return resp; } - CopyObjectResponse resp; - resp.etag = utils::Trim(response.headers.GetFront("etag"), '"'); - resp.version_id = response.headers.GetFront("x-amz-version-id"); + DownloadObjectResponse Client::DownloadObject(DownloadObjectArgs args) { + if (error::Error err = args.Validate()) { + return DownloadObjectResponse(err); + } - return resp; -} + if (args.ssec != nullptr && !base_url_.https) { + return error::make( + "SSE-C operation must be performed over a secure connection"); + } -DownloadObjectResponse Client::DownloadObject(DownloadObjectArgs args) { - if (error::Error err = args.Validate()) { - return DownloadObjectResponse(err); - } + std::string etag; + { + StatObjectArgs soargs; + soargs.bucket = args.bucket; + soargs.region = args.region; + soargs.object = args.object; + soargs.version_id = args.version_id; + soargs.ssec = args.ssec; + StatObjectResponse resp = StatObject(soargs); + if (!resp) { + return DownloadObjectResponse(resp); + } + etag = resp.etag; + } - if (args.ssec != nullptr && !base_url_.https) { - return error::make( - "SSE-C operation must be performed over a secure connection"); - } + std::string temp_filename = + args.filename + "." + curlpp::escape(etag) + ".part.minio"; + std::ofstream fout(temp_filename, + std::ios::trunc | std::ios::out | std::ios::binary); + if (!fout.is_open()) { + return error::make("unable to open file " + + temp_filename); + } - std::string etag; - { - StatObjectArgs soargs; - soargs.bucket = args.bucket; - soargs.region = args.region; - soargs.object = args.object; - soargs.version_id = args.version_id; - soargs.ssec = args.ssec; - StatObjectResponse resp = StatObject(soargs); - if (!resp) { + std::string region; + if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { + region = resp.region; + } else { return DownloadObjectResponse(resp); } - etag = resp.etag; - } - std::string temp_filename = - args.filename + "." + curlpp::escape(etag) + ".part.minio"; - std::ofstream fout(temp_filename, - std::ios::trunc | std::ios::out | std::ios::binary); - if (!fout.is_open()) { - return error::make("unable to open file " + - temp_filename); + Request req(http::Method::kGet, region, base_url_, args.extra_headers, + args.extra_query_params); + req.bucket_name = args.bucket; + req.object_name = args.object; + if (!args.version_id.empty()) { + req.query_params.Add("versionId", args.version_id); + } + req.datafunc = [&fout = fout](http::DataFunctionArgs args) -> bool { + fout << args.datachunk; + return true; + }; + req.progressfunc = args.progressfunc; + req.progress_userdata = args.progress_userdata; + + Response response = Execute(req); + fout.close(); + if (response) { + std::filesystem::rename(temp_filename, args.filename); + } + return DownloadObjectResponse(response); } - std::string region; - if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { - region = resp.region; - } else { - return DownloadObjectResponse(resp); + ListObjectsResult Client::ListObjects(ListObjectsArgs args) { + if (error::Error err = args.Validate()) { + return ListObjectsResult(err); + } + return ListObjectsResult(this, std::move(args)); } - Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); - req.bucket_name = args.bucket; - req.object_name = args.object; - if (!args.version_id.empty()) { - req.query_params.Add("versionId", args.version_id); - } - req.datafunc = [&fout = fout](http::DataFunctionArgs args) -> bool { - fout << args.datachunk; - return true; - }; - req.progressfunc = args.progressfunc; - req.progress_userdata = args.progress_userdata; - - Response response = Execute(req); - fout.close(); - if (response) { - std::filesystem::rename(temp_filename, args.filename); - } - return DownloadObjectResponse(response); -} + PutObjectResponse Client::PutObject(PutObjectArgs args) { + if (error::Error err = args.Validate()) { + return PutObjectResponse(err); + } -ListObjectsResult Client::ListObjects(ListObjectsArgs args) { - if (error::Error err = args.Validate()) { - return ListObjectsResult(err); - } - return ListObjectsResult(this, std::move(args)); -} + if (args.sse != nullptr && args.sse->TlsRequired() && !base_url_.https) { + return error::make( + "SSE operation must be performed over a secure connection"); + } -PutObjectResponse Client::PutObject(PutObjectArgs args) { - if (error::Error err = args.Validate()) { - return PutObjectResponse(err); - } + char *buf; + int res = posix_memalign((void **)&buf, getpagesize(), (args.part_count > 0) ? args.part_size : args.part_size + 1); + if (res) { + return error::make("unable to allocate system memory with alignment"); + } - if (args.sse != nullptr && args.sse->TlsRequired() && !base_url_.https) { - return error::make( - "SSE operation must be performed over a secure connection"); - } + CUObjIOOps ops = { + .get = objectGet, + .put = objectPut + }; + std::unique_ptr rdmaclient(new cuObjClient(ops, CUOBJ_PROTO_RDMA_DC_V1)); + + if (rdmaclient->isConnected()) { + res = rdmaclient->cuMemObjGetDescriptor(buf, args.part_size); + if (res) { + free(buf); + return error::make("unable to register RDMA buffer"); + } + } - std::string upload_id; - auto buf = std::make_unique( - (args.part_count > 0) ? args.part_size : args.part_size + 1); - PutObjectResponse resp = PutObject(args, upload_id, buf.get()); - buf.reset(); - - if (!resp && !upload_id.empty()) { - AbortMultipartUploadArgs amu_args; - amu_args.bucket = std::move(args.bucket); - amu_args.region = std::move(args.region); - amu_args.object = std::move(args.object); - amu_args.upload_id = upload_id; - AbortMultipartUpload(amu_args); - } + std::string upload_id; + args.rdmaclient = rdmaclient.get(); + PutObjectResponse resp = PutObject(args, upload_id, buf); + + if (!resp && !upload_id.empty()) { + AbortMultipartUploadArgs amu_args; + amu_args.bucket = std::move(args.bucket); + amu_args.region = std::move(args.region); + amu_args.object = std::move(args.object); + amu_args.upload_id = upload_id; + AbortMultipartUpload(amu_args); + } - return resp; -} + if (rdmaclient->isConnected()) { + res = rdmaclient->cuMemObjPutDescriptor(buf); + if (res) { + free(buf); + return error::make("unable to deregister RDMA buffer"); + } + } -UploadObjectResponse Client::UploadObject(UploadObjectArgs args) { - if (error::Error err = args.Validate()) { - return UploadObjectResponse(err); + free(buf); + return resp; } - std::ifstream file; - file.exceptions(std::ifstream::failbit | std::ifstream::badbit); - try { - file.open(args.filename, std::ios::binary); - } catch (std::system_error& err) { - return error::make( - "unable to open file " + args.filename + "; " + err.code().message()); - } + UploadObjectResponse Client::UploadObject(UploadObjectArgs args) { + if (error::Error err = args.Validate()) { + return UploadObjectResponse(err); + } - PutObjectArgs po_args(file, args.object_size, 0); - po_args.extra_headers = std::move(args.extra_headers); - po_args.extra_query_params = std::move(args.extra_query_params); - po_args.bucket = std::move(args.bucket); - po_args.region = std::move(args.region); - po_args.object = std::move(args.object); - po_args.headers = std::move(args.headers); - po_args.user_metadata = std::move(args.user_metadata); - po_args.sse = std::move(args.sse); - po_args.tags = std::move(args.tags); - po_args.retention = std::move(args.retention); - po_args.legal_hold = std::move(args.legal_hold); - po_args.content_type = std::move(args.content_type); - po_args.progressfunc = std::move(args.progressfunc); - po_args.progress_userdata = std::move(args.progress_userdata); - - PutObjectResponse resp = PutObject(std::move(po_args)); - file.close(); - return UploadObjectResponse(resp); -} - -RemoveObjectsResult Client::RemoveObjects(RemoveObjectsArgs args) { - if (error::Error err = args.Validate()) { - return RemoveObjectsResult(err); + std::ifstream file; + file.exceptions(std::ifstream::failbit | std::ifstream::badbit); + try { + file.open(args.filename); + } catch (std::system_error& err) { + return error::make( + "unable to open file " + args.filename + "; " + err.code().message()); + } + + PutObjectArgs po_args(file, args.object_size, 0); + po_args.extra_headers = std::move(args.extra_headers); + po_args.extra_query_params = std::move(args.extra_query_params); + po_args.bucket = std::move(args.bucket); + po_args.region = std::move(args.region); + po_args.object = std::move(args.object); + po_args.headers = std::move(args.headers); + po_args.user_metadata = std::move(args.user_metadata); + po_args.sse = std::move(args.sse); + po_args.tags = std::move(args.tags); + po_args.retention = std::move(args.retention); + po_args.legal_hold = std::move(args.legal_hold); + po_args.content_type = std::move(args.content_type); + po_args.progressfunc = std::move(args.progressfunc); + po_args.progress_userdata = std::move(args.progress_userdata); + + PutObjectResponse resp = PutObject(std::move(po_args)); + file.close(); + return UploadObjectResponse(resp); + } + + RemoveObjectsResult Client::RemoveObjects(RemoveObjectsArgs args) { + if (error::Error err = args.Validate()) { + return RemoveObjectsResult(err); + } + return RemoveObjectsResult(this, std::move(args)); } - return RemoveObjectsResult(this, std::move(args)); -} } // namespace minio::s3 diff --git a/src/response.cc b/src/response.cc index 387c8440..a778e6eb 100644 --- a/src/response.cc +++ b/src/response.cc @@ -42,13 +42,13 @@ error::Error Response::Error() const { } if (status_code && (status_code < 200 || status_code > 299)) { return error::Error("failed with HTTP status code " + - std::to_string(status_code)); + std::to_string(status_code)); } return error::SUCCESS; } Response Response::ParseXML(std::string_view data, int status_code, - utils::Multimap headers) { + utils::Multimap headers) { Response resp; resp.status_code = status_code; resp.headers = headers; @@ -124,6 +124,7 @@ CompleteMultipartUploadResponse CompleteMultipartUploadResponse::ParseXML( return error::make("unable to parse XML"); } auto root = xdoc.select_node("/CompleteMultipartUploadResult"); + pugi::xpath_node text; text = root.node().select_node("Bucket/text()"); @@ -156,7 +157,7 @@ CompleteMultipartUploadResponse CompleteMultipartUploadResponse::ParseXML( } ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, - bool version) { + bool version) { ListObjectsResponse resp; pugi::xml_document xdoc; @@ -197,12 +198,12 @@ ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, text = root.node().select_node("Marker/text()"); value = text.node().value(); resp.marker = - (resp.encoding_type == "url") ? curlpp::unescape(value) : value; + (resp.encoding_type == "url") ? curlpp::unescape(value) : value; text = root.node().select_node("NextMarker/text()"); value = text.node().value(); resp.next_marker = - (resp.encoding_type == "url") ? curlpp::unescape(value) : value; + (resp.encoding_type == "url") ? curlpp::unescape(value) : value; } // ListBucketResult V2 @@ -215,7 +216,7 @@ ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, text = root.node().select_node("StartAfter/text()"); value = text.node().value(); resp.start_after = - (resp.encoding_type == "url") ? curlpp::unescape(value) : value; + (resp.encoding_type == "url") ? curlpp::unescape(value) : value; text = root.node().select_node("ContinuationToken/text()"); resp.continuation_token = text.node().value(); @@ -229,12 +230,12 @@ ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, text = root.node().select_node("KeyMarker/text()"); value = text.node().value(); resp.key_marker = - (resp.encoding_type == "url") ? curlpp::unescape(value) : value; + (resp.encoding_type == "url") ? curlpp::unescape(value) : value; text = root.node().select_node("NextKeyMarker/text()"); value = text.node().value(); resp.next_key_marker = - (resp.encoding_type == "url") ? curlpp::unescape(value) : value; + (resp.encoding_type == "url") ? curlpp::unescape(value) : value; text = root.node().select_node("VersionIdMarker/text()"); resp.version_id_marker = text.node().value(); @@ -246,8 +247,8 @@ ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, Item last_item; auto populate = [&resp = resp, &last_item = last_item]( - std::list& items, pugi::xpath_node_set& contents, - bool is_delete_marker) -> void { + std::list& items, pugi::xpath_node_set& contents, + bool is_delete_marker) -> void { for (auto content : contents) { pugi::xpath_node text; std::string value; @@ -259,7 +260,7 @@ ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, text = content.node().select_node("Key/text()"); value = text.node().value(); item.name = - (resp.encoding_type == "url") ? curlpp::unescape(value) : value; + (resp.encoding_type == "url") ? curlpp::unescape(value) : value; text = content.node().select_node("LastModified/text()"); value = text.node().value(); @@ -287,8 +288,8 @@ ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, auto user_metadata = content.node().select_node("UserMetadata"); for (auto metadata = user_metadata.node().first_child(); metadata; - metadata = metadata.next_sibling()) { - item.user_metadata[metadata.name()] = metadata.child_value(); + metadata = metadata.next_sibling()) { + item.user_metadata[metadata.name()] = metadata.child_value(); } item.is_delete_marker = is_delete_marker; @@ -404,17 +405,17 @@ GetBucketNotificationResponse GetBucketNotificationResponse::ParseXML( if (common.node().select_node("Filter")) { auto filters = common.node().select_nodes("Filter/S3Key/FilterRule"); for (auto filter : filters) { - text = filter.node().select_node("Name/text()"); - auto name = text.node().value(); + text = filter.node().select_node("Name/text()"); + auto name = text.node().value(); - text = filter.node().select_node("Value/text()"); - auto value = text.node().value(); + text = filter.node().select_node("Value/text()"); + auto value = text.node().value(); - if (strcmp(name, "prefix") == 0) { - cfg.prefix_filter_rule = PrefixFilterRule(value); - } else { - cfg.suffix_filter_rule = SuffixFilterRule(value); - } + if (strcmp(name, "prefix") == 0) { + cfg.prefix_filter_rule = PrefixFilterRule(value); + } else { + cfg.suffix_filter_rule = SuffixFilterRule(value); + } } } @@ -541,27 +542,27 @@ GetBucketReplicationResponse GetBucketReplicationResponse::ParseXML( if (destination.node().select_node("AccessControlTranslation")) { rrule.destination.access_control_translation.Enable(); text = destination.node().select_node( - "AccessControlTranslation/Owner/text()"); + "AccessControlTranslation/Owner/text()"); rrule.destination.access_control_translation.owner = text.node().value(); } if (destination.node().select_node("EncryptionConfiguration")) { rrule.destination.encryption_config.Enable(); text = destination.node().select_node( - "EncryptionConfiguration/ReplicaKmsKeyID/text()"); + "EncryptionConfiguration/ReplicaKmsKeyID/text()"); rrule.destination.encryption_config.replica_kms_key_id = - text.node().value(); + text.node().value(); } if (destination.node().select_node("Metrics")) { rrule.destination.metrics.Enable(); text = destination.node().select_node( - "Metrics/EventThreshold/Minutes/text()"); + "Metrics/EventThreshold/Minutes/text()"); value = text.node().value(); rrule.destination.metrics.event_threshold_minutes = - static_cast(std::stoul(value)); + static_cast(std::stoul(value)); text = destination.node().select_node( - "Metrics/EventThreshold/Status/text()"); + "Metrics/EventThreshold/Status/text()"); value = text.node().value(); rrule.destination.metrics.status = (value == "Enabled"); } @@ -571,7 +572,7 @@ GetBucketReplicationResponse GetBucketReplicationResponse::ParseXML( text = destination.node().select_node("ReplicationTime/Time/text()"); value = text.node().value(); rrule.destination.replication_time.time_minutes = - static_cast(std::stoul(value)); + static_cast(std::stoul(value)); text = destination.node().select_node("ReplicationTime/Status/text()"); value = text.node().value(); @@ -594,37 +595,37 @@ GetBucketReplicationResponse GetBucketReplicationResponse::ParseXML( auto filter = rule.node().select_node("Filter"); if (filter.node().select_node("And")) { - if (filter.node().select_node("And/Prefix")) { - text = filter.node().select_node("And/Prefix/text()"); - rrule.filter.and_operator.prefix = Prefix(text.node().value()); - } - - if (filter.node().select_node("And/Tag")) { - auto tags = root.node().select_nodes("And/Tag"); - for (auto& tag : tags) { - (void)tag; - text = filter.node().select_node("Key/text()"); - std::string key = text.node().value(); - - text = filter.node().select_node("Value/text()"); - std::string value = text.node().value(); - - rrule.filter.and_operator.tags[key] = value; - } - } + if (filter.node().select_node("And/Prefix")) { + text = filter.node().select_node("And/Prefix/text()"); + rrule.filter.and_operator.prefix = Prefix(text.node().value()); + } + + if (filter.node().select_node("And/Tag")) { + auto tags = root.node().select_nodes("And/Tag"); + for (auto& tag : tags) { + (void)tag; + text = filter.node().select_node("Key/text()"); + std::string key = text.node().value(); + + text = filter.node().select_node("Value/text()"); + std::string value = text.node().value(); + + rrule.filter.and_operator.tags[key] = value; + } + } } if (filter.node().select_node("Prefix")) { - text = filter.node().select_node("Prefix/text()"); - rrule.filter.prefix = Prefix(text.node().value()); + text = filter.node().select_node("Prefix/text()"); + rrule.filter.prefix = Prefix(text.node().value()); } if (filter.node().select_node("Tag")) { - text = filter.node().select_node("Tag/Key/text()"); - rrule.filter.tag.key = text.node().value(); + text = filter.node().select_node("Tag/Key/text()"); + rrule.filter.tag.key = text.node().value(); - text = filter.node().select_node("Tag/Value/text()"); - rrule.filter.tag.value = text.node().value(); + text = filter.node().select_node("Tag/Value/text()"); + rrule.filter.tag.value = text.node().value(); } } @@ -642,12 +643,12 @@ GetBucketReplicationResponse GetBucketReplicationResponse::ParseXML( if (rule.node().select_node("SourceSelectionCriteria")) { rrule.source_selection_criteria.Enable(); if (rule.node().select_node( - "SourceSelectionCriteria/SseKmsEncryptedObjects")) { - text = rule.node().select_node( - "SourceSelectionCriteria/SseKmsEncryptedObjects/Status/text()"); - value = text.node().value(); - rrule.source_selection_criteria.sse_kms_encrypted_objects_status = - (value == "Enabled"); + "SourceSelectionCriteria/SseKmsEncryptedObjects")) { + text = rule.node().select_node( + "SourceSelectionCriteria/SseKmsEncryptedObjects/Status/text()"); + value = text.node().value(); + rrule.source_selection_criteria.sse_kms_encrypted_objects_status = + (value == "Enabled"); } } @@ -683,52 +684,52 @@ GetBucketLifecycleResponse GetBucketLifecycleResponse::ParseXML( if (rule.node().select_node("AbortIncompleteMultipartUpload")) { text = rule.node().select_node( - "AbortIncompleteMultipartUpload/DaysAfterInitiation/text()"); + "AbortIncompleteMultipartUpload/DaysAfterInitiation/text()"); value = text.node().value(); lrule.abort_incomplete_multipart_upload_days_after_initiation = - std::stoi(value); + std::stoi(value); } if (rule.node().select_node("Expiration")) { if (rule.node().select_node("Expiration/Date")) { - text = rule.node().select_node("Expiration/Date/text()"); - lrule.expiration_date = - utils::UtcTime::FromISO8601UTC(text.node().value()); + text = rule.node().select_node("Expiration/Date/text()"); + lrule.expiration_date = + utils::UtcTime::FromISO8601UTC(text.node().value()); } if (rule.node().select_node("Expiration/Days")) { - text = rule.node().select_node("Expiration/Days/text()"); - value = text.node().value(); - lrule.expiration_days = std::stoi(value); + text = rule.node().select_node("Expiration/Days/text()"); + value = text.node().value(); + lrule.expiration_days = std::stoi(value); } if (rule.node().select_node("Expiration/ExpiredObjectDeleteMarker")) { - text = rule.node().select_node( - "Expiration/ExpiredObjectDeleteMarker/text()"); - lrule.expiration_expired_object_delete_marker = - utils::BoolToString(text.node().value()); + text = rule.node().select_node( + "Expiration/ExpiredObjectDeleteMarker/text()"); + lrule.expiration_expired_object_delete_marker = + utils::BoolToString(text.node().value()); } } auto filter = rule.node().select_node("Filter"); if (filter.node().select_node("And")) { if (filter.node().select_node("And/Prefix")) { - text = filter.node().select_node("And/Prefix/text()"); - lrule.filter.and_operator.prefix = Prefix(text.node().value()); + text = filter.node().select_node("And/Prefix/text()"); + lrule.filter.and_operator.prefix = Prefix(text.node().value()); } if (filter.node().select_node("And/Tag")) { - auto tags = root.node().select_nodes("And/Tag"); - for (auto& tag : tags) { - (void)tag; - text = filter.node().select_node("Key/text()"); - std::string key = text.node().value(); + auto tags = root.node().select_nodes("And/Tag"); + for (auto& tag : tags) { + (void)tag; + text = filter.node().select_node("Key/text()"); + std::string key = text.node().value(); - text = filter.node().select_node("Value/text()"); - std::string value = text.node().value(); + text = filter.node().select_node("Value/text()"); + std::string value = text.node().value(); - lrule.filter.and_operator.tags[key] = value; - } + lrule.filter.and_operator.tags[key] = value; + } } } if (filter.node().select_node("Prefix")) { @@ -748,19 +749,19 @@ GetBucketLifecycleResponse GetBucketLifecycleResponse::ParseXML( if (rule.node().select_node("NoncurrentVersionExpiration")) { text = rule.node().select_node( - "NoncurrentVersionExpiration/NoncurrentDays/text()"); + "NoncurrentVersionExpiration/NoncurrentDays/text()"); value = text.node().value(); lrule.noncurrent_version_expiration_noncurrent_days = std::stoi(value); } if (rule.node().select_node("NoncurrentVersionTransition")) { text = rule.node().select_node( - "NoncurrentVersionTransition/NoncurrentDays/text()"); + "NoncurrentVersionTransition/NoncurrentDays/text()"); value = text.node().value(); lrule.noncurrent_version_transition_noncurrent_days = std::stoi(value); text = rule.node().select_node( - "NoncurrentVersionTransition/StorageClass/text()"); + "NoncurrentVersionTransition/StorageClass/text()"); lrule.noncurrent_version_transition_storage_class = text.node().value(); } @@ -770,15 +771,15 @@ GetBucketLifecycleResponse GetBucketLifecycleResponse::ParseXML( if (rule.node().select_node("Transition")) { if (rule.node().select_node("Transition/Date")) { - text = rule.node().select_node("Transition/Date/text()"); - lrule.transition_date = - utils::UtcTime::FromISO8601UTC(text.node().value()); + text = rule.node().select_node("Transition/Date/text()"); + lrule.transition_date = + utils::UtcTime::FromISO8601UTC(text.node().value()); } if (rule.node().select_node("Transition/Days")) { - text = rule.node().select_node("Transition/Days/text()"); - value = text.node().value(); - lrule.transition_days = std::stoi(value); + text = rule.node().select_node("Transition/Days/text()"); + value = text.node().value(); + lrule.transition_days = std::stoi(value); } text = rule.node().select_node("Transition/StorageClass/text()"); diff --git a/src/utils.cc b/src/utils.cc index 70b62bda..9a1c4cea 100644 --- a/src/utils.cc +++ b/src/utils.cc @@ -648,7 +648,7 @@ error::Error CalcPartInfo(long object_size, size_t& part_size, } if (part_size <= 0) { - // Calculate part size by multiple of kMinPartSize. + // Calculate part size by multiple of kOptPartSize. double psize = std::ceil((double)object_size / kMaxMultipartCount); part_size = (size_t)std::ceil(psize / kMinPartSize) * kMinPartSize; } From 576c1522ab06420fd2c1cca7e201ca52d30a135a Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Mon, 12 Jan 2026 13:22:29 -0800 Subject: [PATCH 02/25] Fix C++ issues in RDMA support - Use std::optional for RDMA args size field instead of -1 sentinel - Add region field to s3_rdma_client_ctx and pass resolved region - Add null pointer checks for rdmaclient before dereferencing - Add exception safety with try-catch for std::stoi/stoll in RDMA callbacks - Add [[maybe_unused]] attribute for unused offset parameter in callbacks - Fix pugixml set_value() to use c_str() for compatibility - Add cudart linking for CUDA examples - Use cuda_runtime.h instead of cuda.h in GetPutRDMA example --- CLAUDE.md | 6 +++ CMakeLists.txt | 4 ++ examples/GetPutRDMA.cc | 2 +- include/miniocpp/args.h | 11 +++--- include/miniocpp/nvidia-cuobjclient.h | 1 + include/miniocpp/rdma.h | 56 ++++++++++++++++----------- src/args.cc | 6 +++ src/baseclient.cc | 54 +++++++++++++++----------- src/client.cc | 22 +++++++---- src/utils.cc | 2 +- 10 files changed, 103 insertions(+), 61 deletions(-) diff --git a/CLAUDE.md b/CLAUDE.md index 9c3842be..630a24e1 100644 --- a/CLAUDE.md +++ b/CLAUDE.md @@ -86,3 +86,9 @@ The RDMA implementation uses `objectPut`/`objectGet` callbacks that are invoked - pugixml - XML parsing for S3 responses Additional system dependencies for RDMA: libcufile, libcuobjclient, libibverbs, librdmacm + +## Code Style Guidelines + +- Do not add obvious comments (e.g., "Safe: Validate() ensures X has value") +- Use `std::optional` for values that may be uninitialized (not sentinel values like `-1` for unsigned types) +- RDMA buffers require page-aligned memory - use `posix_memalign` or `std::aligned_alloc` (C++17) diff --git a/CMakeLists.txt b/CMakeLists.txt index 49449497..cffd77bd 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -216,6 +216,10 @@ if (MINIO_CPP_TEST) target_link_libraries(${target} PRIVATE miniocpp::miniocpp ${MINIO_CPP_LIBS}) endforeach() + # CUDA examples need cudart + target_link_libraries(GetPutRDMA PRIVATE cudart) + target_link_libraries(GPUHostDisk PRIVATE cudart) + add_executable(tests tests/tests.cc) target_compile_features(tests PUBLIC cxx_std_${MINIO_CPP_STD}) target_include_directories(tests PRIVATE ${CMAKE_CURRENT_LIST_DIR}/include) diff --git a/examples/GetPutRDMA.cc b/examples/GetPutRDMA.cc index 2f499568..b05ca6ba 100644 --- a/examples/GetPutRDMA.cc +++ b/examples/GetPutRDMA.cc @@ -18,7 +18,7 @@ #include #include #include -#include +#include #include #include #include diff --git a/include/miniocpp/args.h b/include/miniocpp/args.h index 18d0453d..3c02c768 100644 --- a/include/miniocpp/args.h +++ b/include/miniocpp/args.h @@ -21,6 +21,7 @@ #include #include #include +#include #include #include @@ -223,9 +224,9 @@ struct GetObjectArgs : public ObjectConditionalReadArgs { }; // struct GetObjectArgs struct GetObjectRDMAArgs : public GetObjectArgs { - char *buf; - size_t size = -1; - + char *buf = nullptr; + std::optional size; + GetObjectRDMAArgs() = default; ~GetObjectRDMAArgs() = default; @@ -342,8 +343,8 @@ struct PutObjectArgs : public PutObjectBaseArgs { }; // struct PutObjectArgs struct PutObjectRDMAArgs : public PutObjectBaseArgs { - char *buf; - size_t size = -1; + char *buf = nullptr; + std::optional size; PutObjectRDMAArgs() = default; ~PutObjectRDMAArgs() = default; diff --git a/include/miniocpp/nvidia-cuobjclient.h b/include/miniocpp/nvidia-cuobjclient.h index 364d6516..b8bd3cf4 100644 --- a/include/miniocpp/nvidia-cuobjclient.h +++ b/include/miniocpp/nvidia-cuobjclient.h @@ -230,6 +230,7 @@ typedef struct s3_rdma_client_ctx { size_t partNumber; std::string etag; minio::s3::BaseUrl url; + std::string region; cuObjOpType_t op; } s3_rdma_client_ctx_t; diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h index 0709a61e..8d8f6ac2 100644 --- a/include/miniocpp/rdma.h +++ b/include/miniocpp/rdma.h @@ -46,7 +46,7 @@ inline constexpr int kRDMAReplyNotImplemented = 501; // These functions are invoked by cufile rdma layer either user shadow pages or direct gpu va address // depending on whether nvidia-fs driver or nv peer mem is present -inline static ssize_t objectPut(const void *handle, const char* buf, size_t size, loff_t offset, const cufileRDMAInfo_t *infop) +inline static ssize_t objectPut(const void *handle, const char* buf, size_t size, [[maybe_unused]] loff_t offset, const cufileRDMAInfo_t *infop) { void *ctx = cuObjClient::getCtx(handle); s3_rdma_client_ctx_t *sctx = static_cast(ctx); @@ -64,10 +64,10 @@ inline static ssize_t objectPut(const void *handle, const char* buf, size_t size minio::utils::UtcTime date = minio::utils::UtcTime::Now(); minio::creds::Credentials creds = sctx->provider->Fetch(); - minio::utils::Multimap query_params; + minio::utils::Multimap query_params; minio::http::Url url; - std::string region = "us-east-1"; - + const std::string& region = sctx->region; + if (sctx->uploadId != "") { query_params.Add("uploadId", sctx->uploadId); if (sctx->partNumber == 0) { @@ -151,9 +151,14 @@ inline static ssize_t objectPut(const void *handle, const char* buf, size_t size return -2; } - int reply_code = std::stoi(rdma_reply); - if (reply_code != kRDMAReplySuccess && reply_code != kRDMAReplyNoContent) { - std::cerr << "Unexpected RDMA reply: " << reply_code << std::endl; + try { + int reply_code = std::stoi(rdma_reply); + if (reply_code != kRDMAReplySuccess && reply_code != kRDMAReplyNoContent) { + std::cerr << "Unexpected RDMA reply: " << reply_code << std::endl; + return -1; + } + } catch (const std::exception& e) { + std::cerr << "Invalid RDMA reply format: " << rdma_reply << std::endl; return -1; } @@ -161,7 +166,7 @@ inline static ssize_t objectPut(const void *handle, const char* buf, size_t size return size; } -inline static ssize_t objectGet(const void *handle, char* buf, size_t size, loff_t offset, const cufileRDMAInfo_t *infop) +inline static ssize_t objectGet(const void *handle, char* buf, size_t size, [[maybe_unused]] loff_t offset, const cufileRDMAInfo_t *infop) { void *ctx = cuObjClient::getCtx(handle); s3_rdma_client_ctx_t *sctx = static_cast(ctx); @@ -179,10 +184,10 @@ inline static ssize_t objectGet(const void *handle, char* buf, size_t size, loff minio::utils::UtcTime date = minio::utils::UtcTime::Now(); minio::creds::Credentials creds = sctx->provider->Fetch(); - minio::utils::Multimap query_params; + minio::utils::Multimap query_params; minio::http::Url url; - std::string region = "us-east-1"; - + const std::string& region = sctx->region; + if (minio::error::Error err = sctx->url.BuildUrl(url, minio::http::Method::kGet, region, query_params, sctx->bucket, sctx->object)) { @@ -240,20 +245,25 @@ inline static ssize_t objectGet(const void *handle, char* buf, size_t size, loff return -2; } - int reply_code = std::stoi(rdma_reply); - if (reply_code != kRDMAReplySuccess && reply_code != kRDMAReplyPartialContent) { - std::cerr << "Unexpected RDMA reply: " << reply_code << std::endl; - return -1; - } + try { + int reply_code = std::stoi(rdma_reply); + if (reply_code != kRDMAReplySuccess && reply_code != kRDMAReplyPartialContent) { + std::cerr << "Unexpected RDMA reply: " << reply_code << std::endl; + return -1; + } - // Verify bytes transferred per spec - std::string bytes_str = res->get_header_value(kAmzRDMABytesTransferred); - if (!bytes_str.empty()) { - ssize_t bytes_transferred = std::stoll(bytes_str); - if (bytes_transferred != static_cast(size)) { - std::cerr << "RDMA bytes mismatch: expected " << size - << ", got " << bytes_transferred << std::endl; + // Verify bytes transferred per spec + std::string bytes_str = res->get_header_value(kAmzRDMABytesTransferred); + if (!bytes_str.empty()) { + ssize_t bytes_transferred = std::stoll(bytes_str); + if (bytes_transferred != static_cast(size)) { + std::cerr << "RDMA bytes mismatch: expected " << size + << ", got " << bytes_transferred << std::endl; + } } + } catch (const std::exception& e) { + std::cerr << "Invalid RDMA reply format: " << rdma_reply << std::endl; + return -1; } return size; diff --git a/src/args.cc b/src/args.cc index 94d286dc..d7678b33 100644 --- a/src/args.cc +++ b/src/args.cc @@ -228,6 +228,9 @@ error::Error GetObjectRDMAArgs::Validate() const { if (!this->buf) { return error::Error("buffer must be set"); } + if (!this->size.has_value()) { + return error::Error("size must be set"); + } return error::SUCCESS; } @@ -236,6 +239,9 @@ error::Error PutObjectRDMAArgs::Validate() const { if (!this->buf) { return error::Error("buffer must be set"); } + if (!this->size.has_value()) { + return error::Error("size must be set"); + } return error::SUCCESS; } diff --git a/src/baseclient.cc b/src/baseclient.cc index 687b6531..c723859b 100644 --- a/src/baseclient.cc +++ b/src/baseclient.cc @@ -1371,28 +1371,28 @@ PutObjectResponse BaseClient::PutObject(PutObjectApiArgs args) { return PutObjectResponse(resp); } - if (args.rdmaclient->isConnected()) { - // put the buffer + put operation. - // send the buffer + put operation. - s3_rdma_client_ctx putCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .uploadId = "", - .partNumber = 0, - .etag = "", - .url = base_url_, - .op = CUOBJ_PUT, - }; - - ssize_t ret = args.rdmaclient->cuObjPut(&putCtx, args.buf, args.size); - if (ret < 0) { - return error::make("failed to upload the object "+ args.object); - } + if (args.rdmaclient != nullptr && args.rdmaclient->isConnected()) { + // send the buffer + put operation via RDMA. + s3_rdma_client_ctx putCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .uploadId = "", + .partNumber = 0, + .etag = "", + .url = base_url_, + .region = region, + .op = CUOBJ_PUT, + }; + + ssize_t ret = args.rdmaclient->cuObjPut(&putCtx, args.buf, args.size); + if (ret < 0) { + return error::make("failed to upload the object "+ args.object); + } - PutObjectResponse resp; - resp.etag = putCtx.etag; - return resp; + PutObjectResponse resp; + resp.etag = putCtx.etag; + return resp; } Request req(http::Method::kPut, region, base_url_, args.extra_headers, @@ -1946,8 +1946,15 @@ UploadPartResponse BaseClient::UploadPart(UploadPartArgs args) { return UploadPartResponse(err); } - if (args.rdmaclient->isConnected()) { - // put the buffer + put operation. + if (args.rdmaclient != nullptr && args.rdmaclient->isConnected()) { + std::string region; + if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { + region = resp.region; + } else { + return UploadPartResponse(resp); + } + + // send the buffer + put operation via RDMA. s3_rdma_client_ctx putCtx = { .provider = provider_, .bucket = args.bucket, @@ -1956,6 +1963,7 @@ UploadPartResponse BaseClient::UploadPart(UploadPartArgs args) { .partNumber = args.part_number, .etag = "", .url = base_url_, + .region = region, .op = CUOBJ_PUT, }; diff --git a/src/client.cc b/src/client.cc index 126878d3..44a1bc65 100644 --- a/src/client.cc +++ b/src/client.cc @@ -391,8 +391,10 @@ namespace minio::s3 { }; cuObjClient rdmaclient(ops, CUOBJ_PROTO_RDMA_DC_V1); + const size_t size = *args.size; + if (rdmaclient.isConnected()) { - int res = rdmaclient.cuMemObjGetDescriptor(args.buf, args.size); + int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); if (res) { return error::make("unable to register RDMA buffer for object "+ args.object); } @@ -406,10 +408,11 @@ namespace minio::s3 { .partNumber = 0, .etag = "", .url = base_url_, + .region = region, .op = CUOBJ_GET, }; - ssize_t ret = rdmaclient.cuObjGet(&getCtx, args.buf, args.size); + ssize_t ret = rdmaclient.cuObjGet(&getCtx, args.buf, size); if (ret < 0) { rdmaclient.cuMemObjPutDescriptor(args.buf); return error::make("failed to download to object "+ args.object); @@ -427,7 +430,7 @@ namespace minio::s3 { GetObjectArgs targs; std::stringstream ss(std::ios_base::in | std::ios_base::out); - ss.rdbuf()->pubsetbuf(args.buf, args.size); + ss.rdbuf()->pubsetbuf(args.buf, size); targs.bucket = args.bucket; targs.object = args.object; @@ -456,9 +459,11 @@ namespace minio::s3 { .put = objectPut }; cuObjClient rdmaclient(ops, CUOBJ_PROTO_RDMA_DC_V1); - + + const size_t size = *args.size; + if (rdmaclient.isConnected()) { - int res = rdmaclient.cuMemObjGetDescriptor(args.buf, args.size); + int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); if (res) { return error::make("unable to register RDMA buffer for object "+ args.object); } @@ -472,10 +477,11 @@ namespace minio::s3 { .partNumber = 0, .etag = "", .url = base_url_, + .region = region, .op = CUOBJ_PUT, }; - ssize_t ret = rdmaclient.cuObjPut(&putCtx, args.buf, args.size); + ssize_t ret = rdmaclient.cuObjPut(&putCtx, args.buf, size); if (ret < 0) { rdmaclient.cuMemObjPutDescriptor(args.buf); return error::make("failed to upload to object "+ args.object); @@ -492,9 +498,9 @@ namespace minio::s3 { } std::stringstream ss(std::ios_base::in | std::ios_base::out); - ss.rdbuf()->pubsetbuf(args.buf, args.size); + ss.rdbuf()->pubsetbuf(args.buf, size); - minio::s3::PutObjectArgs aargs(ss, args.size, 16*1024*1024UL); + minio::s3::PutObjectArgs aargs(ss, static_cast(size), 16*1024*1024UL); return PutObject(aargs); } diff --git a/src/utils.cc b/src/utils.cc index 9a1c4cea..7925d6b9 100644 --- a/src/utils.cc +++ b/src/utils.cc @@ -225,7 +225,7 @@ std::string EncodePath(const std::string& path) { std::string XMLEncode(const std::string& value) { pugi::xml_document doc; - doc.append_child(pugi::node_pcdata).set_value(value); + doc.append_child(pugi::node_pcdata).set_value(value.c_str()); std::ostringstream out; doc.print(out); return out.str(); From 22d4122a7df31477cb2ee909d54ed8ea86977509 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 15 Jan 2026 16:47:41 -0800 Subject: [PATCH 03/25] fix: style issues --- check-style.sh | 31 +- examples/GPUHostDisk.cc | 22 +- examples/GetPutRDMA.cc | 30 +- examples/PutObject.cc | 12 +- include/miniocpp/args.h | 23 +- include/miniocpp/baseclient.h | 20 +- include/miniocpp/http.h | 8 +- include/miniocpp/nvidia-cufile.h | 507 +++--- include/miniocpp/nvidia-cuobjclient.h | 119 +- include/miniocpp/rdma-httplib.h | 2094 ++++++++++++++++--------- include/miniocpp/rdma.h | 84 +- include/miniocpp/utils.h | 10 +- src/args.cc | 2 +- src/baseclient.cc | 263 ++-- src/client.cc | 1584 +++++++++---------- src/request.cc | 4 + src/response.cc | 182 +-- 17 files changed, 2839 insertions(+), 2156 deletions(-) diff --git a/check-style.sh b/check-style.sh index 5db19fcf..f87ef357 100755 --- a/check-style.sh +++ b/check-style.sh @@ -4,18 +4,31 @@ if [ -z "${CLANG_FORMAT}" ]; then CLANG_FORMAT="clang-format" fi +FIX_MODE=0 +if [ "$1" = "--fix" ] || [ "$1" = "-f" ]; then + FIX_MODE=1 +fi + function do_clang_format() { - echo "verifying '${CLANG_FORMAT} --output-replacements-xml --style=Google $@'" - if ${CLANG_FORMAT} --output-replacements-xml --style=Google "$@" | grep -q ' "$tmpfile" +find src include examples tests -iname "*.cc" -o -iname "*.h" | grep -v 'cuda\.h$' | grep -v 'cufile\.h$' | grep -v 'cufile_info\.h$' > "$tmpfile" ec=0 while read -r file; do if ! do_clang_format "$file"; then @@ -24,4 +37,8 @@ while read -r file; do done < "$tmpfile" rm -f "$tmpfile" +if [ "$FIX_MODE" = "1" ]; then + echo "All formatting issues fixed." +fi + exit "$ec" diff --git a/examples/GPUHostDisk.cc b/examples/GPUHostDisk.cc index 33500e43..d7cbfcc9 100644 --- a/examples/GPUHostDisk.cc +++ b/examples/GPUHostDisk.cc @@ -1,19 +1,19 @@ +#include +#include +#include +#include +#include #include #include -#include -#include -#include -#include #include #include #include -#include -#include -#include +#include -#include +#include +#include -int main(int argc, char* argv[]) { +int main(int argc, char *argv[]) { char *bufptr; size_t bufsize = 10 * 1024 * 1024UL; if (argc == 2) { @@ -23,9 +23,9 @@ int main(int argc, char* argv[]) { cudaMalloc(&bufptr, bufsize); cudaMemset(bufptr, 'A', bufsize); cudaStreamSynchronize(0); - + char *hostptr; - hostptr = (char *) malloc(bufsize); + hostptr = (char *)malloc(bufsize); cudaMemcpy(hostptr, bufptr, bufsize, cudaMemcpyDeviceToHost); // Open the file in binary mode for writing diff --git a/examples/GetPutRDMA.cc b/examples/GetPutRDMA.cc index b05ca6ba..2e448a88 100644 --- a/examples/GetPutRDMA.cc +++ b/examples/GetPutRDMA.cc @@ -15,22 +15,22 @@ // // SPDX-License-Identifier: Apache-2.0 +#include +#include +#include +#include +#include #include #include -#include -#include -#include -#include #include #include #include -#include -#include -#include +#include -#include +#include +#include -int main(int argc, char* argv[]) { +int main(int argc, char *argv[]) { std::string host; std::string access_key; std::string secret_key; @@ -76,8 +76,7 @@ int main(int argc, char* argv[]) { int res = posix_memalign((void **)&bufptr, getpagesize(), bufsize); if (res) { std::cerr << "unable to allocate system memory with alignment" - << getpagesize() << "buf size" - << bufsize << std::endl; + << getpagesize() << "buf size" << bufsize << std::endl; } assert(bufptr); memset(bufptr, 'A', bufsize); @@ -94,9 +93,10 @@ int main(int argc, char* argv[]) { // Handle response. if (presp) { std::cout << std::endl - << "data uploaded successfully " << presp.etag << std::endl; + << "data uploaded successfully " << presp.etag << std::endl; } else { - std::cout << "unable to get object; " << presp.Error().String() << std::endl; + std::cout << "unable to get object; " << presp.Error().String() + << std::endl; } // Create get object arguments. @@ -116,13 +116,13 @@ int main(int argc, char* argv[]) { // Handle response. if (resp) { std::cout << std::endl - << "data of my-object is received successfully" << std::endl; + << "data of my-object is received successfully" << std::endl; } else { std::cout << "unable to get object; " << resp.Error().String() << std::endl; } char *hostptr; - hostptr = (char *) malloc(bufsize); + hostptr = (char *)malloc(bufsize); if (gpu_enabled) { cudaMemcpy(hostptr, bufptr, bufsize, cudaMemcpyDeviceToHost); } else { diff --git a/examples/PutObject.cc b/examples/PutObject.cc index dcba71e4..9423b88e 100644 --- a/examples/PutObject.cc +++ b/examples/PutObject.cc @@ -15,19 +15,18 @@ // // SPDX-License-Identifier: Apache-2.0 -#include - #include #include #include #include #include +#include +#include #include #include #include #include -#include int main(int argc, char* argv[]) { std::string host; @@ -60,7 +59,7 @@ int main(int argc, char* argv[]) { std::filesystem::path filePath("my-object.csv"); std::uintmax_t fileSize = std::filesystem::file_size(filePath); - minio::s3::PutObjectArgs args(file, fileSize, 16*1024*1024UL); + minio::s3::PutObjectArgs args(file, fileSize, 16 * 1024 * 1024UL); args.bucket = "my-bucket"; args.object = "my-object"; @@ -69,10 +68,11 @@ int main(int argc, char* argv[]) { // Handle response. if (resp) { - std::cout << "my-object is successfully created etag=" << resp.etag << " " << std::endl; + std::cout << "my-object is successfully created etag=" << resp.etag << " " + << std::endl; } else { std::cout << "unable to do put object; " << resp.Error().String() - << std::endl; + << std::endl; } return 0; diff --git a/include/miniocpp/args.h b/include/miniocpp/args.h index 3c02c768..9f58b347 100644 --- a/include/miniocpp/args.h +++ b/include/miniocpp/args.h @@ -27,10 +27,10 @@ #include "error.h" #include "http.h" +#include "nvidia-cuobjclient.h" #include "sse.h" #include "types.h" #include "utils.h" -#include "nvidia-cuobjclient.h" namespace minio::s3 { @@ -157,13 +157,13 @@ struct PutObjectBaseArgs : public ObjectWriteArgs { struct PutObjectApiArgs : public PutObjectBaseArgs { std::string_view data; - char *buf; + char* buf; size_t size; utils::Multimap query_params; http::ProgressFunction progressfunc = nullptr; void* progress_userdata = nullptr; cuObjClient* rdmaclient = nullptr; - + PutObjectApiArgs() = default; ~PutObjectApiArgs() = default; }; // struct PutObjectApiArgs @@ -171,7 +171,7 @@ struct PutObjectApiArgs : public PutObjectBaseArgs { struct UploadPartArgs : public ObjectWriteArgs { std::string upload_id; unsigned int part_number; - char *buf; + char* buf; size_t part_size; std::string_view data; http::ProgressFunction progressfunc = nullptr; @@ -224,7 +224,7 @@ struct GetObjectArgs : public ObjectConditionalReadArgs { }; // struct GetObjectArgs struct GetObjectRDMAArgs : public GetObjectArgs { - char *buf = nullptr; + char* buf = nullptr; std::optional size; GetObjectRDMAArgs() = default; @@ -343,7 +343,7 @@ struct PutObjectArgs : public PutObjectBaseArgs { }; // struct PutObjectArgs struct PutObjectRDMAArgs : public PutObjectBaseArgs { - char *buf = nullptr; + char* buf = nullptr; std::optional size; PutObjectRDMAArgs() = default; @@ -351,7 +351,6 @@ struct PutObjectRDMAArgs : public PutObjectBaseArgs { error::Error Validate() const; }; // struct PutObjectRDMAArgs - using CopySource = ObjectConditionalReadArgs; @@ -607,12 +606,12 @@ struct PostPolicy { error::Error AddStartsWithCondition(std::string element, std::string value); error::Error RemoveStartsWithCondition(std::string element); error::Error AddContentLengthRangeCondition(size_t lower_limit, - size_t upper_limit); + size_t upper_limit); void RemoveContentLengthRangeCondition(); error::Error FormData(std::map& data, - std::string access_key, std::string secret_key, - std::string session_token, std::string region); + std::string access_key, std::string secret_key, + std::string session_token, std::string region); private: static constexpr const char* eq_ = "eq"; @@ -626,8 +625,8 @@ struct PostPolicy { static std::string trimDollar(std::string value); static std::string getCredentialString(std::string access_key, - utils::UtcTime date, - std::string region); + utils::UtcTime date, + std::string region); static bool isReservedElement(std::string element); }; // struct PostPolicy diff --git a/include/miniocpp/baseclient.h b/include/miniocpp/baseclient.h index 3afe8249..3258234a 100644 --- a/include/miniocpp/baseclient.h +++ b/include/miniocpp/baseclient.h @@ -32,8 +32,8 @@ #include "utils.h" // RDMA specific includes -#include "rdma.h" #include "nvidia-cuobjclient.h" +#include "rdma.h" #if defined(_WIN32) && defined(GetObject) #pragma push_macro("GetObject") @@ -62,7 +62,7 @@ class BaseClient { public: explicit BaseClient(BaseUrl base_url, - creds::Provider* const provider = nullptr); + creds::Provider* const provider = nullptr); virtual ~BaseClient() = default; @@ -75,20 +75,20 @@ class BaseClient { } error::Error SetAppInfo(std::string_view app_name, - std::string_view app_version); + std::string_view app_version); void HandleRedirectResponse(std::string& code, std::string& message, - int status_code, http::Method method, - const utils::Multimap& headers, - const std::string& bucket_name, - bool retry = false); + int status_code, http::Method method, + const utils::Multimap& headers, + const std::string& bucket_name, + bool retry = false); Response GetErrorResponse(http::Response resp, std::string_view resource, - http::Method method, const std::string& bucket_name, - const std::string& object_name); + http::Method method, const std::string& bucket_name, + const std::string& object_name); Response execute(Request& req); Response Execute(Request& req); GetRegionResponse GetRegion(const std::string& bucket_name, - const std::string& region); + const std::string& region); AbortMultipartUploadResponse AbortMultipartUpload( AbortMultipartUploadArgs args); diff --git a/include/miniocpp/http.h b/include/miniocpp/http.h index c23c5537..433d8efb 100644 --- a/include/miniocpp/http.h +++ b/include/miniocpp/http.h @@ -53,12 +53,10 @@ struct Url { host(std::move(host)), port(port), path(std::move(path)), - query_string(std::move(query_string)) {}; + query_string(std::move(query_string)){}; explicit Url(bool https, std::string host, unsigned int port) - : https(https), - host(std::move(host)), - port(port) {}; - + : https(https), host(std::move(host)), port(port){}; + ~Url() = default; explicit operator bool() const { return !host.empty(); } diff --git a/include/miniocpp/nvidia-cufile.h b/include/miniocpp/nvidia-cufile.h index ec5693ad..c33ad949 100644 --- a/include/miniocpp/nvidia-cufile.h +++ b/include/miniocpp/nvidia-cufile.h @@ -51,80 +51,114 @@ * @file cufile.h * @brief cuFile C APIs * - * This file contains all the C APIs to perform GPUDirect Storage supported IO operations + * This file contains all the C APIs to perform GPUDirect Storage supported IO + * operations */ #if __cplusplus -extern "C" -{ +extern "C" { #endif /// @cond DOXYGEN_SKIP_MACRO #ifndef __CUFILE_H_ #define __CUFILE_H_ -#include -#include -#include "cuda.h" #include +#include +#include #include -#define CUFILEOP_BASE_ERR 5000 +#include "cuda.h" -//Note :Data path errors are captured via standard error codes -#define CUFILEOP_STATUS_ENTRIES \ - CUFILE_OP(0, CU_FILE_SUCCESS, cufile success) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 1, CU_FILE_DRIVER_NOT_INITIALIZED, nvidia-fs driver is not loaded) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 2, CU_FILE_DRIVER_INVALID_PROPS, invalid property) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 3, CU_FILE_DRIVER_UNSUPPORTED_LIMIT, property range error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 4, CU_FILE_DRIVER_VERSION_MISMATCH, nvidia-fs driver version mismatch) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 5, CU_FILE_DRIVER_VERSION_READ_ERROR, nvidia-fs driver version read error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 6, CU_FILE_DRIVER_CLOSING, driver shutdown in progress) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 7, CU_FILE_PLATFORM_NOT_SUPPORTED, GPUDirect Storage not supported on current platform) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 8, CU_FILE_IO_NOT_SUPPORTED, GPUDirect Storage not supported on current file) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 9, CU_FILE_DEVICE_NOT_SUPPORTED, GPUDirect Storage not supported on current GPU) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 10, CU_FILE_NVFS_DRIVER_ERROR, nvidia-fs driver ioctl error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 11, CU_FILE_CUDA_DRIVER_ERROR, CUDA Driver API error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 12, CU_FILE_CUDA_POINTER_INVALID, invalid device pointer) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 13, CU_FILE_CUDA_MEMORY_TYPE_INVALID, invalid pointer memory type) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 14, CU_FILE_CUDA_POINTER_RANGE_ERROR, pointer range exceeds allocated address range) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 15, CU_FILE_CUDA_CONTEXT_MISMATCH, cuda context mismatch) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 16, CU_FILE_INVALID_MAPPING_SIZE, access beyond maximum pinned size) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 17, CU_FILE_INVALID_MAPPING_RANGE, access beyond mapped size) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 18, CU_FILE_INVALID_FILE_TYPE, unsupported file type) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 19, CU_FILE_INVALID_FILE_OPEN_FLAG, unsupported file open flags) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 20, CU_FILE_DIO_NOT_SET, fd direct IO not set) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 22, CU_FILE_INVALID_VALUE, invalid arguments) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 23, CU_FILE_MEMORY_ALREADY_REGISTERED, device pointer already registered) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 24, CU_FILE_MEMORY_NOT_REGISTERED, device pointer lookup failure) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 25, CU_FILE_PERMISSION_DENIED, driver or file access error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 26, CU_FILE_DRIVER_ALREADY_OPEN, driver is already open) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 27, CU_FILE_HANDLE_NOT_REGISTERED, file descriptor is not registered) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 28, CU_FILE_HANDLE_ALREADY_REGISTERED, file descriptor is already registered) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 29, CU_FILE_DEVICE_NOT_FOUND, GPU device not found) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 30, CU_FILE_INTERNAL_ERROR, internal error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 31, CU_FILE_GETNEWFD_FAILED, failed to obtain new file descriptor) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 33, CU_FILE_NVFS_SETUP_ERROR, NVFS driver initialization error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 34, CU_FILE_IO_DISABLED, GPUDirect Storage disabled by config on current file)\ - CUFILE_OP(CUFILEOP_BASE_ERR + 35, CU_FILE_BATCH_SUBMIT_FAILED, failes to submit batch operation)\ - CUFILE_OP(CUFILEOP_BASE_ERR + 36, CU_FILE_GPU_MEMORY_PINNING_FAILED, Failed to allocate pinned GPU Memory) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 37, CU_FILE_IO_MAX_ERROR, GPUDirect Storage Max Error) +#define CUFILEOP_BASE_ERR 5000 +// Note :Data path errors are captured via standard error codes +#define CUFILEOP_STATUS_ENTRIES \ + CUFILE_OP(0, CU_FILE_SUCCESS, cufile success) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 1, CU_FILE_DRIVER_NOT_INITIALIZED, \ + nvidia - fs driver is not loaded) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 2, CU_FILE_DRIVER_INVALID_PROPS, \ + invalid property) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 3, CU_FILE_DRIVER_UNSUPPORTED_LIMIT, \ + property range error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 4, CU_FILE_DRIVER_VERSION_MISMATCH, \ + nvidia - fs driver version mismatch) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 5, CU_FILE_DRIVER_VERSION_READ_ERROR, \ + nvidia - fs driver version read error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 6, CU_FILE_DRIVER_CLOSING, \ + driver shutdown in progress) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 7, CU_FILE_PLATFORM_NOT_SUPPORTED, \ + GPUDirect Storage not supported on current platform) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 8, CU_FILE_IO_NOT_SUPPORTED, \ + GPUDirect Storage not supported on current file) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 9, CU_FILE_DEVICE_NOT_SUPPORTED, \ + GPUDirect Storage not supported on current GPU) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 10, CU_FILE_NVFS_DRIVER_ERROR, \ + nvidia - fs driver ioctl error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 11, CU_FILE_CUDA_DRIVER_ERROR, \ + CUDA Driver API error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 12, CU_FILE_CUDA_POINTER_INVALID, \ + invalid device pointer) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 13, CU_FILE_CUDA_MEMORY_TYPE_INVALID, \ + invalid pointer memory type) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 14, CU_FILE_CUDA_POINTER_RANGE_ERROR, \ + pointer range exceeds allocated address range) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 15, CU_FILE_CUDA_CONTEXT_MISMATCH, \ + cuda context mismatch) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 16, CU_FILE_INVALID_MAPPING_SIZE, \ + access beyond maximum pinned size) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 17, CU_FILE_INVALID_MAPPING_RANGE, \ + access beyond mapped size) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 18, CU_FILE_INVALID_FILE_TYPE, \ + unsupported file type) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 19, CU_FILE_INVALID_FILE_OPEN_FLAG, \ + unsupported file open flags) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 20, CU_FILE_DIO_NOT_SET, fd direct IO not set) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 22, CU_FILE_INVALID_VALUE, invalid arguments) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 23, CU_FILE_MEMORY_ALREADY_REGISTERED, \ + device pointer already registered) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 24, CU_FILE_MEMORY_NOT_REGISTERED, \ + device pointer lookup failure) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 25, CU_FILE_PERMISSION_DENIED, \ + driver or file access error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 26, CU_FILE_DRIVER_ALREADY_OPEN, \ + driver is already open) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 27, CU_FILE_HANDLE_NOT_REGISTERED, \ + file descriptor is not registered) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 28, CU_FILE_HANDLE_ALREADY_REGISTERED, \ + file descriptor is already registered) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 29, CU_FILE_DEVICE_NOT_FOUND, \ + GPU device not found) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 30, CU_FILE_INTERNAL_ERROR, internal error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 31, CU_FILE_GETNEWFD_FAILED, \ + failed to obtain new file descriptor) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 33, CU_FILE_NVFS_SETUP_ERROR, \ + NVFS driver initialization error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 34, CU_FILE_IO_DISABLED, \ + GPUDirect Storage disabled by config on current file) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 35, CU_FILE_BATCH_SUBMIT_FAILED, \ + failes to submit batch operation) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 36, CU_FILE_GPU_MEMORY_PINNING_FAILED, \ + Failed to allocate pinned GPU Memory) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 37, CU_FILE_IO_MAX_ERROR, \ + GPUDirect Storage Max Error) /** * @brief cufileop status enum * * @note on success the error code is set to @ref CU_FILE_SUCCESS. - * @note The error code can be inspected using @ref IS_CUFILE_ERR and @ref CUFILE_ERRSTR. - * @note The error code if set to @ref CU_FILE_CUDA_DRIVER_ERROR, then cuda error can be inspected using @ref IS_CUDA_ERR and @ref CU_FILE_CUDA_ERR. + * @note The error code can be inspected using @ref IS_CUFILE_ERR and @ref + * CUFILE_ERRSTR. + * @note The error code if set to @ref CU_FILE_CUDA_DRIVER_ERROR, then cuda + * error can be inspected using @ref IS_CUDA_ERR and @ref CU_FILE_CUDA_ERR. * @note Data path errors are captured via standard error codes */ typedef enum CUfileOpError { - /// @cond DOXYGEN_SKIP_MACRO - #define CUFILE_OP(code, name, string) name = code, - CUFILEOP_STATUS_ENTRIES - #undef CUFILE_OP - ///@endcond +/// @cond DOXYGEN_SKIP_MACRO +#define CUFILE_OP(code, name, string) name = code, + CUFILEOP_STATUS_ENTRIES +#undef CUFILE_OP + ///@endcond } CUfileOpError; /// @endcond @@ -132,187 +166,195 @@ typedef enum CUfileOpError { /** * @brief cufileop status string */ -static inline const char *cufileop_status_error(CUfileOpError status) -{ - switch (status) { - /// @cond DOXYGEN_SKIP_MACRO - #define CUFILE_OP(code, name, string) \ - case name: return #string; - CUFILEOP_STATUS_ENTRIES - #undef CUFILE_OP - ///@endcond - default:return "unknown cufile error"; - } +static inline const char *cufileop_status_error(CUfileOpError status) { + switch (status) { +/// @cond DOXYGEN_SKIP_MACRO +#define CUFILE_OP(code, name, string) \ + case name: \ + return #string; + CUFILEOP_STATUS_ENTRIES +#undef CUFILE_OP + ///@endcond + default: + return "unknown cufile error"; + } } /** * @brief cufileop status string */ typedef struct CUfileError { + CUfileOpError err; // cufile error - CUfileOpError err; // cufile error - - CUresult cu_err; // cuda driver error + CUresult cu_err; // cuda driver error -}CUfileError_t; +} CUfileError_t; /** * @brief error macros to inspect error status of type @ref CUfileOpError */ -#define IS_CUFILE_ERR(err) \ - (abs((err)) > CUFILEOP_BASE_ERR) +#define IS_CUFILE_ERR(err) (abs((err)) > CUFILEOP_BASE_ERR) -#define CUFILE_ERRSTR(err) \ - cufileop_status_error((CUfileOpError)abs((err))) +#define CUFILE_ERRSTR(err) cufileop_status_error((CUfileOpError)abs((err))) -#define IS_CUDA_ERR(status) \ - ((status).err == CU_FILE_CUDA_DRIVER_ERROR) +#define IS_CUDA_ERR(status) ((status).err == CU_FILE_CUDA_DRIVER_ERROR) #define CU_FILE_CUDA_ERR(status) ((status).cu_err) /* driver properties */ typedef enum CUfileDriverStatusFlags { - CU_FILE_LUSTRE_SUPPORTED = 0, /*!< Support for DDN LUSTRE */ + CU_FILE_LUSTRE_SUPPORTED = 0, /*!< Support for DDN LUSTRE */ - CU_FILE_WEKAFS_SUPPORTED = 1, /*!< Support for WEKAFS */ + CU_FILE_WEKAFS_SUPPORTED = 1, /*!< Support for WEKAFS */ - CU_FILE_NFS_SUPPORTED = 2, /*!< Support for NFS */ + CU_FILE_NFS_SUPPORTED = 2, /*!< Support for NFS */ - CU_FILE_GPFS_SUPPORTED = 3, /*! < Support for GPFS */ + CU_FILE_GPFS_SUPPORTED = 3, /*! < Support for GPFS */ - CU_FILE_NVME_SUPPORTED = 4, /*!< Support for NVMe */ + CU_FILE_NVME_SUPPORTED = 4, /*!< Support for NVMe */ - CU_FILE_NVMEOF_SUPPORTED = 5, /*!< Support for NVMeOF */ + CU_FILE_NVMEOF_SUPPORTED = 5, /*!< Support for NVMeOF */ - CU_FILE_SCSI_SUPPORTED = 6, /*!< Support for SCSI */ + CU_FILE_SCSI_SUPPORTED = 6, /*!< Support for SCSI */ - CU_FILE_SCALEFLUX_CSD_SUPPORTED = 7, /*!< Support for Scaleflux CSD*/ + CU_FILE_SCALEFLUX_CSD_SUPPORTED = 7, /*!< Support for Scaleflux CSD*/ - CU_FILE_NVMESH_SUPPORTED = 8, /*!< Support for NVMesh Block Dev*/ - CU_FILE_BEEGFS_SUPPORTED = 9, /*!< Support for BeeGFS */ + CU_FILE_NVMESH_SUPPORTED = 8, /*!< Support for NVMesh Block Dev*/ + CU_FILE_BEEGFS_SUPPORTED = 9, /*!< Support for BeeGFS */ -}CUfileDriverStatusFlags_t; +} CUfileDriverStatusFlags_t; typedef enum CUfileDriverControlFlags { - CU_FILE_USE_POLL_MODE = 0 , /*!< use POLL mode. properties.use_poll_mode*/ + CU_FILE_USE_POLL_MODE = 0, /*!< use POLL mode. properties.use_poll_mode*/ - CU_FILE_ALLOW_COMPAT_MODE = 1/*!< allow COMPATIBILITY mode. properties.allow_compat_mode*/ + CU_FILE_ALLOW_COMPAT_MODE = + 1 /*!< allow COMPATIBILITY mode. properties.allow_compat_mode*/ -}CUfileDriverControlFlags_t; +} CUfileDriverControlFlags_t; typedef enum CUfileFeatureFlags { - CU_FILE_DYN_ROUTING_SUPPORTED = 0, /*!< Support for Dynamic routing to handle devices across the PCIe bridges */ + CU_FILE_DYN_ROUTING_SUPPORTED = 0, /*!< Support for Dynamic routing to handle + devices across the PCIe bridges */ - CU_FILE_BATCH_IO_SUPPORTED = 1, /*!< Unsupported */ + CU_FILE_BATCH_IO_SUPPORTED = 1, /*!< Unsupported */ - CU_FILE_STREAMS_SUPPORTED = 2 /*!< Unsupported */ + CU_FILE_STREAMS_SUPPORTED = 2 /*!< Unsupported */ -}CUfileFeatureFlags_t; +} CUfileFeatureFlags_t; typedef struct CUfileDrvProps { - struct { - unsigned int major_version; + struct { + unsigned int major_version; - unsigned int minor_version; + unsigned int minor_version; - size_t poll_thresh_size; + size_t poll_thresh_size; - size_t max_direct_io_size; + size_t max_direct_io_size; - unsigned int dstatusflags; + unsigned int dstatusflags; - unsigned int dcontrolflags; + unsigned int dcontrolflags; - } nvfs; + } nvfs; - unsigned int fflags; + unsigned int fflags; - unsigned int max_device_cache_size; + unsigned int max_device_cache_size; - unsigned int per_buffer_cache_size; + unsigned int per_buffer_cache_size; - unsigned int max_device_pinned_mem_size; + unsigned int max_device_pinned_mem_size; - unsigned int max_batch_io_size; - unsigned int max_batch_io_timeout_msecs; -}CUfileDrvProps_t; + unsigned int max_batch_io_size; + unsigned int max_batch_io_timeout_msecs; +} CUfileDrvProps_t; typedef struct sockaddr sockaddr_t; -typedef struct cufileRDMAInfo -{ - int version; - int desc_len; - const char *desc_str; +typedef struct cufileRDMAInfo { + int version; + int desc_len; + const char *desc_str; } cufileRDMAInfo_t; #define CU_FILE_RDMA_REGISTER 1 -#define CU_FILE_RDMA_RELAXED_ORDERING (1<<1) +#define CU_FILE_RDMA_RELAXED_ORDERING (1 << 1) typedef struct CUfileFSOps { - /* NULL means discover using fstat */ - const char* (*fs_type) (const void *handle); + /* NULL means discover using fstat */ + const char *(*fs_type)(const void *handle); - /* list of host addresses to use, NULL means no restriction */ - int (*getRDMADeviceList)(const void *handle, sockaddr_t **hostaddrs); + /* list of host addresses to use, NULL means no restriction */ + int (*getRDMADeviceList)(const void *handle, sockaddr_t **hostaddrs); - /* -1 no pref */ - int (*getRDMADevicePriority)(const void *handle, char*, size_t, - loff_t, const sockaddr_t* hostaddr); + /* -1 no pref */ + int (*getRDMADevicePriority)(const void *handle, char *, size_t, loff_t, + const sockaddr_t *hostaddr); - /* NULL means try VFS */ - ssize_t (*read) (const void *handle, char*, size_t, loff_t, const cufileRDMAInfo_t*); - ssize_t (*write) (const void *handle, const char *, size_t, loff_t , const cufileRDMAInfo_t*); -}CUfileFSOps_t; + /* NULL means try VFS */ + ssize_t (*read)(const void *handle, char *, size_t, loff_t, + const cufileRDMAInfo_t *); + ssize_t (*write)(const void *handle, const char *, size_t, loff_t, + const cufileRDMAInfo_t *); +} CUfileFSOps_t; /* File Handle */ enum CUfileFileHandleType { - CU_FILE_HANDLE_TYPE_OPAQUE_FD = 1, /*!< Linux based fd */ + CU_FILE_HANDLE_TYPE_OPAQUE_FD = 1, /*!< Linux based fd */ - CU_FILE_HANDLE_TYPE_OPAQUE_WIN32 = 2, /*!< Windows based handle (unsupported) */ + CU_FILE_HANDLE_TYPE_OPAQUE_WIN32 = + 2, /*!< Windows based handle (unsupported) */ - CU_FILE_HANDLE_TYPE_USERSPACE_FS = 3, /* Userspace based FS */ + CU_FILE_HANDLE_TYPE_USERSPACE_FS = 3, /* Userspace based FS */ }; typedef struct CUfileDescr_t { - enum CUfileFileHandleType type; /* type of file being registered */ - union { - int fd; /* Linux */ - void *handle; /* Windows */ - } handle; - const CUfileFSOps_t *fs_ops; /* file system operation table */ -}CUfileDescr_t; + enum CUfileFileHandleType type; /* type of file being registered */ + union { + int fd; /* Linux */ + void *handle; /* Windows */ + } handle; + const CUfileFSOps_t *fs_ops; /* file system operation table */ +} CUfileDescr_t; /** * @brief File handle type * */ -typedef void* CUfileHandle_t; - +typedef void *CUfileHandle_t; #pragma GCC visibility push(default) /** - * @brief cuFileHandleRegister is required, and performs extra checking that is memoized to provide increased performance on later cuFile operations. + * @brief cuFileHandleRegister is required, and performs extra checking that is + * memoized to provide increased performance on later cuFile operations. * * @param fh @ref CUfileHandle_t opaque file handle for IO operations * @param descr @ref CUfileDescr_t file descriptor (OS agnostic) * - * @return CU_FILE_SUCCESS on successful completion. fh will be updated for use in @ref cuFileRead, @ref cuFileWrite, @ref cuFileHandleDeregister + * @return CU_FILE_SUCCESS on successful completion. fh will be updated for + * use in @ref cuFileRead, @ref cuFileWrite, @ref cuFileHandleDeregister * @return CU_FILE_DRIVER_NOT_INITIALIZED on failure to load driver * @return CU_FILE_IO_NOT_SUPPORTED - if filesystem is not supported * @return CU_FILE_INVALID_VALUE if null or bad api arguments - * @return CU_FILE_INVALID_FILE_OPEN_FLAG if file is opened with unsupported modes like no O_DIRECT - * @return CU_FILE_INVALID_FILE_TYPE if filepath is not valid or is not a regular file - * @return CU_FILE_HANDLE_ALREADY_REGISTERED if file handle/descriptor is already registered + * @return CU_FILE_INVALID_FILE_OPEN_FLAG if file is opened with + * unsupported modes like no O_DIRECT + * @return CU_FILE_INVALID_FILE_TYPE if filepath is not valid or is not a + * regular file + * @return CU_FILE_HANDLE_ALREADY_REGISTERED if file handle/descriptor is + * already registered * * Description - * cuFileHandleRegister registers the open file descriptor for use with cuFile IO operations. + * cuFileHandleRegister registers the open file descriptor for use with cuFile + * IO operations. * - * This API will ensure that the file’s descriptor is checked for GPUDirect Storage support and returns a valid file handle on CU_FILE_SUCCESS. + * This API will ensure that the file’s descriptor is checked for GPUDirect + * Storage support and returns a valid file handle on CU_FILE_SUCCESS. * - * @note the file needs to be opened in O_DIRECT mode to support GPUDirect Storage. + * @note the file needs to be opened in O_DIRECT mode to support GPUDirect + * Storage. * * @see cuFileRead * @see cuFileWrite @@ -333,26 +375,32 @@ CUfileError_t cuFileHandleRegister(CUfileHandle_t *fh, CUfileDescr_t *descr); void cuFileHandleDeregister(CUfileHandle_t fh); /** - * @brief register an existing cudaMalloced memory with cuFile to pin for GPUDirect Storage access. + * @brief register an existing cudaMalloced memory with cuFile to pin for + * GPUDirect Storage access. * * @param devPtr_base device pointer to allocated * @param length size of memory region from the above specified devPtr - * @param flags CU_FILE_RDMA_REGISTER + * @param flags CU_FILE_RDMA_REGISTER * * @return CU_FILE_SUCCESS on success * @return CU_FILE_NVFS_DRIVER_ERROR * @return CU_FILE_INVALID_VALUE * @return CU_FILE_CUDA_ERROR for unsuported memory type * @return CU_FILE_MEMORY_ALREADY_REGISTERED on error - * @return CU_FILE_GPU_MEMORY_PINNING_FAILED if not enough pinned memory is available - * @note This memory will be use to perform GPU direct DMA from the supported storage. - * @warning This API is intended for usecases where the memory is used as streaming buffer that is reused across multiple cuFile IO operations before calling @ref cuFileBufDeregister + * @return CU_FILE_GPU_MEMORY_PINNING_FAILED if not enough pinned memory is + * available + * @note This memory will be use to perform GPU direct DMA from the supported + * storage. + * @warning This API is intended for usecases where the memory is used as + * streaming buffer that is reused across multiple cuFile IO operations before + * calling @ref cuFileBufDeregister * * @see cuFileBufDeregister * @see cuFileRead * @see cuFileWrite */ -CUfileError_t cuFileBufRegister(const void *devPtr_base, size_t length, int flags); +CUfileError_t cuFileBufRegister(const void *devPtr_base, size_t length, + int flags); /** * @brief deregister an already registered device memory from cuFile @@ -360,7 +408,8 @@ CUfileError_t cuFileBufRegister(const void *devPtr_base, size_t length, int flag * @param devPtr_base device pointer to deregister * * @return CU_FILE_SUCCESS on success - * @return CU_FILE_INVALID_VALUE on invalid memory pointer or unregistered memory pointer + * @return CU_FILE_INVALID_VALUE on invalid memory pointer or unregistered + * memory pointer * * @see cuFileBufRegister * @see cuFileRead @@ -376,22 +425,28 @@ CUfileError_t cuFileBufDeregister(const void *devPtr_base); * @param devPtr_base base address of buffer in device memory * @param size size bytes to read * @param file_offset file-offset from begining of the file - * @param devPtr_offset offset relative to the devPtr_base pointer to read into. + * @param devPtr_offset offset relative to the devPtr_base pointer to read + * into. * * @return size of bytes successfully read - * @return -1 on error, in which case errno is set to indicate filesystem errors. - * @return all other errors will return a negative integer value of @ref CUfileOpError enum value. + * @return -1 on error, in which case errno is set to indicate filesystem + * errors. + * @return all other errors will return a negative integer value of @ref + * CUfileOpError enum value. * - * @note If the devPtr is not registered with @ref cuFileBufRegister, the data will be buffered through preallocated pinned buffers. - * @note This is useful for applications that need to perform IO to unaligned file offsets and/or size. This is also recommended - * for cases where the BAR1 memory size is smaller than the size of the allocated memory. + * @note If the devPtr is not registered with @ref cuFileBufRegister, the data + * will be buffered through preallocated pinned buffers. + * @note This is useful for applications that need to perform IO to unaligned + * file offsets and/or size. This is also recommended for cases where the BAR1 + * memory size is smaller than the size of the allocated memory. * * @see cuFileBufRegister * @see cuFileHandleRegister * @see cuFileWrite */ -ssize_t cuFileRead(CUfileHandle_t fh, void *devPtr_base, size_t size, off_t file_offset, off_t devPtr_offset); +ssize_t cuFileRead(CUfileHandle_t fh, void *devPtr_base, size_t size, + off_t file_offset, off_t devPtr_offset); /** * @brief write data from a specified device memory to a registered file handle @@ -400,22 +455,28 @@ ssize_t cuFileRead(CUfileHandle_t fh, void *devPtr_base, size_t size, off_t file * @param devPtr_base base address of buffer in device memory * @param size size bytes to write * @param file_offset file-offset from begining of the file - * @param devPtr_offset offset relative to the devPtr_base pointer to read into. + * @param devPtr_offset offset relative to the devPtr_base pointer to read + * into. * * @return size of bytes successfully written - * @return -1 on error, in which case errno is set to indicate filesystem errors. - * @return all other errors will return a negative integer value of @ref CUfileOpError enum value. + * @return -1 on error, in which case errno is set to indicate filesystem + * errors. + * @return all other errors will return a negative integer value of @ref + * CUfileOpError enum value. * - * @note If the devPtr is not registered with @ref cuFileBufRegister, the data will be buffered through preallocated pinned buffers. - * @note This is useful for applications that need to perform IO to unaligned file offsets and/or size. This is also recommended - * for cases where the BAR1 memory size is smaller than the size of the allocated memory. + * @note If the devPtr is not registered with @ref cuFileBufRegister, the data + * will be buffered through preallocated pinned buffers. + * @note This is useful for applications that need to perform IO to unaligned + * file offsets and/or size. This is also recommended for cases where the BAR1 + * memory size is smaller than the size of the allocated memory. * * @see cuFileBufRegister * @see cuFileHandleRegister * @see cuFileRead */ -ssize_t cuFileWrite(CUfileHandle_t fh, const void *devPtr_base, size_t size, off_t file_offset, off_t devPtr_offset); +ssize_t cuFileWrite(CUfileHandle_t fh, const void *devPtr_base, size_t size, + off_t file_offset, off_t devPtr_offset); // CUFile Driver APIs @@ -438,7 +499,8 @@ CUfileError_t cuFileDriverClose(void); * reset the cuFile library and release the nvidia-fs driver * * @return CU_FILE_SUCCESS on success - * @return CU_FILE_DRIVER_CLOSING if there are any active IO operations using @ref cuFileRead or @ref cuFileWrite + * @return CU_FILE_DRIVER_CLOSING if there are any active IO operations using + * @ref cuFileRead or @ref cuFileWrite * * @see cuFileDriverOpen */ @@ -446,7 +508,7 @@ CUfileError_t cuFileDriverClose(void); /** * @brief - * returns use count of cufile drivers at that moment by the process. + * returns use count of cufile drivers at that moment by the process. */ long cuFileUseCount(void); @@ -472,9 +534,11 @@ CUfileError_t cuFileDriverGetProperties(CUfileDrvProps_t *props); * * @return CU_FILE_SUCCESS on success * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized - * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on error + * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on + * error * - * @warning This is an advanced command and should be tuned based on available system memory + * @warning This is an advanced command and should be tuned based on available + * system memory * * @see cuFileDriverGetProperties */ @@ -482,15 +546,18 @@ CUfileError_t cuFileDriverSetPollMode(bool poll, size_t poll_threshold_size); /** * @brief - * Control parameter to set max IO size(KB) used by the library to talk to nvidia-fs driver + * Control parameter to set max IO size(KB) used by the library to talk to + * nvidia-fs driver * * @param max_direct_io_size maximum allowed direct io size in KB * * @return CU_FILE_SUCCESS on success * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized - * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on error + * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on + * error * - * @warning This is an advanced command and should be tuned based on available system memory + * @warning This is an advanced command and should be tuned based on available + * system memory * * @see cuFileDriverGetProperties * @@ -499,15 +566,19 @@ CUfileError_t cuFileDriverSetMaxDirectIOSize(size_t max_direct_io_size); /** * @brief - * Control parameter to set maximum GPU memory reserved per device by the library for internal buffering + * Control parameter to set maximum GPU memory reserved per device by the + * library for internal buffering * - * @param max_cache_size The maximum GPU buffer space per device used for internal use in KB + * @param max_cache_size The maximum GPU buffer space per device used for + * internal use in KB * * @return CU_FILE_SUCCESS on success * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized - * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on error + * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on + * error * - * @warning This is an advanced command and should be tuned based on supported GPU memory + * @warning This is an advanced command and should be tuned based on supported + * GPU memory * * @see cuFileDriverGetProperties */ @@ -515,78 +586,80 @@ CUfileError_t cuFileDriverSetMaxCacheSize(size_t max_cache_size); /** * @brief - * Sets maximum buffer space that is pinned in KB for use by @ref cuFileBufRegister + * Sets maximum buffer space that is pinned in KB for use by @ref + * cuFileBufRegister * * @param max_pinned_size maximum buffer space that is pinned in KB * * @return CU_FILE_SUCCESS on success * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized - * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on error + * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on + * error * - * @warning This is an advanced command and should be tuned based on supported GPU memory + * @warning This is an advanced command and should be tuned based on supported + * GPU memory * * @see cuFileDriverGetProperties * */ CUfileError_t cuFileDriverSetMaxPinnedMemSize(size_t max_pinned_size); +// Experimental Batch API's -//Experimental Batch API's - - -typedef enum CUfileOpcode { - CUFILE_READ = 0, - CUFILE_WRITE -}CUfileOpcode_t; +typedef enum CUfileOpcode { CUFILE_READ = 0, CUFILE_WRITE } CUfileOpcode_t; -typedef enum CUFILEStatus_enum { - CUFILE_WAITING = 0x000001, /* required value prior to submission */ - CUFILE_PENDING = 0x000002, /* once enqueued */ - CUFILE_INVALID = 0x000004, /* request was ill-formed or could not be enqueued */ - CUFILE_CANCELED = 0x000008, /* request successfully canceled */ - CUFILE_COMPLETE = 0x0000010, /* request successfully completed */ - CUFILE_TIMEOUT = 0x0000020, /* request timed out */ - CUFILE_FAILED = 0x0000040 /* unable to complete */ -}CUfileStatus_t; +typedef enum CUFILEStatus_enum { + CUFILE_WAITING = 0x000001, /* required value prior to submission */ + CUFILE_PENDING = 0x000002, /* once enqueued */ + CUFILE_INVALID = + 0x000004, /* request was ill-formed or could not be enqueued */ + CUFILE_CANCELED = 0x000008, /* request successfully canceled */ + CUFILE_COMPLETE = 0x0000010, /* request successfully completed */ + CUFILE_TIMEOUT = 0x0000020, /* request timed out */ + CUFILE_FAILED = 0x0000040 /* unable to complete */ +} CUfileStatus_t; typedef enum cufileBatchMode { - CUFILE_BATCH = 1, + CUFILE_BATCH = 1, } CUfileBatchMode_t; typedef struct CUfileIOParams { - CUfileBatchMode_t mode; // Must be the very first field. - union { - struct { - void *devPtr_base; - off_t file_offset; - off_t devPtr_offset; - size_t size; - }batch; - }u; - CUfileHandle_t fh; - CUfileOpcode_t opcode; - void *cookie; -}CUfileIOParams_t; + CUfileBatchMode_t mode; // Must be the very first field. + union { + struct { + void *devPtr_base; + off_t file_offset; + off_t devPtr_offset; + size_t size; + } batch; + } u; + CUfileHandle_t fh; + CUfileOpcode_t opcode; + void *cookie; +} CUfileIOParams_t; typedef struct CUfileIOEvents { - void *cookie; - CUfileStatus_t status; /* status of the operation */ - size_t ret; /* -ve error or amount of I/O done. */ -}CUfileIOEvents_t; + void *cookie; + CUfileStatus_t status; /* status of the operation */ + size_t ret; /* -ve error or amount of I/O done. */ +} CUfileIOEvents_t; -typedef void* CUfileBatchHandle_t; +typedef void *CUfileBatchHandle_t; CUfileError_t cuFileBatchIOSetUp(CUfileBatchHandle_t *batch_idp, unsigned nr); -CUfileError_t cuFileBatchIOSubmit(CUfileBatchHandle_t batch_idp, unsigned nr, CUfileIOParams_t *iocbp, unsigned int flags); -CUfileError_t cuFileBatchIOGetStatus(CUfileBatchHandle_t batch_idp, unsigned min_nr, unsigned* nr, - CUfileIOEvents_t *iocbp, struct timespec* timeout); +CUfileError_t cuFileBatchIOSubmit(CUfileBatchHandle_t batch_idp, unsigned nr, + CUfileIOParams_t *iocbp, unsigned int flags); +CUfileError_t cuFileBatchIOGetStatus(CUfileBatchHandle_t batch_idp, + unsigned min_nr, unsigned *nr, + CUfileIOEvents_t *iocbp, + struct timespec *timeout); CUfileError_t cuFileBatchIOCancel(CUfileBatchHandle_t batch_idp); void cuFileBatchIODestroy(CUfileBatchHandle_t batch_idp); #pragma GCC visibility pop /// @cond DOXYGEN_SKIP_MACRO -#endif // CUFILE_H +#endif // CUFILE_H /// @endcond #if __cplusplus } diff --git a/include/miniocpp/nvidia-cuobjclient.h b/include/miniocpp/nvidia-cuobjclient.h index b8bd3cf4..a7dc0a15 100644 --- a/include/miniocpp/nvidia-cuobjclient.h +++ b/include/miniocpp/nvidia-cuobjclient.h @@ -1,6 +1,6 @@ /* - * SPDX-FileCopyrightText: Copyright (c) 2024 NVIDIA CORPORATION & AFFILIATES. All rights reserved. - * SPDX-License-Identifier: LicenseRef-NvidiaProprietary + * SPDX-FileCopyrightText: Copyright (c) 2024 NVIDIA CORPORATION & AFFILIATES. + * All rights reserved. SPDX-License-Identifier: LicenseRef-NvidiaProprietary * * NVIDIA CORPORATION, its affiliates and licensors retain all intellectual * property and proprietary rights in and to this material, related @@ -14,12 +14,14 @@ #define OBJ_RDMA_V1 "CUOBJ" -#include #include +#include + #include -#include "request.h" + #include "nvidia-cufile.h" #include "providers.h" +#include "request.h" /** * @brief cuObject error numbers. @@ -29,20 +31,19 @@ */ typedef enum cuObjErr_enum { - CU_OBJ_SUCCESS =0, /**< Operation successfully completed */ - CU_OBJ_FAIL =1, /**< Operation failed */ -} cuObjErr_t; + CU_OBJ_SUCCESS = 0, /**< Operation successfully completed */ + CU_OBJ_FAIL = 1, /**< Operation failed */ +} cuObjErr_t; /** * @brief cuObject RDMA descriptor protocol version * */ typedef enum cuObjProto_enum { - CUOBJ_PROTO_RDMA_DC_V1=1001, /**< RDMA support version 1 */ + CUOBJ_PROTO_RDMA_DC_V1 = 1001, /**< RDMA support version 1 */ CUOBJ_PROTO_MAX } cuObjProto_t; - /** * @brief cuObject Operation type * @@ -50,53 +51,67 @@ typedef enum cuObjProto_enum { typedef enum cuObjOpType_enum { CUOBJ_GET = 0, /**< GET operation */ CUOBJ_PUT = 1, /**< PUT operation */ - CUOBJ_INVALID=9999 + CUOBJ_INVALID = 9999 } cuObjOpType_t; /** * @brief cuObject Operation callbacks - * This struct specifies the callback interfaces used by cuObjClient class object during IO operations. - * @note The callbacks can be called from a different thread than the caller thread. user must lock any shared resources - * that can be used concurrently across multiple callers. + * This struct specifies the callback interfaces used by cuObjClient class + * object during IO operations. + * @note The callbacks can be called from a different thread than the caller + * thread. user must lock any shared resources that can be used concurrently + * across multiple callers. */ typedef struct CUObjIOOps { /** * @brief cuObject GET callback - * @param handle cookie to the user context provided in the cuObjGet call. cuObjClient::getCtx(handle) should be called for getting the user context + * @param handle cookie to the user context provided in the cuObjGet call. + * cuObjClient::getCtx(handle) should be called for getting the user context * @param ptr pointer to the start of the memory chunk * @param size size of the memory chunk being read. * @param offset starting object offset for this memory chunk. * @param cufileRDMAInfo_t Pointer to a RDMA memory descriptor string * - * @return size of the data read on success or negative -1, the data read is obtained from control path + * @return size of the data read on success or negative -1, the data read is + * obtained from control path * - * @note offset will be set to zero for cases where the MaxReqCallbackSize is equal to or greater the cuObjectGet call size - * @note size will be set to total requested size n cuObjectGet for cases where the MaxReqCallbackSize is equal to or greater the cuObjectGet call size + * @note offset will be set to zero for cases where the MaxReqCallbackSize is + * equal to or greater the cuObjectGet call size + * @note size will be set to total requested size n cuObjectGet for cases + * where the MaxReqCallbackSize is equal to or greater the cuObjectGet call + * size * * * @see cuObjClient::cuObjGet */ - ssize_t (*get) (const void *handle, char *ptr, size_t size, loff_t offset, const cufileRDMAInfo_t*); + ssize_t (*get)(const void *handle, char *ptr, size_t size, loff_t offset, + const cufileRDMAInfo_t *); /** * @brief cuObject PUT callback - * @param handle to the user context provided in the cuObjPut call. cuObjClient::getCtx(handle) should be called for getting the user context + * @param handle to the user context provided in the cuObjPut call. + * cuObjClient::getCtx(handle) should be called for getting the user context * @param ptr pointer to the start of the memory chunk * @param size size of the memory chunk being written * @param offset starting object offset for this memory chunk. * @param cufileRDMAInfo_t Pointer to a RDMA memory descriptor string * - * @return size of the data written on success or negative -1, the data written is obtained from control path + * @return size of the data written on success or negative -1, the data + * written is obtained from control path * - * @note offset will be set to zero for cases where the MaxReqCallbackSize is equal to or greater the cuObjectPut call size - * @note size will be set to total requested size n cuObjectGet for cases where the MaxReqCallbackSize is equal to or greater the cuObjectPut call size + * @note offset will be set to zero for cases where the MaxReqCallbackSize is + * equal to or greater the cuObjectPut call size + * @note size will be set to total requested size n cuObjectGet for cases + * where the MaxReqCallbackSize is equal to or greater the cuObjectPut call + * size * * * @see cuObjClient::cuObjPut */ - ssize_t (*put) (const void *handle, const char *ptr, size_t size, loff_t offset, const cufileRDMAInfo_t*); -}CUObjOps_t; + ssize_t (*put)(const void *handle, const char *ptr, size_t size, + loff_t offset, const cufileRDMAInfo_t *); +} CUObjOps_t; /** * @brief cuObject memory type @@ -112,40 +127,45 @@ typedef enum cuObjMemoryType_enum { /** * @brief cuObjClient class. * - * cuObjClient Provides client side APIs to prepare PUT/GET operations for out-of-band RDMA IO operations. - * The user of this object is expected to implement a set of callback interfaces specified in CUObjIOOps. - * Once the client object is created, user is expected to optionally register the memory for RDMA and - * perform PUT and GET operations on this client object. - * The cuObjClient will validate the memory and prepare a memory region for RDMA transer. - * The cuObjClient will call one or more callback operations with relevant RDMA information. - * The user is expected to relay the RDMA information and other data to cuObjServer using standard control path. - * After the IO completion, the callback should return the total data read or written in this context. - * The client object may perform additional operations before the cuObjectPut/cuObjectGet operation finishes. + * cuObjClient Provides client side APIs to prepare PUT/GET operations for + * out-of-band RDMA IO operations. The user of this object is expected to + * implement a set of callback interfaces specified in CUObjIOOps. Once the + * client object is created, user is expected to optionally register the memory + * for RDMA and perform PUT and GET operations on this client object. The + * cuObjClient will validate the memory and prepare a memory region for RDMA + * transer. The cuObjClient will call one or more callback operations with + * relevant RDMA information. The user is expected to relay the RDMA information + * and other data to cuObjServer using standard control path. After the IO + * completion, the callback should return the total data read or written in this + * context. The client object may perform additional operations before the + * cuObjectPut/cuObjectGet operation finishes. */ class cuObjClient { -public: - + public: /** * @brief constructor for cuObjClient class. * @param ops callback reference to CUObjIOOps - * @param proto RDMA descriptor protocol used for this client. defaults to CUOBJ_PROTO_RDMA_DC_V1 + * @param proto RDMA descriptor protocol used for this client. defaults to + * CUOBJ_PROTO_RDMA_DC_V1 */ - cuObjClient(CUObjOps_t& ops, cuObjProto_t proto=CUOBJ_PROTO_RDMA_DC_V1); + cuObjClient(CUObjOps_t &ops, cuObjProto_t proto = CUOBJ_PROTO_RDMA_DC_V1); ~cuObjClient(); /** * @brief Acquire a RDMA memory descriptor for the user memory * @param ptr start address of user memory - * @param size size of memory that needs pinning starting from the start address of user memory + * @param size size of memory that needs pinning starting from the start + * address of user memory */ cuObjErr_t cuMemObjGetDescriptor(void *ptr, size_t size); /** * @brief Get a RDMA memory descriptor for the user memory * @param ptr start address of user memory * @return max size of the callback for this memory pointer - * @note: The size can be smaller than allocated memory if the memory is not registered or - * the underlying RDMA subsystem does not allow for pinning/transfer of the entire memory in a single callback + * @note: The size can be smaller than allocated memory if the memory is not + * registered or the underlying RDMA subsystem does not allow for + * pinning/transfer of the entire memory in a single callback */ ssize_t cuMemObjGetMaxRequestCallbackSize(void *ptr); @@ -158,12 +178,13 @@ class cuObjClient { cuObjErr_t cuMemObjPutDescriptor(void *ptr); /** - * @brief Get the user context provided in the cuObjGet and cuObjPut from handle in the callback + * @brief Get the user context provided in the cuObjGet and cuObjPut from + * handle in the callback * @param handle pointer to the handle from the callback * @return void pointer to the user context. */ - static void* getCtx(const void *handle); + static void *getCtx(const void *handle); /** * @brief API to perform GET operation using cuObject @@ -175,7 +196,8 @@ class cuObjClient { * @return data returned by the cuObjServer or a negative error code. */ - ssize_t cuObjGet(void *ctx, void *ptr, size_t size, loff_t offset=0, loff_t buf_offset=0); + ssize_t cuObjGet(void *ctx, void *ptr, size_t size, loff_t offset = 0, + loff_t buf_offset = 0); /** * @brief API to perform PUT operation using cuObject * @param ctx pointer to a user control context, used in PUT callback @@ -186,7 +208,8 @@ class cuObjClient { * @return data returned by the cuObjServer or a negative error code. */ - ssize_t cuObjPut(void *ctx, void *ptr, size_t size, loff_t offset=0, loff_t buf_offset=0); + ssize_t cuObjPut(void *ctx, void *ptr, size_t size, loff_t offset = 0, + loff_t buf_offset = 0); /** * @brief check if the client is connected */ @@ -206,11 +229,11 @@ class cuObjClient { * @param ptr pointer to the memory * @return memory type */ - static cuObjMemoryType_t getMemoryType(const void* ptr); + static cuObjMemoryType_t getMemoryType(const void *ptr); -private: + private: bool cuObjRegisterKey(); - void* _ctx; + void *_ctx; CUfileHandle_t _cufh; CUfileFSOps _objectFsOps; bool _connected; @@ -223,7 +246,7 @@ class cuObjClient { }; typedef struct s3_rdma_client_ctx { - minio::creds::Provider* const provider = nullptr; + minio::creds::Provider *const provider = nullptr; std::string bucket; std::string object; std::string uploadId; diff --git a/include/miniocpp/rdma-httplib.h b/include/miniocpp/rdma-httplib.h index 121ce349..2a5e027a 100644 --- a/include/miniocpp/rdma-httplib.h +++ b/include/miniocpp/rdma-httplib.h @@ -119,9 +119,9 @@ #endif #ifndef CPPHTTPLIB_THREAD_POOL_COUNT -#define CPPHTTPLIB_THREAD_POOL_COUNT \ - ((std::max)(8u, std::thread::hardware_concurrency() > 0 \ - ? std::thread::hardware_concurrency() - 1 \ +#define CPPHTTPLIB_THREAD_POOL_COUNT \ + ((std::max)(8u, std::thread::hardware_concurrency() > 0 \ + ? std::thread::hardware_concurrency() - 1 \ : 0)) #endif @@ -144,11 +144,11 @@ #ifdef _WIN32 #ifndef _CRT_SECURE_NO_WARNINGS #define _CRT_SECURE_NO_WARNINGS -#endif //_CRT_SECURE_NO_WARNINGS +#endif //_CRT_SECURE_NO_WARNINGS #ifndef _CRT_NONSTDC_NO_DEPRECATE #define _CRT_NONSTDC_NO_DEPRECATE -#endif //_CRT_NONSTDC_NO_DEPRECATE +#endif //_CRT_NONSTDC_NO_DEPRECATE #if defined(_MSC_VER) #if _MSC_VER < 1900 @@ -162,19 +162,19 @@ using ssize_t = __int64; #else using ssize_t = long; #endif -#endif // _MSC_VER +#endif // _MSC_VER #ifndef S_ISREG #define S_ISREG(m) (((m) & S_IFREG) == S_IFREG) -#endif // S_ISREG +#endif // S_ISREG #ifndef S_ISDIR #define S_ISDIR(m) (((m) & S_IFDIR) == S_IFDIR) -#endif // S_ISDIR +#endif // S_ISDIR #ifndef NOMINMAX #define NOMINMAX -#endif // NOMINMAX +#endif // NOMINMAX #include #include @@ -189,7 +189,7 @@ using socket_t = SOCKET; #define poll(fds, nfds, timeout) WSAPoll(fds, nfds, timeout) #endif -#else // not _WIN32 +#else // not _WIN32 #include #if !defined(_AIX) && !defined(__MVS__) @@ -211,7 +211,6 @@ using socket_t = SOCKET; #ifdef CPPHTTPLIB_USE_POLL #include #endif -#include #include #include #include @@ -219,11 +218,17 @@ using socket_t = SOCKET; #include #include +#include + using socket_t = int; #ifndef INVALID_SOCKET #define INVALID_SOCKET (-1) #endif -#endif //_WIN32 +#endif //_WIN32 + +#include +#include +#include #include #include @@ -233,9 +238,7 @@ using socket_t = int; #include #include #include -#include #include -#include #include #include #include @@ -249,7 +252,6 @@ using socket_t = int; #include #include #include -#include #include #include #include @@ -274,8 +276,8 @@ using socket_t = int; #if TARGET_OS_OSX #include #include -#endif // TARGET_OS_OSX -#endif // _WIN32 +#endif // TARGET_OS_OSX +#endif // _WIN32 #include #include @@ -365,8 +367,9 @@ inline unsigned char to_lower(int c) { inline bool equal(const std::string &a, const std::string &b) { return a.size() == b.size() && - std::equal(a.begin(), a.end(), b.begin(), - [](char ca, char cb) { return to_lower(ca) == to_lower(cb); }); + std::equal(a.begin(), a.end(), b.begin(), [](char ca, char cb) { + return to_lower(ca) == to_lower(cb); + }); } struct equal_to { @@ -381,17 +384,18 @@ struct hash { } size_t hash_core(const char *s, size_t l, size_t h) const { - return (l == 0) ? h - : hash_core(s + 1, l - 1, - // Unsets the 6 high bits of h, therefore no - // overflow happens - (((std::numeric_limits::max)() >> 6) & - h * 33) ^ - static_cast(to_lower(*s))); + return (l == 0) + ? h + : hash_core( + s + 1, l - 1, + // Unsets the 6 high bits of h, therefore no + // overflow happens + (((std::numeric_limits::max)() >> 6) & h * 33) ^ + static_cast(to_lower(*s))); } }; -}; // namespace case_ignore +}; // namespace case_ignore // This is based on // "http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2014/n4189". @@ -407,12 +411,14 @@ struct scope_exit { } ~scope_exit() { - if (execute_on_destruction) { this->exit_function(); } + if (execute_on_destruction) { + this->exit_function(); + } } void release() { this->execute_on_destruction = false; } -private: + private: scope_exit(const scope_exit &) = delete; void operator=(const scope_exit &) = delete; scope_exit &operator=(scope_exit &&) = delete; @@ -421,7 +427,7 @@ struct scope_exit { bool execute_on_destruction; }; -} // namespace detail +} // namespace detail enum StatusCode { // Information responses @@ -520,7 +526,7 @@ using MultipartFormDataItems = std::vector; using MultipartFormDataMap = std::multimap; class DataSink { -public: + public: DataSink() : os(&sb_), sb_(*this) {} DataSink(const DataSink &) = delete; @@ -534,18 +540,18 @@ class DataSink { std::function done_with_trailer; std::ostream os; -private: + private: class data_sink_streambuf final : public std::streambuf { - public: + public: explicit data_sink_streambuf(DataSink &sink) : sink_(sink) {} - protected: + protected: std::streamsize xsputn(const char *s, std::streamsize n) override { sink_.write(s, static_cast(n)); return n; } - private: + private: DataSink &sink_; }; @@ -579,7 +585,7 @@ using MultipartContentHeader = std::function; class ContentReader { -public: + public: using Reader = std::function; using MultipartReader = std::function; @@ -664,7 +670,7 @@ struct Response { std::string reason; Headers headers; std::string body; - std::string location; // Redirect location + std::string location; // Redirect location bool has_header(const std::string &key) const; std::string get_header_value(const std::string &key, const char *def = "", @@ -717,7 +723,7 @@ struct Response { }; class Stream { -public: + public: virtual ~Stream() = default; virtual bool is_readable() const = 0; @@ -734,7 +740,7 @@ class Stream { }; class TaskQueue { -public: + public: TaskQueue() = default; virtual ~TaskQueue() = default; @@ -745,7 +751,7 @@ class TaskQueue { }; class ThreadPool final : public TaskQueue { -public: + public: explicit ThreadPool(size_t n, size_t mqr = 0) : shutdown_(false), max_queued_requests_(mqr) { while (n) { @@ -785,7 +791,7 @@ class ThreadPool final : public TaskQueue { } } -private: + private: struct worker { explicit worker(ThreadPool &pool) : pool_(pool) {} @@ -798,7 +804,9 @@ class ThreadPool final : public TaskQueue { pool_.cond_.wait( lock, [&] { return !pool_.jobs_.empty() || pool_.shutdown_; }); - if (pool_.shutdown_ && pool_.jobs_.empty()) { break; } + if (pool_.shutdown_ && pool_.jobs_.empty()) { + break; + } fn = pool_.jobs_.front(); pool_.jobs_.pop_front(); @@ -808,7 +816,7 @@ class ThreadPool final : public TaskQueue { fn(); } -#if defined(CPPHTTPLIB_OPENSSL_SUPPORT) && !defined(OPENSSL_IS_BORINGSSL) && \ +#if defined(CPPHTTPLIB_OPENSSL_SUPPORT) && !defined(OPENSSL_IS_BORINGSSL) && \ !defined(LIBRESSL_VERSION_NUMBER) OPENSSL_thread_stop(); #endif @@ -841,7 +849,7 @@ std::string get_bearer_token_auth(const Request &req); namespace detail { class MatcherBase { -public: + public: virtual ~MatcherBase() = default; // Match request path and populate its matches and @@ -867,12 +875,12 @@ class MatcherBase { * {{"capture", "1"}, {"second_capture", "2"}} */ class PathParamsMatcher final : public MatcherBase { -public: + public: PathParamsMatcher(const std::string &pattern); bool match(Request &request) const override; -private: + private: // Treat segment separators as the end of path parameter capture // Does not need to handle query parameters as they are parsed before path // matching @@ -896,21 +904,21 @@ class PathParamsMatcher final : public MatcherBase { * "/begin/(.*)/end" will match both "/begin/middle/end" and "/begin/1/2/end". */ class RegexMatcher final : public MatcherBase { -public: + public: RegexMatcher(const std::string &pattern) : regex_(pattern) {} bool match(Request &request) const override; -private: + private: std::regex regex_; }; ssize_t write_headers(Stream &strm, const Headers &headers); -} // namespace detail +} // namespace detail class Server { -public: + public: using Handler = std::function; using ExceptionHandler = @@ -976,8 +984,8 @@ class Server { Server &set_socket_options(SocketOptions socket_options); Server &set_default_headers(Headers headers); - Server & - set_header_writer(std::function const &writer); + Server &set_header_writer( + std::function const &writer); Server &set_keep_alive_max_count(size_t count); Server &set_keep_alive_timeout(time_t sec); @@ -1009,7 +1017,7 @@ class Server { std::function new_task_queue; -protected: + protected: bool process_request(Stream &strm, const std::string &remote_addr, int remote_port, const std::string &local_addr, int local_port, bool close_connection, @@ -1027,15 +1035,15 @@ class Server { time_t idle_interval_usec_ = CPPHTTPLIB_IDLE_INTERVAL_USECOND; size_t payload_max_length_ = CPPHTTPLIB_PAYLOAD_MAX_LENGTH; -private: + private: using Handlers = std::vector, Handler>>; using HandlersForContentReader = std::vector, HandlerWithContentReader>>; - static std::unique_ptr - make_matcher(const std::string &pattern); + static std::unique_ptr make_matcher( + const std::string &pattern); Server &set_error_handler_core(HandlerWithResponse handler, std::true_type); Server &set_error_handler_core(Handler handler, std::false_type); @@ -1069,11 +1077,10 @@ class Server { Response &res, const std::string &boundary, const std::string &content_type); bool read_content(Stream &strm, Request &req, Response &res); - bool - read_content_with_content_receiver(Stream &strm, Request &req, Response &res, - ContentReceiver receiver, - MultipartContentHeader multipart_header, - ContentReceiver multipart_receiver); + bool read_content_with_content_receiver( + Stream &strm, Request &req, Response &res, ContentReceiver receiver, + MultipartContentHeader multipart_header, + ContentReceiver multipart_receiver); bool read_content_core(Stream &strm, Request &req, Response &res, ContentReceiver receiver, MultipartContentHeader multipart_header, @@ -1150,11 +1157,12 @@ std::string to_string(Error error); std::ostream &operator<<(std::ostream &os, const Error &obj); class Result { -public: + public: Result() = default; Result(std::unique_ptr &&res, Error err, Headers &&request_headers = Headers{}) - : res_(std::move(res)), err_(err), + : res_(std::move(res)), + err_(err), request_headers_(std::move(request_headers)) {} // Response operator bool() const { return res_ != nullptr; } @@ -1179,14 +1187,14 @@ class Result { uint64_t def = 0, size_t id = 0) const; size_t get_request_header_value_count(const std::string &key) const; -private: + private: std::unique_ptr res_; Error err_ = Error::Unknown; Headers request_headers_; }; class ClientImpl { -public: + public: explicit ClientImpl(const std::string &host); explicit ClientImpl(const std::string &host, int port); @@ -1394,8 +1402,8 @@ class ClientImpl { void set_default_headers(Headers headers); - void - set_header_writer(std::function const &writer); + void set_header_writer( + std::function const &writer); void set_address_family(int family); void set_tcp_nodelay(bool on); @@ -1404,8 +1412,8 @@ class ClientImpl { void set_connection_timeout(time_t sec, time_t usec = 0); template - void - set_connection_timeout(const std::chrono::duration &duration); + void set_connection_timeout( + const std::chrono::duration &duration); void set_read_timeout(time_t sec, time_t usec = 0); template @@ -1457,7 +1465,7 @@ class ClientImpl { void set_logger(Logger logger); -protected: + protected: struct Socket { socket_t sock = INVALID_SOCKET; #ifdef CPPHTTPLIB_OPENSSL_SUPPORT @@ -1573,7 +1581,7 @@ class ClientImpl { Logger logger_; -private: + private: bool send_(Request &req, Response &res, Error &error); Result send_(Request &&req); @@ -1608,7 +1616,7 @@ class ClientImpl { }; class Client { -public: + public: // Universal interface explicit Client(const std::string &scheme_host_port); @@ -1825,8 +1833,8 @@ class Client { void set_default_headers(Headers headers); - void - set_header_writer(std::function const &writer); + void set_header_writer( + std::function const &writer); void set_address_family(int family); void set_tcp_nodelay(bool on); @@ -1834,8 +1842,8 @@ class Client { void set_connection_timeout(time_t sec, time_t usec = 0); template - void - set_connection_timeout(const std::chrono::duration &duration); + void set_connection_timeout( + const std::chrono::duration &duration); void set_read_timeout(time_t sec, time_t usec = 0); template @@ -1893,7 +1901,7 @@ class Client { SSL_CTX *ssl_context() const; #endif -private: + private: std::unique_ptr cli_; #ifdef CPPHTTPLIB_OPENSSL_SUPPORT @@ -1903,7 +1911,7 @@ class Client { #ifdef CPPHTTPLIB_OPENSSL_SUPPORT class SSLServer : public Server { -public: + public: SSLServer(const char *cert_path, const char *private_key_path, const char *client_ca_cert_file_path = nullptr, const char *client_ca_cert_dir_path = nullptr, @@ -1924,7 +1932,7 @@ class SSLServer : public Server { void update_certs(X509 *cert, EVP_PKEY *private_key, X509_STORE *client_ca_cert_store = nullptr); -private: + private: bool process_and_close_socket(socket_t sock) override; SSL_CTX *ctx_; @@ -1932,7 +1940,7 @@ class SSLServer : public Server { }; class SSLClient final : public ClientImpl { -public: + public: explicit SSLClient(const std::string &host); explicit SSLClient(const std::string &host, int port); @@ -1957,7 +1965,7 @@ class SSLClient final : public ClientImpl { SSL_CTX *ssl_context() const; -private: + private: bool create_and_connect_socket(Socket &socket, Error &error) override; void shutdown_ssl(Socket &socket, bool shutdown_gracefully) override; void shutdown_ssl_impl(Socket &socket, bool shutdown_gracefully); @@ -2016,7 +2024,7 @@ inline uint64_t get_header_value_u64(const Headers &headers, return def; } -} // namespace detail +} // namespace detail inline uint64_t Request::get_header_value_u64(const std::string &key, uint64_t def, size_t id) const { @@ -2048,77 +2056,134 @@ inline void default_socket_options(socket_t sock) { inline const char *status_message(int status) { switch (status) { - case StatusCode::Continue_100: return "Continue"; - case StatusCode::SwitchingProtocol_101: return "Switching Protocol"; - case StatusCode::Processing_102: return "Processing"; - case StatusCode::EarlyHints_103: return "Early Hints"; - case StatusCode::OK_200: return "OK"; - case StatusCode::Created_201: return "Created"; - case StatusCode::Accepted_202: return "Accepted"; - case StatusCode::NonAuthoritativeInformation_203: - return "Non-Authoritative Information"; - case StatusCode::NoContent_204: return "No Content"; - case StatusCode::ResetContent_205: return "Reset Content"; - case StatusCode::PartialContent_206: return "Partial Content"; - case StatusCode::MultiStatus_207: return "Multi-Status"; - case StatusCode::AlreadyReported_208: return "Already Reported"; - case StatusCode::IMUsed_226: return "IM Used"; - case StatusCode::MultipleChoices_300: return "Multiple Choices"; - case StatusCode::MovedPermanently_301: return "Moved Permanently"; - case StatusCode::Found_302: return "Found"; - case StatusCode::SeeOther_303: return "See Other"; - case StatusCode::NotModified_304: return "Not Modified"; - case StatusCode::UseProxy_305: return "Use Proxy"; - case StatusCode::unused_306: return "unused"; - case StatusCode::TemporaryRedirect_307: return "Temporary Redirect"; - case StatusCode::PermanentRedirect_308: return "Permanent Redirect"; - case StatusCode::BadRequest_400: return "Bad Request"; - case StatusCode::Unauthorized_401: return "Unauthorized"; - case StatusCode::PaymentRequired_402: return "Payment Required"; - case StatusCode::Forbidden_403: return "Forbidden"; - case StatusCode::NotFound_404: return "Not Found"; - case StatusCode::MethodNotAllowed_405: return "Method Not Allowed"; - case StatusCode::NotAcceptable_406: return "Not Acceptable"; - case StatusCode::ProxyAuthenticationRequired_407: - return "Proxy Authentication Required"; - case StatusCode::RequestTimeout_408: return "Request Timeout"; - case StatusCode::Conflict_409: return "Conflict"; - case StatusCode::Gone_410: return "Gone"; - case StatusCode::LengthRequired_411: return "Length Required"; - case StatusCode::PreconditionFailed_412: return "Precondition Failed"; - case StatusCode::PayloadTooLarge_413: return "Payload Too Large"; - case StatusCode::UriTooLong_414: return "URI Too Long"; - case StatusCode::UnsupportedMediaType_415: return "Unsupported Media Type"; - case StatusCode::RangeNotSatisfiable_416: return "Range Not Satisfiable"; - case StatusCode::ExpectationFailed_417: return "Expectation Failed"; - case StatusCode::ImATeapot_418: return "I'm a teapot"; - case StatusCode::MisdirectedRequest_421: return "Misdirected Request"; - case StatusCode::UnprocessableContent_422: return "Unprocessable Content"; - case StatusCode::Locked_423: return "Locked"; - case StatusCode::FailedDependency_424: return "Failed Dependency"; - case StatusCode::TooEarly_425: return "Too Early"; - case StatusCode::UpgradeRequired_426: return "Upgrade Required"; - case StatusCode::PreconditionRequired_428: return "Precondition Required"; - case StatusCode::TooManyRequests_429: return "Too Many Requests"; - case StatusCode::RequestHeaderFieldsTooLarge_431: - return "Request Header Fields Too Large"; - case StatusCode::UnavailableForLegalReasons_451: - return "Unavailable For Legal Reasons"; - case StatusCode::NotImplemented_501: return "Not Implemented"; - case StatusCode::BadGateway_502: return "Bad Gateway"; - case StatusCode::ServiceUnavailable_503: return "Service Unavailable"; - case StatusCode::GatewayTimeout_504: return "Gateway Timeout"; - case StatusCode::HttpVersionNotSupported_505: - return "HTTP Version Not Supported"; - case StatusCode::VariantAlsoNegotiates_506: return "Variant Also Negotiates"; - case StatusCode::InsufficientStorage_507: return "Insufficient Storage"; - case StatusCode::LoopDetected_508: return "Loop Detected"; - case StatusCode::NotExtended_510: return "Not Extended"; - case StatusCode::NetworkAuthenticationRequired_511: - return "Network Authentication Required"; - - default: - case StatusCode::InternalServerError_500: return "Internal Server Error"; + case StatusCode::Continue_100: + return "Continue"; + case StatusCode::SwitchingProtocol_101: + return "Switching Protocol"; + case StatusCode::Processing_102: + return "Processing"; + case StatusCode::EarlyHints_103: + return "Early Hints"; + case StatusCode::OK_200: + return "OK"; + case StatusCode::Created_201: + return "Created"; + case StatusCode::Accepted_202: + return "Accepted"; + case StatusCode::NonAuthoritativeInformation_203: + return "Non-Authoritative Information"; + case StatusCode::NoContent_204: + return "No Content"; + case StatusCode::ResetContent_205: + return "Reset Content"; + case StatusCode::PartialContent_206: + return "Partial Content"; + case StatusCode::MultiStatus_207: + return "Multi-Status"; + case StatusCode::AlreadyReported_208: + return "Already Reported"; + case StatusCode::IMUsed_226: + return "IM Used"; + case StatusCode::MultipleChoices_300: + return "Multiple Choices"; + case StatusCode::MovedPermanently_301: + return "Moved Permanently"; + case StatusCode::Found_302: + return "Found"; + case StatusCode::SeeOther_303: + return "See Other"; + case StatusCode::NotModified_304: + return "Not Modified"; + case StatusCode::UseProxy_305: + return "Use Proxy"; + case StatusCode::unused_306: + return "unused"; + case StatusCode::TemporaryRedirect_307: + return "Temporary Redirect"; + case StatusCode::PermanentRedirect_308: + return "Permanent Redirect"; + case StatusCode::BadRequest_400: + return "Bad Request"; + case StatusCode::Unauthorized_401: + return "Unauthorized"; + case StatusCode::PaymentRequired_402: + return "Payment Required"; + case StatusCode::Forbidden_403: + return "Forbidden"; + case StatusCode::NotFound_404: + return "Not Found"; + case StatusCode::MethodNotAllowed_405: + return "Method Not Allowed"; + case StatusCode::NotAcceptable_406: + return "Not Acceptable"; + case StatusCode::ProxyAuthenticationRequired_407: + return "Proxy Authentication Required"; + case StatusCode::RequestTimeout_408: + return "Request Timeout"; + case StatusCode::Conflict_409: + return "Conflict"; + case StatusCode::Gone_410: + return "Gone"; + case StatusCode::LengthRequired_411: + return "Length Required"; + case StatusCode::PreconditionFailed_412: + return "Precondition Failed"; + case StatusCode::PayloadTooLarge_413: + return "Payload Too Large"; + case StatusCode::UriTooLong_414: + return "URI Too Long"; + case StatusCode::UnsupportedMediaType_415: + return "Unsupported Media Type"; + case StatusCode::RangeNotSatisfiable_416: + return "Range Not Satisfiable"; + case StatusCode::ExpectationFailed_417: + return "Expectation Failed"; + case StatusCode::ImATeapot_418: + return "I'm a teapot"; + case StatusCode::MisdirectedRequest_421: + return "Misdirected Request"; + case StatusCode::UnprocessableContent_422: + return "Unprocessable Content"; + case StatusCode::Locked_423: + return "Locked"; + case StatusCode::FailedDependency_424: + return "Failed Dependency"; + case StatusCode::TooEarly_425: + return "Too Early"; + case StatusCode::UpgradeRequired_426: + return "Upgrade Required"; + case StatusCode::PreconditionRequired_428: + return "Precondition Required"; + case StatusCode::TooManyRequests_429: + return "Too Many Requests"; + case StatusCode::RequestHeaderFieldsTooLarge_431: + return "Request Header Fields Too Large"; + case StatusCode::UnavailableForLegalReasons_451: + return "Unavailable For Legal Reasons"; + case StatusCode::NotImplemented_501: + return "Not Implemented"; + case StatusCode::BadGateway_502: + return "Bad Gateway"; + case StatusCode::ServiceUnavailable_503: + return "Service Unavailable"; + case StatusCode::GatewayTimeout_504: + return "Gateway Timeout"; + case StatusCode::HttpVersionNotSupported_505: + return "HTTP Version Not Supported"; + case StatusCode::VariantAlsoNegotiates_506: + return "Variant Also Negotiates"; + case StatusCode::InsufficientStorage_507: + return "Insufficient Storage"; + case StatusCode::LoopDetected_508: + return "Loop Detected"; + case StatusCode::NotExtended_510: + return "Not Extended"; + case StatusCode::NetworkAuthenticationRequired_511: + return "Network Authentication Required"; + + default: + case StatusCode::InternalServerError_500: + return "Internal Server Error"; } } @@ -2132,24 +2197,24 @@ inline std::string get_bearer_token_auth(const Request &req) { } template -inline Server & -Server::set_read_timeout(const std::chrono::duration &duration) { +inline Server &Server::set_read_timeout( + const std::chrono::duration &duration) { detail::duration_to_sec_and_usec( duration, [&](time_t sec, time_t usec) { set_read_timeout(sec, usec); }); return *this; } template -inline Server & -Server::set_write_timeout(const std::chrono::duration &duration) { +inline Server &Server::set_write_timeout( + const std::chrono::duration &duration) { detail::duration_to_sec_and_usec( duration, [&](time_t sec, time_t usec) { set_write_timeout(sec, usec); }); return *this; } template -inline Server & -Server::set_idle_interval(const std::chrono::duration &duration) { +inline Server &Server::set_idle_interval( + const std::chrono::duration &duration) { detail::duration_to_sec_and_usec( duration, [&](time_t sec, time_t usec) { set_idle_interval(sec, usec); }); return *this; @@ -2157,25 +2222,40 @@ Server::set_idle_interval(const std::chrono::duration &duration) { inline std::string to_string(const Error error) { switch (error) { - case Error::Success: return "Success (no error)"; - case Error::Connection: return "Could not establish connection"; - case Error::BindIPAddress: return "Failed to bind IP address"; - case Error::Read: return "Failed to read connection"; - case Error::Write: return "Failed to write connection"; - case Error::ExceedRedirectCount: return "Maximum redirect count exceeded"; - case Error::Canceled: return "Connection handling canceled"; - case Error::SSLConnection: return "SSL connection failed"; - case Error::SSLLoadingCerts: return "SSL certificate loading failed"; - case Error::SSLServerVerification: return "SSL server verification failed"; - case Error::SSLServerHostnameVerification: - return "SSL server hostname verification failed"; - case Error::UnsupportedMultipartBoundaryChars: - return "Unsupported HTTP multipart boundary characters"; - case Error::Compression: return "Compression failed"; - case Error::ConnectionTimeout: return "Connection timed out"; - case Error::ProxyConnection: return "Proxy connection failed"; - case Error::Unknown: return "Unknown"; - default: break; + case Error::Success: + return "Success (no error)"; + case Error::Connection: + return "Could not establish connection"; + case Error::BindIPAddress: + return "Failed to bind IP address"; + case Error::Read: + return "Failed to read connection"; + case Error::Write: + return "Failed to write connection"; + case Error::ExceedRedirectCount: + return "Maximum redirect count exceeded"; + case Error::Canceled: + return "Connection handling canceled"; + case Error::SSLConnection: + return "SSL connection failed"; + case Error::SSLLoadingCerts: + return "SSL certificate loading failed"; + case Error::SSLServerVerification: + return "SSL server verification failed"; + case Error::SSLServerHostnameVerification: + return "SSL server hostname verification failed"; + case Error::UnsupportedMultipartBoundaryChars: + return "Unsupported HTTP multipart boundary characters"; + case Error::Compression: + return "Compression failed"; + case Error::ConnectionTimeout: + return "Connection timed out"; + case Error::ProxyConnection: + return "Proxy connection failed"; + case Error::Unknown: + return "Unknown"; + default: + break; } return "Invalid"; @@ -2222,14 +2302,14 @@ inline void Client::set_connection_timeout( } template -inline void -Client::set_read_timeout(const std::chrono::duration &duration) { +inline void Client::set_read_timeout( + const std::chrono::duration &duration) { cli_->set_read_timeout(duration); } template -inline void -Client::set_write_timeout(const std::chrono::duration &duration) { +inline void Client::set_write_timeout( + const std::chrono::duration &duration) { cli_->set_write_timeout(duration); } @@ -2246,10 +2326,9 @@ std::string append_query_params(const std::string &path, const Params ¶ms); std::pair make_range_header(const Ranges &ranges); -std::pair -make_basic_authentication_header(const std::string &username, - const std::string &password, - bool is_proxy = false); +std::pair make_basic_authentication_header( + const std::string &username, const std::string &password, + bool is_proxy = false); namespace detail { @@ -2258,7 +2337,7 @@ struct FileStat { bool is_file() const; bool is_dir() const; -private: + private: struct stat st_; int ret_ = -1; }; @@ -2327,7 +2406,7 @@ enum class EncodingType { None = 0, Gzip, Brotli }; EncodingType encoding_type(const Request &req, const Response &res); class BufferStream final : public Stream { -public: + public: BufferStream() = default; ~BufferStream() override = default; @@ -2341,13 +2420,13 @@ class BufferStream final : public Stream { const std::string &get_buffer() const; -private: + private: std::string buffer; size_t position = 0; }; class compressor { -public: + public: virtual ~compressor() = default; typedef std::function Callback; @@ -2356,7 +2435,7 @@ class compressor { }; class decompressor { -public: + public: virtual ~decompressor() = default; virtual bool is_valid() const = 0; @@ -2367,7 +2446,7 @@ class decompressor { }; class nocompressor final : public compressor { -public: + public: ~nocompressor() override = default; bool compress(const char *data, size_t data_length, bool /*last*/, @@ -2376,20 +2455,20 @@ class nocompressor final : public compressor { #ifdef CPPHTTPLIB_ZLIB_SUPPORT class gzip_compressor final : public compressor { -public: + public: gzip_compressor(); ~gzip_compressor() override; bool compress(const char *data, size_t data_length, bool last, Callback callback) override; -private: + private: bool is_valid_ = false; z_stream strm_; }; class gzip_decompressor final : public decompressor { -public: + public: gzip_decompressor(); ~gzip_decompressor() override; @@ -2398,7 +2477,7 @@ class gzip_decompressor final : public decompressor { bool decompress(const char *data, size_t data_length, Callback callback) override; -private: + private: bool is_valid_ = false; z_stream strm_; }; @@ -2406,19 +2485,19 @@ class gzip_decompressor final : public decompressor { #ifdef CPPHTTPLIB_BROTLI_SUPPORT class brotli_compressor final : public compressor { -public: + public: brotli_compressor(); ~brotli_compressor(); bool compress(const char *data, size_t data_length, bool last, Callback callback) override; -private: + private: BrotliEncoderState *state_ = nullptr; }; class brotli_decompressor final : public decompressor { -public: + public: brotli_decompressor(); ~brotli_decompressor(); @@ -2427,7 +2506,7 @@ class brotli_decompressor final : public decompressor { bool decompress(const char *data, size_t data_length, Callback callback) override; -private: + private: BrotliDecoderResult decoder_r; BrotliDecoderState *decoder_s = nullptr; }; @@ -2436,7 +2515,7 @@ class brotli_decompressor final : public decompressor { // NOTE: until the read size reaches `fixed_buffer_size`, use `fixed_buffer` // to store data. The call can set memory on stack for performance. class stream_line_reader { -public: + public: stream_line_reader(Stream &strm, char *fixed_buffer, size_t fixed_buffer_size); const char *ptr() const; @@ -2444,7 +2523,7 @@ class stream_line_reader { bool end_with_crlf() const; bool getline(); -private: + private: void append(char c); Stream &strm_; @@ -2455,7 +2534,7 @@ class stream_line_reader { }; class mmap { -public: + public: mmap(const char *path); ~mmap(); @@ -2466,7 +2545,7 @@ class mmap { size_t size() const; const char *data() const; -private: + private: #if defined(_WIN32) HANDLE hFile_ = NULL; HANDLE hMapping_ = NULL; @@ -2478,7 +2557,7 @@ class mmap { bool is_open_empty_file = false; }; -} // namespace detail +} // namespace detail // ---------------------------------------------------------------------------- @@ -2504,11 +2583,15 @@ inline bool is_hex(char c, int &v) { inline bool from_hex_to_i(const std::string &s, size_t i, size_t cnt, int &val) { - if (i >= s.size()) { return false; } + if (i >= s.size()) { + return false; + } val = 0; for (; cnt; i++, cnt--) { - if (!s[i]) { return false; } + if (!s[i]) { + return false; + } auto v = 0; if (is_hex(s[i], v)) { val = val * 16 + v; @@ -2542,7 +2625,7 @@ inline size_t to_utf8(int code, char *buff) { buff[1] = static_cast(0x80 | ((code >> 6) & 0x3F)); buff[2] = static_cast(0x80 | (code & 0x3F)); return 3; - } else if (code < 0xE000) { // D800 - DFFF is invalid... + } else if (code < 0xE000) { // D800 - DFFF is invalid... return 0; } else if (code < 0x10000) { buff[0] = static_cast(0xE0 | ((code >> 12) & 0xF)); @@ -2582,7 +2665,9 @@ inline std::string base64_encode(const std::string &in) { } } - if (valb > -6) { out.push_back(lookup[((val << 8) >> (valb + 8)) & 0x3F]); } + if (valb > -6) { + out.push_back(lookup[((val << 8) >> (valb + 8)) & 0x3F]); + } while (out.size() % 4) { out.push_back('='); @@ -2618,7 +2703,9 @@ inline bool is_valid_path(const std::string &path) { if (!path.compare(beg, len, ".")) { ; } else if (!path.compare(beg, len, "..")) { - if (level == 0) { return false; } + if (level == 0) { + return false; + } level--; } else { level++; @@ -2670,26 +2757,40 @@ inline std::string encode_url(const std::string &s) { for (size_t i = 0; s[i]; i++) { switch (s[i]) { - case ' ': result += "%20"; break; - case '+': result += "%2B"; break; - case '\r': result += "%0D"; break; - case '\n': result += "%0A"; break; - case '\'': result += "%27"; break; - case ',': result += "%2C"; break; - // case ':': result += "%3A"; break; // ok? probably... - case ';': result += "%3B"; break; - default: - auto c = static_cast(s[i]); - if (c >= 0x80) { - result += '%'; - char hex[4]; - auto len = snprintf(hex, sizeof(hex) - 1, "%02X", c); - assert(len == 2); - result.append(hex, static_cast(len)); - } else { - result += s[i]; - } - break; + case ' ': + result += "%20"; + break; + case '+': + result += "%2B"; + break; + case '\r': + result += "%0D"; + break; + case '\n': + result += "%0A"; + break; + case '\'': + result += "%27"; + break; + case ',': + result += "%2C"; + break; + // case ':': result += "%3A"; break; // ok? probably... + case ';': + result += "%3B"; + break; + default: + auto c = static_cast(s[i]); + if (c >= 0x80) { + result += '%'; + char hex[4]; + auto len = snprintf(hex, sizeof(hex) - 1, "%02X", c); + assert(len == 2); + result.append(hex, static_cast(len)); + } else { + result += s[i]; + } + break; } } @@ -2708,8 +2809,10 @@ inline std::string decode_url(const std::string &s, // 4 digits Unicode codes char buff[4]; size_t len = to_utf8(val, buff); - if (len > 0) { result.append(buff, len); } - i += 5; // 'u0000' + if (len > 0) { + result.append(buff, len); + } + i += 5; // 'u0000' } else { result += s[i]; } @@ -2718,7 +2821,7 @@ inline std::string decode_url(const std::string &s, if (from_hex_to_i(s, i + 1, 2, val)) { // 2 digits hex codes result += static_cast(val); - i += 2; // '00' + i += 2; // '00' } else { result += s[i]; } @@ -2745,7 +2848,9 @@ inline void read_file(const std::string &path, std::string &out) { inline std::string file_extension(const std::string &path) { std::smatch m; static auto re = std::regex("\\.([a-zA-Z0-9]+)$"); - if (std::regex_search(path, m, re)) { return m[1].str(); } + if (std::regex_search(path, m, re)) { + return m[1].str(); + } return std::string(); } @@ -2774,10 +2879,10 @@ inline std::string trim_double_quotes_copy(const std::string &s) { return s; } -inline void -divide(const char *data, std::size_t size, char d, - std::function - fn) { +inline void divide( + const char *data, std::size_t size, char d, + std::function + fn) { const auto it = std::find(data, data + size, d); const auto found = static_cast(it != data + size); const auto lhs_data = data; @@ -2788,10 +2893,10 @@ divide(const char *data, std::size_t size, char d, fn(lhs_data, lhs_size, rhs_data, rhs_size); } -inline void -divide(const std::string &str, char d, - std::function - fn) { +inline void divide( + const std::string &str, char d, + std::function + fn) { divide(str.data(), str.size(), d, std::move(fn)); } @@ -2809,7 +2914,9 @@ inline void split(const char *b, const char *e, char d, size_t m, while (e ? (b + i < e) : (b[i] != '\0')) { if (b[i] == d && count < m) { auto r = trim(b, e, beg, i); - if (r.first < r.second) { fn(&b[r.first], &b[r.second]); } + if (r.first < r.second) { + fn(&b[r.first], &b[r.second]); + } beg = i + 1; count++; } @@ -2818,13 +2925,16 @@ inline void split(const char *b, const char *e, char d, size_t m, if (i) { auto r = trim(b, e, beg, i); - if (r.first < r.second) { fn(&b[r.first], &b[r.second]); } + if (r.first < r.second) { + fn(&b[r.first], &b[r.second]); + } } } inline stream_line_reader::stream_line_reader(Stream &strm, char *fixed_buffer, size_t fixed_buffer_size) - : strm_(strm), fixed_buffer_(fixed_buffer), + : strm_(strm), + fixed_buffer_(fixed_buffer), fixed_buffer_size_(fixed_buffer_size) {} inline const char *stream_line_reader::ptr() const { @@ -2873,9 +2983,13 @@ inline bool stream_line_reader::getline() { append(byte); #ifdef CPPHTTPLIB_ALLOW_LF_AS_LINE_TERMINATOR - if (byte == '\n') { break; } + if (byte == '\n') { + break; + } #else - if (prev_byte == '\r' && byte == '\n') { break; } + if (prev_byte == '\r' && byte == '\n') { + break; + } prev_byte = byte; #endif } @@ -2896,9 +3010,7 @@ inline void stream_line_reader::append(char c) { } } -inline mmap::mmap(const char *path) { - open(path); -} +inline mmap::mmap(const char *path) { open(path); } inline mmap::~mmap() { close(); } @@ -2919,10 +3031,14 @@ inline bool mmap::open(const char *path) { OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); #endif - if (hFile_ == INVALID_HANDLE_VALUE) { return false; } + if (hFile_ == INVALID_HANDLE_VALUE) { + return false; + } LARGE_INTEGER size{}; - if (!::GetFileSizeEx(hFile_, &size)) { return false; } + if (!::GetFileSizeEx(hFile_, &size)) { + return false; + } // If the following line doesn't compile due to QuadPart, update Windows SDK. // See: // https://github.com/yhirose/cpp-httplib/issues/1903#issuecomment-2316520721 @@ -2964,7 +3080,9 @@ inline bool mmap::open(const char *path) { } #else fd_ = ::open(path, O_RDONLY); - if (fd_ == -1) { return false; } + if (fd_ == -1) { + return false; + } struct stat sb; if (fstat(fd_, &sb) == -1) { @@ -3035,7 +3153,8 @@ inline int close_socket(socket_t sock) { #endif } -template inline ssize_t handle_EINTR(T fn) { +template +inline ssize_t handle_EINTR(T fn) { ssize_t res = 0; while (true) { res = fn(); @@ -3084,7 +3203,9 @@ inline ssize_t select_read(socket_t sock, time_t sec, time_t usec) { return handle_EINTR([&]() { return poll(&pfd_read, 1, timeout); }); #else #ifndef _WIN32 - if (sock >= FD_SETSIZE) { return -1; } + if (sock >= FD_SETSIZE) { + return -1; + } #endif fd_set fds; @@ -3112,7 +3233,9 @@ inline ssize_t select_write(socket_t sock, time_t sec, time_t usec) { return handle_EINTR([&]() { return poll(&pfd_read, 1, timeout); }); #else #ifndef _WIN32 - if (sock >= FD_SETSIZE) { return -1; } + if (sock >= FD_SETSIZE) { + return -1; + } #endif fd_set fds; @@ -3140,7 +3263,9 @@ inline Error wait_until_socket_is_ready(socket_t sock, time_t sec, auto poll_res = handle_EINTR([&]() { return poll(&pfd_read, 1, timeout); }); - if (poll_res == 0) { return Error::ConnectionTimeout; } + if (poll_res == 0) { + return Error::ConnectionTimeout; + } if (poll_res > 0 && pfd_read.revents & (POLLIN | POLLOUT)) { auto error = 0; @@ -3154,7 +3279,9 @@ inline Error wait_until_socket_is_ready(socket_t sock, time_t sec, return Error::Connection; #else #ifndef _WIN32 - if (sock >= FD_SETSIZE) { return Error::Connection; } + if (sock >= FD_SETSIZE) { + return Error::Connection; + } #endif fd_set fdsr; @@ -3172,7 +3299,9 @@ inline Error wait_until_socket_is_ready(socket_t sock, time_t sec, return select(static_cast(sock + 1), &fdsr, &fdsw, &fdse, &tv); }); - if (ret == 0) { return Error::ConnectionTimeout; } + if (ret == 0) { + return Error::ConnectionTimeout; + } if (ret > 0 && (FD_ISSET(sock, &fdsr) || FD_ISSET(sock, &fdsw))) { auto error = 0; @@ -3198,7 +3327,7 @@ inline bool is_socket_alive(socket_t sock) { } class SocketStream final : public Stream { -public: + public: SocketStream(socket_t sock, time_t read_timeout_sec, time_t read_timeout_usec, time_t write_timeout_sec, time_t write_timeout_usec); ~SocketStream() override; @@ -3211,7 +3340,7 @@ class SocketStream final : public Stream { void get_local_ip_and_port(std::string &ip, int &port) const override; socket_t socket() const override; -private: + private: socket_t sock_; time_t read_timeout_sec_; time_t read_timeout_usec_; @@ -3227,7 +3356,7 @@ class SocketStream final : public Stream { #ifdef CPPHTTPLIB_OPENSSL_SUPPORT class SSLSocketStream final : public Stream { -public: + public: SSLSocketStream(socket_t sock, SSL *ssl, time_t read_timeout_sec, time_t read_timeout_usec, time_t write_timeout_sec, time_t write_timeout_usec); @@ -3241,7 +3370,7 @@ class SSLSocketStream final : public Stream { void get_local_ip_and_port(std::string &ip, int &port) const override; socket_t socket() const override; -private: + private: socket_t sock_; SSL *ssl_; time_t read_timeout_sec_; @@ -3252,10 +3381,11 @@ class SSLSocketStream final : public Stream { #endif template -inline bool -process_server_socket_core(const std::atomic &svr_sock, socket_t sock, - size_t keep_alive_max_count, - time_t keep_alive_timeout_sec, T callback) { +inline bool process_server_socket_core(const std::atomic &svr_sock, + socket_t sock, + size_t keep_alive_max_count, + time_t keep_alive_timeout_sec, + T callback) { assert(keep_alive_max_count > 0); auto ret = false; auto count = keep_alive_max_count; @@ -3264,19 +3394,22 @@ process_server_socket_core(const std::atomic &svr_sock, socket_t sock, auto close_connection = count == 1; auto connection_closed = false; ret = callback(close_connection, connection_closed); - if (!ret || connection_closed) { break; } + if (!ret || connection_closed) { + break; + } count--; } return ret; } template -inline bool -process_server_socket(const std::atomic &svr_sock, socket_t sock, - size_t keep_alive_max_count, - time_t keep_alive_timeout_sec, time_t read_timeout_sec, - time_t read_timeout_usec, time_t write_timeout_sec, - time_t write_timeout_usec, T callback) { +inline bool process_server_socket(const std::atomic &svr_sock, + socket_t sock, size_t keep_alive_max_count, + time_t keep_alive_timeout_sec, + time_t read_timeout_sec, + time_t read_timeout_usec, + time_t write_timeout_sec, + time_t write_timeout_usec, T callback) { return process_server_socket_core( svr_sock, sock, keep_alive_max_count, keep_alive_timeout_sec, [&](bool close_connection, bool &connection_closed) { @@ -3313,8 +3446,8 @@ inline std::string escape_abstract_namespace_unix_domain(const std::string &s) { return s; } -inline std::string -unescape_abstract_namespace_unix_domain(const std::string &s) { +inline std::string unescape_abstract_namespace_unix_domain( + const std::string &s) { if (s.size() > 1 && s[0] == '@') { auto ret = s; ret[0] = '\0'; @@ -3343,7 +3476,9 @@ socket_t create_socket(const std::string &host, const std::string &ip, int port, hints.ai_family = AF_UNSPEC; hints.ai_flags = AI_NUMERICHOST; } else { - if (!host.empty()) { node = host.c_str(); } + if (!host.empty()) { + node = host.c_str(); + } hints.ai_family = address_family; hints.ai_flags = socket_flags; } @@ -3351,7 +3486,9 @@ socket_t create_socket(const std::string &host, const std::string &ip, int port, #ifndef _WIN32 if (hints.ai_family == AF_UNIX) { const auto addrlen = host.length(); - if (addrlen > sizeof(sockaddr_un::sun_path)) { return INVALID_SOCKET; } + if (addrlen > sizeof(sockaddr_un::sun_path)) { + return INVALID_SOCKET; + } #ifdef SOCK_CLOEXEC auto sock = socket(hints.ai_family, hints.ai_socktype | SOCK_CLOEXEC, @@ -3375,7 +3512,9 @@ socket_t create_socket(const std::string &host, const std::string &ip, int port, fcntl(sock, F_SETFD, FD_CLOEXEC); #endif - if (socket_options) { socket_options(sock); } + if (socket_options) { + socket_options(sock); + } bool dummy; if (!bind_or_connect(sock, hints, dummy)) { @@ -3430,7 +3569,9 @@ socket_t create_socket(const std::string &host, const std::string &ip, int port, #endif #endif - if (sock == INVALID_SOCKET) { continue; } + if (sock == INVALID_SOCKET) { + continue; + } #if !defined _WIN32 && !defined SOCK_CLOEXEC if (fcntl(sock, F_SETFD, FD_CLOEXEC) == -1) { @@ -3461,15 +3602,21 @@ socket_t create_socket(const std::string &host, const std::string &ip, int port, #endif } - if (socket_options) { socket_options(sock); } + if (socket_options) { + socket_options(sock); + } // bind or connect auto quit = false; - if (bind_or_connect(sock, *rp, quit)) { return sock; } + if (bind_or_connect(sock, *rp, quit)) { + return sock; + } close_socket(sock); - if (quit) { break; } + if (quit) { + break; + } } return INVALID_SOCKET; @@ -3503,7 +3650,9 @@ inline bool bind_ip_address(socket_t sock, const std::string &host) { hints.ai_socktype = SOCK_STREAM; hints.ai_protocol = 0; - if (getaddrinfo(host.c_str(), "0", &hints, &result)) { return false; } + if (getaddrinfo(host.c_str(), "0", &hints, &result)) { + return false; + } auto se = detail::scope_exit([&] { freeaddrinfo(result); }); auto ret = false; @@ -3574,7 +3723,9 @@ inline socket_t create_client_socket( if (!intf.empty()) { #ifdef USE_IF2IP auto ip_from_if = if2ip(address_family, intf); - if (ip_from_if.empty()) { ip_from_if = intf; } + if (ip_from_if.empty()) { + ip_from_if = intf; + } if (!bind_ip_address(sock2, ip_from_if)) { error = Error::BindIPAddress; return false; @@ -3595,7 +3746,9 @@ inline socket_t create_client_socket( error = wait_until_socket_is_ready(sock2, connection_timeout_sec, connection_timeout_usec); if (error != Error::Success) { - if (error == Error::ConnectionTimeout) { quit = true; } + if (error == Error::ConnectionTimeout) { + quit = true; + } return false; } } @@ -3639,7 +3792,9 @@ inline socket_t create_client_socket( if (sock != INVALID_SOCKET) { error = Error::Success; } else { - if (error == Error::Success) { error = Error::Connection; } + if (error == Error::Success) { + error = Error::Connection; + } } return sock; @@ -3690,7 +3845,7 @@ inline void get_remote_ip_and_port(socket_t sock, std::string &ip, int &port) { if (getsockopt(sock, SOL_SOCKET, SO_PEERCRED, &ucred, &len) == 0) { port = ucred.pid; } -#elif defined(SOL_LOCAL) && defined(SO_PEERPID) // __APPLE__ +#elif defined(SOL_LOCAL) && defined(SO_PEERPID) // __APPLE__ pid_t pid; socklen_t len = sizeof(pid); if (getsockopt(sock, SOL_LOCAL, SO_PEERPID, &pid, &len) == 0) { @@ -3726,71 +3881,114 @@ inline constexpr unsigned int operator"" _t(const char *s, size_t l) { return str2tag_core(s, l, 0); } -} // namespace udl +} // namespace udl -inline std::string -find_content_type(const std::string &path, - const std::map &user_data, - const std::string &default_content_type) { +inline std::string find_content_type( + const std::string &path, + const std::map &user_data, + const std::string &default_content_type) { auto ext = file_extension(path); auto it = user_data.find(ext); - if (it != user_data.end()) { return it->second; } + if (it != user_data.end()) { + return it->second; + } using udl::operator""_t; switch (str2tag(ext)) { - default: return default_content_type; - - case "css"_t: return "text/css"; - case "csv"_t: return "text/csv"; - case "htm"_t: - case "html"_t: return "text/html"; - case "js"_t: - case "mjs"_t: return "text/javascript"; - case "txt"_t: return "text/plain"; - case "vtt"_t: return "text/vtt"; - - case "apng"_t: return "image/apng"; - case "avif"_t: return "image/avif"; - case "bmp"_t: return "image/bmp"; - case "gif"_t: return "image/gif"; - case "png"_t: return "image/png"; - case "svg"_t: return "image/svg+xml"; - case "webp"_t: return "image/webp"; - case "ico"_t: return "image/x-icon"; - case "tif"_t: return "image/tiff"; - case "tiff"_t: return "image/tiff"; - case "jpg"_t: - case "jpeg"_t: return "image/jpeg"; - - case "mp4"_t: return "video/mp4"; - case "mpeg"_t: return "video/mpeg"; - case "webm"_t: return "video/webm"; - - case "mp3"_t: return "audio/mp3"; - case "mpga"_t: return "audio/mpeg"; - case "weba"_t: return "audio/webm"; - case "wav"_t: return "audio/wave"; - - case "otf"_t: return "font/otf"; - case "ttf"_t: return "font/ttf"; - case "woff"_t: return "font/woff"; - case "woff2"_t: return "font/woff2"; - - case "7z"_t: return "application/x-7z-compressed"; - case "atom"_t: return "application/atom+xml"; - case "pdf"_t: return "application/pdf"; - case "json"_t: return "application/json"; - case "rss"_t: return "application/rss+xml"; - case "tar"_t: return "application/x-tar"; - case "xht"_t: - case "xhtml"_t: return "application/xhtml+xml"; - case "xslt"_t: return "application/xslt+xml"; - case "xml"_t: return "application/xml"; - case "gz"_t: return "application/gzip"; - case "zip"_t: return "application/zip"; - case "wasm"_t: return "application/wasm"; + default: + return default_content_type; + + case "css"_t: + return "text/css"; + case "csv"_t: + return "text/csv"; + case "htm"_t: + case "html"_t: + return "text/html"; + case "js"_t: + case "mjs"_t: + return "text/javascript"; + case "txt"_t: + return "text/plain"; + case "vtt"_t: + return "text/vtt"; + + case "apng"_t: + return "image/apng"; + case "avif"_t: + return "image/avif"; + case "bmp"_t: + return "image/bmp"; + case "gif"_t: + return "image/gif"; + case "png"_t: + return "image/png"; + case "svg"_t: + return "image/svg+xml"; + case "webp"_t: + return "image/webp"; + case "ico"_t: + return "image/x-icon"; + case "tif"_t: + return "image/tiff"; + case "tiff"_t: + return "image/tiff"; + case "jpg"_t: + case "jpeg"_t: + return "image/jpeg"; + + case "mp4"_t: + return "video/mp4"; + case "mpeg"_t: + return "video/mpeg"; + case "webm"_t: + return "video/webm"; + + case "mp3"_t: + return "audio/mp3"; + case "mpga"_t: + return "audio/mpeg"; + case "weba"_t: + return "audio/webm"; + case "wav"_t: + return "audio/wave"; + + case "otf"_t: + return "font/otf"; + case "ttf"_t: + return "font/ttf"; + case "woff"_t: + return "font/woff"; + case "woff2"_t: + return "font/woff2"; + + case "7z"_t: + return "application/x-7z-compressed"; + case "atom"_t: + return "application/atom+xml"; + case "pdf"_t: + return "application/pdf"; + case "json"_t: + return "application/json"; + case "rss"_t: + return "application/rss+xml"; + case "tar"_t: + return "application/x-tar"; + case "xht"_t: + case "xhtml"_t: + return "application/xhtml+xml"; + case "xslt"_t: + return "application/xslt+xml"; + case "xml"_t: + return "application/xml"; + case "gz"_t: + return "application/gzip"; + case "zip"_t: + return "application/zip"; + case "wasm"_t: + return "application/wasm"; } } @@ -3800,23 +3998,28 @@ inline bool can_compress_content_type(const std::string &content_type) { auto tag = str2tag(content_type); switch (tag) { - case "image/svg+xml"_t: - case "application/javascript"_t: - case "application/json"_t: - case "application/xml"_t: - case "application/protobuf"_t: - case "application/xhtml+xml"_t: return true; + case "image/svg+xml"_t: + case "application/javascript"_t: + case "application/json"_t: + case "application/xml"_t: + case "application/protobuf"_t: + case "application/xhtml+xml"_t: + return true; - case "text/event-stream"_t: return false; + case "text/event-stream"_t: + return false; - default: return !content_type.rfind("text/", 0); + default: + return !content_type.rfind("text/", 0); } } inline EncodingType encoding_type(const Request &req, const Response &res) { auto ret = detail::can_compress_content_type(res.get_header_value("Content-Type")); - if (!ret) { return EncodingType::None; } + if (!ret) { + return EncodingType::None; + } const auto &s = req.get_header_value("Accept-Encoding"); (void)(s); @@ -3824,13 +4027,17 @@ inline EncodingType encoding_type(const Request &req, const Response &res) { #ifdef CPPHTTPLIB_BROTLI_SUPPORT // TODO: 'Accept-Encoding' has br, not br;q=0 ret = s.find("br") != std::string::npos; - if (ret) { return EncodingType::Brotli; } + if (ret) { + return EncodingType::Brotli; + } #endif #ifdef CPPHTTPLIB_ZLIB_SUPPORT // TODO: 'Accept-Encoding' has gzip, not gzip;q=0 ret = s.find("gzip") != std::string::npos; - if (ret) { return EncodingType::Gzip; } + if (ret) { + return EncodingType::Gzip; + } #endif return EncodingType::None; @@ -3838,7 +4045,9 @@ inline EncodingType encoding_type(const Request &req, const Response &res) { inline bool nocompressor::compress(const char *data, size_t data_length, bool /*last*/, Callback callback) { - if (!data_length) { return true; } + if (!data_length) { + return true; + } return callback(data, data_length); } @@ -3879,7 +4088,9 @@ inline bool gzip_compressor::compress(const char *data, size_t data_length, strm_.next_out = reinterpret_cast(buff.data()); ret = deflate(&strm_, flush); - if (ret == Z_STREAM_ERROR) { return false; } + if (ret == Z_STREAM_ERROR) { + return false; + } if (!callback(buff.data(), buff.size() - strm_.avail_out)) { return false; @@ -3937,9 +4148,11 @@ inline bool gzip_decompressor::decompress(const char *data, size_t data_length, assert(ret != Z_STREAM_ERROR); switch (ret) { - case Z_NEED_DICT: - case Z_DATA_ERROR: - case Z_MEM_ERROR: inflateEnd(&strm_); return false; + case Z_NEED_DICT: + case Z_DATA_ERROR: + case Z_MEM_ERROR: + inflateEnd(&strm_); + return false; } if (!callback(buff.data(), buff.size() - strm_.avail_out)) { @@ -3947,7 +4160,9 @@ inline bool gzip_decompressor::decompress(const char *data, size_t data_length, } } - if (ret != Z_OK && ret != Z_STREAM_END) { return false; } + if (ret != Z_OK && ret != Z_STREAM_END) { + return false; + } } while (data_length > 0); @@ -3974,9 +4189,13 @@ inline bool brotli_compressor::compress(const char *data, size_t data_length, for (;;) { if (last) { - if (BrotliEncoderIsFinished(state_)) { break; } + if (BrotliEncoderIsFinished(state_)) { + break; + } } else { - if (!available_in) { break; } + if (!available_in) { + break; + } } auto available_out = buff.size(); @@ -4003,7 +4222,9 @@ inline brotli_decompressor::brotli_decompressor() { } inline brotli_decompressor::~brotli_decompressor() { - if (decoder_s) { BrotliDecoderDestroyInstance(decoder_s); } + if (decoder_s) { + BrotliDecoderDestroyInstance(decoder_s); + } } inline bool brotli_decompressor::is_valid() const { return decoder_s; } @@ -4031,9 +4252,13 @@ inline bool brotli_decompressor::decompress(const char *data, decoder_s, &avail_in, &next_in, &avail_out, reinterpret_cast(&next_out), &total_out); - if (decoder_r == BROTLI_DECODER_RESULT_ERROR) { return false; } + if (decoder_r == BROTLI_DECODER_RESULT_ERROR) { + return false; + } - if (!callback(buff.data(), buff.size() - avail_out)) { return false; } + if (!callback(buff.data(), buff.size() - avail_out)) { + return false; + } } return decoder_r == BROTLI_DECODER_RESULT_SUCCESS || @@ -4051,7 +4276,9 @@ inline const char *get_header_value(const Headers &headers, auto rng = headers.equal_range(key); auto it = rng.first; std::advance(it, static_cast(id)); - if (it != rng.second) { return it->second.c_str(); } + if (it != rng.second) { + return it->second.c_str(); + } return def; } @@ -4067,11 +4294,15 @@ inline bool parse_header(const char *beg, const char *end, T fn) { p++; } - if (p == end) { return false; } + if (p == end) { + return false; + } auto key_end = p; - if (*p++ != ':') { return false; } + if (*p++ != ':') { + return false; + } while (p < end && is_space_or_tab(*p)) { p++; @@ -4079,7 +4310,9 @@ inline bool parse_header(const char *beg, const char *end, T fn) { if (p < end) { auto key_len = key_end - beg; - if (!key_len) { return false; } + if (!key_len) { + return false; + } auto key = std::string(beg, key_end); auto val = case_ignore::equal(key, "Location") @@ -4095,7 +4328,9 @@ inline bool parse_header(const char *beg, const char *end, T fn) { // those characters with SP before further processing or // forwarding of that message. static const std::string CR_LF_NUL("\r\n\0", 3); - if (val.find_first_of(CR_LF_NUL) != std::string::npos) { return false; } + if (val.find_first_of(CR_LF_NUL) != std::string::npos) { + return false; + } fn(key, val); return true; @@ -4110,24 +4345,32 @@ inline bool read_headers(Stream &strm, Headers &headers) { stream_line_reader line_reader(strm, buf, bufsiz); for (;;) { - if (!line_reader.getline()) { return false; } + if (!line_reader.getline()) { + return false; + } // Check if the line ends with CRLF. auto line_terminator_len = 2; if (line_reader.end_with_crlf()) { // Blank line indicates end of headers. - if (line_reader.size() == 2) { break; } + if (line_reader.size() == 2) { + break; + } } else { #ifdef CPPHTTPLIB_ALLOW_LF_AS_LINE_TERMINATOR // Blank line indicates end of headers. - if (line_reader.size() == 1) { break; } + if (line_reader.size() == 1) { + break; + } line_terminator_len = 1; #else - continue; // Skip invalid line. + continue; // Skip invalid line. #endif } - if (line_reader.size() > CPPHTTPLIB_HEADER_MAX_LENGTH) { return false; } + if (line_reader.size() > CPPHTTPLIB_HEADER_MAX_LENGTH) { + return false; + } // Exclude line terminator auto end = line_reader.ptr() + line_reader.size() - line_terminator_len; @@ -4152,13 +4395,19 @@ inline bool read_content_with_length(Stream &strm, uint64_t len, while (r < len) { auto read_len = static_cast(len - r); auto n = strm.read(buf, (std::min)(read_len, CPPHTTPLIB_RECV_BUFSIZ)); - if (n <= 0) { return false; } + if (n <= 0) { + return false; + } - if (!out(buf, static_cast(n), r, len)) { return false; } + if (!out(buf, static_cast(n), r, len)) { + return false; + } r += static_cast(n); if (progress) { - if (!progress(r, len)) { return false; } + if (!progress(r, len)) { + return false; + } } } @@ -4171,7 +4420,9 @@ inline void skip_content_with_length(Stream &strm, uint64_t len) { while (r < len) { auto read_len = static_cast(len - r); auto n = strm.read(buf, (std::min)(read_len, CPPHTTPLIB_RECV_BUFSIZ)); - if (n <= 0) { return; } + if (n <= 0) { + return; + } r += static_cast(n); } } @@ -4182,9 +4433,13 @@ inline bool read_content_without_length(Stream &strm, uint64_t r = 0; for (;;) { auto n = strm.read(buf, CPPHTTPLIB_RECV_BUFSIZ); - if (n <= 0) { return true; } + if (n <= 0) { + return true; + } - if (!out(buf, static_cast(n), r, 0)) { return false; } + if (!out(buf, static_cast(n), r, 0)) { + return false; + } r += static_cast(n); } @@ -4199,7 +4454,9 @@ inline bool read_content_chunked(Stream &strm, T &x, stream_line_reader line_reader(strm, buf, bufsiz); - if (!line_reader.getline()) { return false; } + if (!line_reader.getline()) { + return false; + } unsigned long chunk_len; while (true) { @@ -4207,20 +4464,32 @@ inline bool read_content_chunked(Stream &strm, T &x, chunk_len = std::strtoul(line_reader.ptr(), &end_ptr, 16); - if (end_ptr == line_reader.ptr()) { return false; } - if (chunk_len == ULONG_MAX) { return false; } + if (end_ptr == line_reader.ptr()) { + return false; + } + if (chunk_len == ULONG_MAX) { + return false; + } - if (chunk_len == 0) { break; } + if (chunk_len == 0) { + break; + } if (!read_content_with_length(strm, chunk_len, nullptr, out)) { return false; } - if (!line_reader.getline()) { return false; } + if (!line_reader.getline()) { + return false; + } - if (strcmp(line_reader.ptr(), "\r\n") != 0) { return false; } + if (strcmp(line_reader.ptr(), "\r\n") != 0) { + return false; + } - if (!line_reader.getline()) { return false; } + if (!line_reader.getline()) { + return false; + } } assert(chunk_len == 0); @@ -4237,10 +4506,14 @@ inline bool read_content_chunked(Stream &strm, T &x, // // According to the reference code in RFC 9112, cpp-htpplib now allows // chuncked transfer coding data without the final CRLF. - if (!line_reader.getline()) { return true; } + if (!line_reader.getline()) { + return true; + } while (strcmp(line_reader.ptr(), "\r\n") != 0) { - if (line_reader.size() > CPPHTTPLIB_HEADER_MAX_LENGTH) { return false; } + if (line_reader.size() > CPPHTTPLIB_HEADER_MAX_LENGTH) { + return false; + } // Exclude line terminator constexpr auto line_terminator_len = 2; @@ -4251,7 +4524,9 @@ inline bool read_content_chunked(Stream &strm, T &x, x.headers.emplace(key, val); }); - if (!line_reader.getline()) { return false; } + if (!line_reader.getline()) { + return false; + } } return true; @@ -4371,11 +4646,15 @@ inline ssize_t write_headers(Stream &strm, const Headers &headers) { s += "\r\n"; auto len = strm.write(s.data(), s.size()); - if (len < 0) { return len; } + if (len < 0) { + return len; + } write_len += len; } auto len = strm.write("\r\n"); - if (len < 0) { return len; } + if (len < 0) { + return len; + } write_len += len; return write_len; } @@ -4384,7 +4663,9 @@ inline bool write_data(Stream &strm, const char *d, size_t l) { size_t offset = 0; while (offset < l) { auto length = strm.write(d + offset, l - offset); - if (length < 0) { return false; } + if (length < 0) { + return false; + } offset += static_cast(length); } return true; @@ -4438,10 +4719,9 @@ inline bool write_content(Stream &strm, const ContentProvider &content_provider, } template -inline bool -write_content_without_length(Stream &strm, - const ContentProvider &content_provider, - const T &is_shutting_down) { +inline bool write_content_without_length( + Stream &strm, const ContentProvider &content_provider, + const T &is_shutting_down) { size_t offset = 0; auto data_available = true; auto ok = true; @@ -4450,7 +4730,9 @@ write_content_without_length(Stream &strm, data_sink.write = [&](const char *d, size_t l) -> bool { if (ok) { offset += l; - if (!strm.is_writable() || !write_data(strm, d, l)) { ok = false; } + if (!strm.is_writable() || !write_data(strm, d, l)) { + ok = false; + } } return ok; }; @@ -4472,9 +4754,10 @@ write_content_without_length(Stream &strm, } template -inline bool -write_content_chunked(Stream &strm, const ContentProvider &content_provider, - const T &is_shutting_down, U &compressor, Error &error) { +inline bool write_content_chunked(Stream &strm, + const ContentProvider &content_provider, + const T &is_shutting_down, U &compressor, + Error &error) { size_t offset = 0; auto data_available = true; auto ok = true; @@ -4510,7 +4793,9 @@ write_content_chunked(Stream &strm, const ContentProvider &content_provider, data_sink.is_writable = [&]() -> bool { return strm.is_writable(); }; auto done_with_trailer = [&](const Headers *trailer) { - if (!ok) { return; } + if (!ok) { + return; + } data_available = false; @@ -4550,7 +4835,9 @@ write_content_chunked(Stream &strm, const ContentProvider &content_provider, } static const std::string crlf("\r\n"); - if (!write_data(strm, crlf.data(), crlf.size())) { ok = false; } + if (!write_data(strm, crlf.data(), crlf.size())) { + ok = false; + } }; data_sink.done = [&](void) { done_with_trailer(nullptr); }; @@ -4607,7 +4894,9 @@ inline bool redirect(T &cli, Request &req, Response &res, req = new_req; res = new_res; - if (res.location.empty()) { res.location = location; } + if (res.location.empty()) { + res.location = location; + } } return ret; } @@ -4616,7 +4905,9 @@ inline std::string params_to_query_str(const Params ¶ms) { std::string query; for (auto it = params.begin(); it != params.end(); ++it) { - if (it != params.begin()) { query += "&"; } + if (it != params.begin()) { + query += "&"; + } query += it->first; query += "="; query += encode_query_param(it->second); @@ -4629,7 +4920,9 @@ inline void parse_query_text(const char *data, std::size_t size, std::set cache; split(data, data + size, '&', [&](const char *b, const char *e) { std::string kv(b, e); - if (cache.find(kv) != cache.end()) { return; } + if (cache.find(kv) != cache.end()) { + return; + } cache.insert(std::move(kv)); std::string key; @@ -4655,7 +4948,9 @@ inline bool parse_multipart_boundary(const std::string &content_type, std::string &boundary) { auto boundary_keyword = "boundary="; auto pos = content_type.find(boundary_keyword); - if (pos == std::string::npos) { return false; } + if (pos == std::string::npos) { + return false; + } auto end = content_type.find(';', pos); auto beg = pos + strlen(boundary_keyword); boundary = trim_double_quotes_copy(content_type.substr(beg, end - beg)); @@ -4666,7 +4961,9 @@ inline void parse_disposition_params(const std::string &s, Params ¶ms) { std::set cache; split(s.data(), s.data() + s.size(), ';', [&](const char *b, const char *e) { std::string kv(b, e); - if (cache.find(kv) != cache.end()) { return; } + if (cache.find(kv) != cache.end()) { + return; + } cache.insert(kv); std::string key; @@ -4701,7 +4998,9 @@ inline bool parse_range_header(const std::string &s, Ranges &ranges) try { const auto len = static_cast(s.size() - 6); auto all_valid_ranges = true; split(&s[pos], &s[pos + len], ',', [&](const char *b, const char *e) { - if (!all_valid_ranges) { return; } + if (!all_valid_ranges) { + return; + } const auto it = std::find(b, e, '-'); if (it == e) { @@ -4734,11 +5033,13 @@ inline bool parse_range_header(const std::string &s, Ranges &ranges) try { #ifdef CPPHTTPLIB_NO_EXCEPTIONS } #else -} catch (...) { return false; } +} catch (...) { + return false; +} #endif class MultipartFormDataParser { -public: + public: MultipartFormDataParser() = default; void set_boundary(std::string &&boundary) { @@ -4751,142 +5052,158 @@ class MultipartFormDataParser { bool parse(const char *buf, size_t n, const ContentReceiver &content_callback, const MultipartContentHeader &header_callback) { - buf_append(buf, n); while (buf_size() > 0) { switch (state_) { - case 0: { // Initial boundary - buf_erase(buf_find(dash_boundary_crlf_)); - if (dash_boundary_crlf_.size() > buf_size()) { return true; } - if (!buf_start_with(dash_boundary_crlf_)) { return false; } - buf_erase(dash_boundary_crlf_.size()); - state_ = 1; - break; - } - case 1: { // New entry - clear_file_info(); - state_ = 2; - break; - } - case 2: { // Headers - auto pos = buf_find(crlf_); - if (pos > CPPHTTPLIB_HEADER_MAX_LENGTH) { return false; } - while (pos < buf_size()) { - // Empty line - if (pos == 0) { - if (!header_callback(file_)) { - is_valid_ = false; - return false; - } - buf_erase(crlf_.size()); - state_ = 3; - break; + case 0: { // Initial boundary + buf_erase(buf_find(dash_boundary_crlf_)); + if (dash_boundary_crlf_.size() > buf_size()) { + return true; } - - const auto header = buf_head(pos); - - if (!parse_header(header.data(), header.data() + header.size(), - [&](const std::string &, const std::string &) {})) { - is_valid_ = false; + if (!buf_start_with(dash_boundary_crlf_)) { return false; } - - static const std::string header_content_type = "Content-Type:"; - - if (start_with_case_ignore(header, header_content_type)) { - file_.content_type = - trim_copy(header.substr(header_content_type.size())); - } else { - static const std::regex re_content_disposition( - R"~(^Content-Disposition:\s*form-data;\s*(.*)$)~", - std::regex_constants::icase); - - std::smatch m; - if (std::regex_match(header, m, re_content_disposition)) { - Params params; - parse_disposition_params(m[1], params); - - auto it = params.find("name"); - if (it != params.end()) { - file_.name = it->second; - } else { + buf_erase(dash_boundary_crlf_.size()); + state_ = 1; + break; + } + case 1: { // New entry + clear_file_info(); + state_ = 2; + break; + } + case 2: { // Headers + auto pos = buf_find(crlf_); + if (pos > CPPHTTPLIB_HEADER_MAX_LENGTH) { + return false; + } + while (pos < buf_size()) { + // Empty line + if (pos == 0) { + if (!header_callback(file_)) { is_valid_ = false; return false; } + buf_erase(crlf_.size()); + state_ = 3; + break; + } + + const auto header = buf_head(pos); - it = params.find("filename"); - if (it != params.end()) { file_.filename = it->second; } + if (!parse_header( + header.data(), header.data() + header.size(), + [&](const std::string &, const std::string &) {})) { + is_valid_ = false; + return false; + } - it = params.find("filename*"); - if (it != params.end()) { - // Only allow UTF-8 enconnding... - static const std::regex re_rfc5987_encoding( - R"~(^UTF-8''(.+?)$)~", std::regex_constants::icase); + static const std::string header_content_type = "Content-Type:"; - std::smatch m2; - if (std::regex_match(it->second, m2, re_rfc5987_encoding)) { - file_.filename = decode_url(m2[1], false); // override... + if (start_with_case_ignore(header, header_content_type)) { + file_.content_type = + trim_copy(header.substr(header_content_type.size())); + } else { + static const std::regex re_content_disposition( + R"~(^Content-Disposition:\s*form-data;\s*(.*)$)~", + std::regex_constants::icase); + + std::smatch m; + if (std::regex_match(header, m, re_content_disposition)) { + Params params; + parse_disposition_params(m[1], params); + + auto it = params.find("name"); + if (it != params.end()) { + file_.name = it->second; } else { is_valid_ = false; return false; } + + it = params.find("filename"); + if (it != params.end()) { + file_.filename = it->second; + } + + it = params.find("filename*"); + if (it != params.end()) { + // Only allow UTF-8 enconnding... + static const std::regex re_rfc5987_encoding( + R"~(^UTF-8''(.+?)$)~", std::regex_constants::icase); + + std::smatch m2; + if (std::regex_match(it->second, m2, re_rfc5987_encoding)) { + file_.filename = decode_url(m2[1], false); // override... + } else { + is_valid_ = false; + return false; + } + } } } + buf_erase(pos + crlf_.size()); + pos = buf_find(crlf_); } - buf_erase(pos + crlf_.size()); - pos = buf_find(crlf_); + if (state_ != 3) { + return true; + } + break; } - if (state_ != 3) { return true; } - break; - } - case 3: { // Body - if (crlf_dash_boundary_.size() > buf_size()) { return true; } - auto pos = buf_find(crlf_dash_boundary_); - if (pos < buf_size()) { - if (!content_callback(buf_data(), pos)) { - is_valid_ = false; - return false; + case 3: { // Body + if (crlf_dash_boundary_.size() > buf_size()) { + return true; } - buf_erase(pos + crlf_dash_boundary_.size()); - state_ = 4; - } else { - auto len = buf_size() - crlf_dash_boundary_.size(); - if (len > 0) { - if (!content_callback(buf_data(), len)) { + auto pos = buf_find(crlf_dash_boundary_); + if (pos < buf_size()) { + if (!content_callback(buf_data(), pos)) { is_valid_ = false; return false; } - buf_erase(len); + buf_erase(pos + crlf_dash_boundary_.size()); + state_ = 4; + } else { + auto len = buf_size() - crlf_dash_boundary_.size(); + if (len > 0) { + if (!content_callback(buf_data(), len)) { + is_valid_ = false; + return false; + } + buf_erase(len); + } + return true; } - return true; + break; } - break; - } - case 4: { // Boundary - if (crlf_.size() > buf_size()) { return true; } - if (buf_start_with(crlf_)) { - buf_erase(crlf_.size()); - state_ = 1; - } else { - if (dash_.size() > buf_size()) { return true; } - if (buf_start_with(dash_)) { - buf_erase(dash_.size()); - is_valid_ = true; - buf_erase(buf_size()); // Remove epilogue - } else { + case 4: { // Boundary + if (crlf_.size() > buf_size()) { return true; } + if (buf_start_with(crlf_)) { + buf_erase(crlf_.size()); + state_ = 1; + } else { + if (dash_.size() > buf_size()) { + return true; + } + if (buf_start_with(dash_)) { + buf_erase(dash_.size()); + is_valid_ = true; + buf_erase(buf_size()); // Remove epilogue + } else { + return true; + } + } + break; } - break; - } } } return true; } -private: + private: void clear_file_info() { file_.name.clear(); file_.filename.clear(); @@ -4895,7 +5212,9 @@ class MultipartFormDataParser { bool start_with_case_ignore(const std::string &a, const std::string &b) const { - if (a.size() < b.size()) { return false; } + if (a.size() < b.size()) { + return false; + } for (size_t i = 0; i < b.size(); i++) { if (case_ignore::to_lower(a[i]) != case_ignore::to_lower(b[i])) { return false; @@ -4917,9 +5236,13 @@ class MultipartFormDataParser { // Buffer bool start_with(const std::string &a, size_t spos, size_t epos, const std::string &b) const { - if (epos - spos < b.size()) { return false; } + if (epos - spos < b.size()) { + return false; + } for (size_t i = 0; i < b.size(); i++) { - if (a[i + spos] != b[i]) { return false; } + if (a[i + spos] != b[i]) { + return false; + } } return true; } @@ -4941,15 +5264,23 @@ class MultipartFormDataParser { while (off < buf_epos_) { auto pos = off; while (true) { - if (pos == buf_epos_) { return buf_size(); } - if (buf_[pos] == c) { break; } + if (pos == buf_epos_) { + return buf_size(); + } + if (buf_[pos] == c) { + break; + } pos++; } auto remaining_size = buf_epos_ - pos; - if (s.size() > remaining_size) { return buf_size(); } + if (s.size() > remaining_size) { + return buf_size(); + } - if (start_with(buf_, pos, buf_epos_, s)) { return pos - buf_spos_; } + if (start_with(buf_, pos, buf_epos_, s)) { + return pos - buf_spos_; + } off = pos + 1; } @@ -4967,7 +5298,9 @@ class MultipartFormDataParser { buf_spos_ = 0; buf_epos_ = remaining_size; - if (remaining_size + n > buf_.size()) { buf_.resize(remaining_size + n); } + if (remaining_size + n > buf_.size()) { + buf_.resize(remaining_size + n); + } for (size_t i = 0; i < n; i++) { buf_[buf_epos_ + i] = data[i]; @@ -5021,9 +5354,8 @@ inline bool is_multipart_boundary_chars_valid(const std::string &boundary) { } template -inline std::string -serialize_multipart_formdata_item_begin(const T &item, - const std::string &boundary) { +inline std::string serialize_multipart_formdata_item_begin( + const T &item, const std::string &boundary) { std::string body = "--" + boundary + "\r\n"; body += "Content-Disposition: form-data; name=\"" + item.name + "\""; if (!item.filename.empty()) { @@ -5040,19 +5372,19 @@ serialize_multipart_formdata_item_begin(const T &item, inline std::string serialize_multipart_formdata_item_end() { return "\r\n"; } -inline std::string -serialize_multipart_formdata_finish(const std::string &boundary) { +inline std::string serialize_multipart_formdata_finish( + const std::string &boundary) { return "--" + boundary + "--\r\n"; } -inline std::string -serialize_multipart_formdata_get_content_type(const std::string &boundary) { +inline std::string serialize_multipart_formdata_get_content_type( + const std::string &boundary) { return "multipart/form-data; boundary=" + boundary; } -inline std::string -serialize_multipart_formdata(const MultipartFormDataItems &items, - const std::string &boundary, bool finish = true) { +inline std::string serialize_multipart_formdata( + const MultipartFormDataItems &items, const std::string &boundary, + bool finish = true) { std::string body; for (const auto &item : items) { @@ -5060,7 +5392,9 @@ serialize_multipart_formdata(const MultipartFormDataItems &items, body += item.content + serialize_multipart_formdata_item_end(); } - if (finish) { body += serialize_multipart_formdata_finish(boundary); } + if (finish) { + body += serialize_multipart_formdata_finish(boundary); + } return body; } @@ -5079,7 +5413,9 @@ inline bool range_error(Request &req, Response &res) { // https://www.rfc-editor.org/rfc/rfc9110#section-14.2 // Too many ranges - if (req.ranges.size() > CPPHTTPLIB_RANGE_MAX_COUNT) { return true; } + if (req.ranges.size() > CPPHTTPLIB_RANGE_MAX_COUNT) { + return true; + } for (auto &r : req.ranges) { auto &first_pos = r.first; @@ -5095,7 +5431,9 @@ inline bool range_error(Request &req, Response &res) { last_pos = contant_len - 1; } - if (last_pos == -1) { last_pos = contant_len - 1; } + if (last_pos == -1) { + last_pos = contant_len - 1; + } // Range must be within content length if (!(0 <= first_pos && first_pos <= last_pos && @@ -5104,12 +5442,16 @@ inline bool range_error(Request &req, Response &res) { } // Ranges must be in ascending order - if (first_pos <= prev_first_pos) { return true; } + if (first_pos <= prev_first_pos) { + return true; + } // Request must not have more than two overlapping ranges if (first_pos <= prev_last_pos) { overwrapping_count++; - if (overwrapping_count > 2) { return true; } + if (overwrapping_count > 2) { + return true; + } } prev_first_pos = (std::max)(prev_first_pos, first_pos); @@ -5120,8 +5462,8 @@ inline bool range_error(Request &req, Response &res) { return false; } -inline std::pair -get_range_offset_and_length(Range r, size_t content_length) { +inline std::pair get_range_offset_and_length( + Range r, size_t content_length) { assert(r.first != -1 && r.second != -1); assert(0 <= r.first && r.first < static_cast(content_length)); assert(r.first <= r.second && @@ -5216,11 +5558,12 @@ inline size_t get_multipart_ranges_data_length(const Request &req, } template -inline bool -write_multipart_ranges_data(Stream &strm, const Request &req, Response &res, - const std::string &boundary, - const std::string &content_type, - size_t content_length, const T &is_shutting_down) { +inline bool write_multipart_ranges_data(Stream &strm, const Request &req, + Response &res, + const std::string &boundary, + const std::string &content_type, + size_t content_length, + const T &is_shutting_down) { return process_multipart_ranges_data( req, boundary, content_type, content_length, [&](const std::string &token) { strm.write(token); }, @@ -5243,7 +5586,9 @@ inline bool expect_content(const Request &req) { inline bool has_crlf(const std::string &s) { auto p = s.c_str(); while (*p) { - if (*p == '\r' || *p == '\n') { return true; } + if (*p == '\r' || *p == '\n') { + return true; + } p++; } return false; @@ -5289,7 +5634,9 @@ inline std::string SHA_512(const std::string &s) { // https://stackoverflow.com/questions/9507184/can-openssl-on-windows-use-the-system-certificate-store inline bool load_system_certs_on_windows(X509_STORE *store) { auto hStore = CertOpenSystemStoreW((HCRYPTPROV_LEGACY)NULL, L"ROOT"); - if (!hStore) { return false; } + if (!hStore) { + return false; + } auto result = false; PCCERT_CONTEXT pContext = NULL; @@ -5318,7 +5665,9 @@ using CFObjectPtr = std::unique_ptr::type, void (*)(CFTypeRef)>; inline void cf_object_ptr_deleter(CFTypeRef obj) { - if (obj) { CFRelease(obj); } + if (obj) { + CFRelease(obj); + } } inline bool retrieve_certs_from_keychain(CFObjectPtr &certs) { @@ -5333,7 +5682,9 @@ inline bool retrieve_certs_from_keychain(CFObjectPtr &certs) { &kCFTypeDictionaryValueCallBacks), cf_object_ptr_deleter); - if (!query) { return false; } + if (!query) { + return false; + } CFTypeRef security_items = nullptr; if (SecItemCopyMatching(query.get(), &security_items) != errSecSuccess || @@ -5361,7 +5712,9 @@ inline bool add_certs_to_x509_store(CFArrayRef certs, X509_STORE *store) { const auto cert = reinterpret_cast( CFArrayGetValueAtIndex(certs, i)); - if (SecCertificateGetTypeID() != CFGetTypeID(cert)) { continue; } + if (SecCertificateGetTypeID() != CFGetTypeID(cert)) { + continue; + } CFDataRef cert_data = nullptr; if (SecItemExport(cert, kSecFormatX509Cert, 0, nullptr, &cert_data) != @@ -5400,13 +5753,13 @@ inline bool load_system_certs_on_macos(X509_STORE *store) { return result; } -#endif // TARGET_OS_OSX -#endif // _WIN32 -#endif // CPPHTTPLIB_OPENSSL_SUPPORT +#endif // TARGET_OS_OSX +#endif // _WIN32 +#endif // CPPHTTPLIB_OPENSSL_SUPPORT #ifdef _WIN32 class WSInit { -public: + public: WSInit() { WSADATA wsaData; if (WSAStartup(0x0002, &wsaData) == 0) is_valid_ = true; @@ -5447,7 +5800,9 @@ inline std::pair make_digest_authentication_header( } std::string algo = "MD5"; - if (auth.find("algorithm") != auth.end()) { algo = auth.at("algorithm"); } + if (auth.find("algorithm") != auth.end()) { + algo = auth.at("algorithm"); + } std::string response; { @@ -5458,7 +5813,9 @@ inline std::pair make_digest_authentication_header( auto A1 = username + ":" + auth.at("realm") + ":" + password; auto A2 = req.method + ":" + req.path; - if (qop == "auth-int") { A2 += ":" + H(req.body); } + if (qop == "auth-int") { + A2 += ":" + H(req.body); + } if (qop.empty()) { response = H(H(A1) + ":" + auth.at("nonce") + ":" + H(A2)); @@ -5518,7 +5875,7 @@ inline bool parse_www_authenticate(const Response &res, } class ContentProviderAdapter { -public: + public: explicit ContentProviderAdapter( ContentProviderWithoutLength &&content_provider) : content_provider_(content_provider) {} @@ -5527,16 +5884,18 @@ class ContentProviderAdapter { return content_provider_(offset, sink); } -private: + private: ContentProviderWithoutLength content_provider_; }; -} // namespace detail +} // namespace detail inline std::string hosted_at(const std::string &hostname) { std::vector addrs; hosted_at(hostname, addrs); - if (addrs.empty()) { return std::string(); } + if (addrs.empty()) { + return std::string(); + } return addrs[0]; } @@ -5580,23 +5939,28 @@ inline std::string append_query_params(const std::string &path, } // Header utilities -inline std::pair -make_range_header(const Ranges &ranges) { +inline std::pair make_range_header( + const Ranges &ranges) { std::string field = "bytes="; auto i = 0; for (const auto &r : ranges) { - if (i != 0) { field += ", "; } - if (r.first != -1) { field += std::to_string(r.first); } + if (i != 0) { + field += ", "; + } + if (r.first != -1) { + field += std::to_string(r.first); + } field += '-'; - if (r.second != -1) { field += std::to_string(r.second); } + if (r.second != -1) { + field += std::to_string(r.second); + } i++; } return std::make_pair("Range", std::move(field)); } -inline std::pair -make_basic_authentication_header(const std::string &username, - const std::string &password, bool is_proxy) { +inline std::pair make_basic_authentication_header( + const std::string &username, const std::string &password, bool is_proxy) { auto field = "Basic " + detail::base64_encode(username + ":" + password); auto key = is_proxy ? "Proxy-Authorization" : "Authorization"; return std::make_pair(key, std::move(field)); @@ -5641,7 +6005,9 @@ inline std::string Request::get_param_value(const std::string &key, auto rng = params.equal_range(key); auto it = rng.first; std::advance(it, static_cast(id)); - if (it != rng.second) { return it->second; } + if (it != rng.second) { + return it->second; + } return std::string(); } @@ -5661,12 +6027,14 @@ inline bool Request::has_file(const std::string &key) const { inline MultipartFormData Request::get_file_value(const std::string &key) const { auto it = files.find(key); - if (it != files.end()) { return it->second; } + if (it != files.end()) { + return it->second; + } return MultipartFormData(); } -inline std::vector -Request::get_file_values(const std::string &key) const { +inline std::vector Request::get_file_values( + const std::string &key) const { std::vector values; auto rng = files.equal_range(key); for (auto it = rng.first; it != rng.second; it++) { @@ -5737,7 +6105,9 @@ inline void Response::set_content_provider( ContentProviderResourceReleaser resource_releaser) { set_header("Content-Type", content_type); content_length_ = in_length; - if (in_length > 0) { content_provider_ = std::move(provider); } + if (in_length > 0) { + content_provider_ = std::move(provider); + } content_provider_resource_releaser_ = std::move(resource_releaser); is_chunked_content_provider_ = false; } @@ -5783,8 +6153,8 @@ inline std::string Result::get_request_header_value(const std::string &key, return detail::get_header_value(request_headers_, key, def, id); } -inline size_t -Result::get_request_header_value_count(const std::string &key) const { +inline size_t Result::get_request_header_value_count( + const std::string &key) const { auto r = request_headers_.equal_range(key); return static_cast(std::distance(r.first, r.second)); } @@ -5805,10 +6175,12 @@ inline SocketStream::SocketStream(socket_t sock, time_t read_timeout_sec, time_t read_timeout_usec, time_t write_timeout_sec, time_t write_timeout_usec) - : sock_(sock), read_timeout_sec_(read_timeout_sec), + : sock_(sock), + read_timeout_sec_(read_timeout_sec), read_timeout_usec_(read_timeout_usec), write_timeout_sec_(write_timeout_sec), - write_timeout_usec_(write_timeout_usec), read_buff_(read_buff_size_, 0) {} + write_timeout_usec_(write_timeout_usec), + read_buff_(read_buff_size_, 0) {} inline SocketStream::~SocketStream() = default; @@ -5843,7 +6215,9 @@ inline ssize_t SocketStream::read(char *ptr, size_t size) { } } - if (!is_readable()) { return -1; } + if (!is_readable()) { + return -1; + } read_buff_off_ = 0; read_buff_content_size_ = 0; @@ -5868,7 +6242,9 @@ inline ssize_t SocketStream::read(char *ptr, size_t size) { } inline ssize_t SocketStream::write(const char *ptr, size_t size) { - if (!is_writable()) { return -1; } + if (!is_writable()) { + return -1; + } #if defined(_WIN32) && !defined(_WIN64) size = @@ -5937,7 +6313,9 @@ inline PathParamsMatcher::PathParamsMatcher(const std::string &pattern) { while (true) { const auto marker_pos = pattern.find( marker, last_param_end == 0 ? last_param_end : last_param_end - 1); - if (marker_pos == std::string::npos) { break; } + if (marker_pos == std::string::npos) { + break; + } static_fragments_.push_back( pattern.substr(last_param_end, marker_pos - last_param_end + 1)); @@ -5945,7 +6323,9 @@ inline PathParamsMatcher::PathParamsMatcher(const std::string &pattern) { const auto param_name_start = marker_pos + 2; auto sep_pos = pattern.find(separator, param_name_start); - if (sep_pos == std::string::npos) { sep_pos = pattern.length(); } + if (sep_pos == std::string::npos) { + sep_pos = pattern.length(); + } auto param_name = pattern.substr(param_name_start, sep_pos - param_name_start); @@ -5994,10 +6374,14 @@ inline bool PathParamsMatcher::match(Request &request) const { // Should only happen when we have a static fragment after a param // Example: '/users/:id/subscriptions' // The 'subscriptions' fragment here does not have a corresponding param - if (i >= param_names_.size()) { continue; } + if (i >= param_names_.size()) { + continue; + } auto sep_pos = request.path.find(separator, starting_pos); - if (sep_pos == std::string::npos) { sep_pos = request.path.length(); } + if (sep_pos == std::string::npos) { + sep_pos = request.path.length(); + } const auto ¶m_name = param_names_[i]; @@ -6016,7 +6400,7 @@ inline bool RegexMatcher::match(Request &request) const { return std::regex_match(request.path, request.matches, regex_); } -} // namespace detail +} // namespace detail // HTTP server implementation inline Server::Server() @@ -6029,8 +6413,8 @@ inline Server::Server() inline Server::~Server() = default; -inline std::unique_ptr -Server::make_matcher(const std::string &pattern) { +inline std::unique_ptr Server::make_matcher( + const std::string &pattern) { if (pattern.find("/:") != std::string::npos) { return detail::make_unique(pattern); } else { @@ -6124,9 +6508,8 @@ inline bool Server::remove_mount_point(const std::string &mount_point) { return false; } -inline Server & -Server::set_file_extension_and_mimetype_mapping(const std::string &ext, - const std::string &mime) { +inline Server &Server::set_file_extension_and_mimetype_mapping( + const std::string &ext, const std::string &mime) { file_extension_and_mimetype_map_[ext] = mime; return *this; } @@ -6176,8 +6559,8 @@ inline Server &Server::set_logger(Logger logger) { return *this; } -inline Server & -Server::set_expect_100_continue_handler(Expect100ContinueHandler handler) { +inline Server &Server::set_expect_100_continue_handler( + Expect100ContinueHandler handler) { expect_100_continue_handler_ = std::move(handler); return *this; } @@ -6249,12 +6632,16 @@ inline Server &Server::set_payload_max_length(size_t length) { inline bool Server::bind_to_port(const std::string &host, int port, int socket_flags) { auto ret = bind_internal(host, port, socket_flags); - if (ret == -1) { is_decommisioned = true; } + if (ret == -1) { + is_decommisioned = true; + } return ret >= 0; } inline int Server::bind_to_any_port(const std::string &host, int socket_flags) { auto ret = bind_internal(host, 0, socket_flags); - if (ret == -1) { is_decommisioned = true; } + if (ret == -1) { + is_decommisioned = true; + } return ret; } @@ -6287,7 +6674,9 @@ inline void Server::decommission() { is_decommisioned = true; } inline bool Server::parse_request_line(const char *s, Request &req) const { auto len = strlen(s); - if (len < 2 || s[len - 2] != '\r' || s[len - 1] != '\n') { return false; } + if (len < 2 || s[len - 2] != '\r' || s[len - 1] != '\n') { + return false; + } len -= 2; { @@ -6295,24 +6684,37 @@ inline bool Server::parse_request_line(const char *s, Request &req) const { detail::split(s, s + len, ' ', [&](const char *b, const char *e) { switch (count) { - case 0: req.method = std::string(b, e); break; - case 1: req.target = std::string(b, e); break; - case 2: req.version = std::string(b, e); break; - default: break; + case 0: + req.method = std::string(b, e); + break; + case 1: + req.target = std::string(b, e); + break; + case 2: + req.version = std::string(b, e); + break; + default: + break; } count++; }); - if (count != 3) { return false; } + if (count != 3) { + return false; + } } static const std::set methods{ "GET", "HEAD", "POST", "PUT", "DELETE", "CONNECT", "OPTIONS", "TRACE", "PATCH", "PRI"}; - if (methods.find(req.method) == methods.end()) { return false; } + if (methods.find(req.method) == methods.end()) { + return false; + } - if (req.version != "HTTP/1.1" && req.version != "HTTP/1.0") { return false; } + if (req.version != "HTTP/1.1" && req.version != "HTTP/1.0") { + return false; + } { // Skip URL fragment @@ -6362,7 +6764,9 @@ inline bool Server::write_response_core(Stream &strm, bool close_connection, std::string content_type; std::string boundary; - if (need_apply_ranges) { apply_ranges(req, res, content_type, boundary); } + if (need_apply_ranges) { + apply_ranges(req, res, content_type, boundary); + } // Prepare additional headers if (close_connection || req.get_header_value("Connection") == "close") { @@ -6389,13 +6793,19 @@ inline bool Server::write_response_core(Stream &strm, bool close_connection, res.set_header("Accept-Ranges", "bytes"); } - if (post_routing_handler_) { post_routing_handler_(req, res); } + if (post_routing_handler_) { + post_routing_handler_(req, res); + } // Response line and headers { detail::BufferStream bstrm; - if (!detail::write_response_line(bstrm, res.status)) { return false; } - if (!header_writer_(bstrm, res.headers)) { return false; } + if (!detail::write_response_line(bstrm, res.status)) { + return false; + } + if (!header_writer_(bstrm, res.headers)) { + return false; + } // Flush buffer auto &data = bstrm.get_buffer(); @@ -6419,15 +6829,16 @@ inline bool Server::write_response_core(Stream &strm, bool close_connection, } // Log - if (logger_) { logger_(req, res); } + if (logger_) { + logger_(req, res); + } return ret; } -inline bool -Server::write_content_with_provider(Stream &strm, const Request &req, - Response &res, const std::string &boundary, - const std::string &content_type) { +inline bool Server::write_content_with_provider( + Stream &strm, const Request &req, Response &res, + const std::string &boundary, const std::string &content_type) { auto is_shutting_down = [this]() { return this->svr_sock_ == INVALID_SOCKET; }; @@ -6482,7 +6893,9 @@ inline bool Server::read_content(Stream &strm, Request &req, Response &res) { strm, req, res, // Regular [&](const char *buf, size_t n) { - if (req.body.size() + n > req.body.max_size()) { return false; } + if (req.body.size() + n > req.body.max_size()) { + return false; + } req.body.append(buf, n); return true; }, @@ -6496,14 +6909,16 @@ inline bool Server::read_content(Stream &strm, Request &req, Response &res) { }, [&](const char *buf, size_t n) { auto &content = cur->second.content; - if (content.size() + n > content.max_size()) { return false; } + if (content.size() + n > content.max_size()) { + return false; + } content.append(buf, n); return true; })) { const auto &content_type = req.get_header_value("Content-Type"); if (!content_type.find("application/x-www-form-urlencoded")) { if (req.body.size() > CPPHTTPLIB_FORM_URL_ENCODED_PAYLOAD_MAX_LENGTH) { - res.status = StatusCode::PayloadTooLarge_413; // NOTE: should be 414? + res.status = StatusCode::PayloadTooLarge_413; // NOTE: should be 414? return false; } detail::parse_query_text(req.body, req.params); @@ -6522,11 +6937,10 @@ inline bool Server::read_content_with_content_receiver( std::move(multipart_receiver)); } -inline bool -Server::read_content_core(Stream &strm, Request &req, Response &res, - ContentReceiver receiver, - MultipartContentHeader multipart_header, - ContentReceiver multipart_receiver) const { +inline bool Server::read_content_core( + Stream &strm, Request &req, Response &res, ContentReceiver receiver, + MultipartContentHeader multipart_header, + ContentReceiver multipart_receiver) const { detail::MultipartFormDataParser multipart_form_data_parser; ContentReceiverWithProgress out; @@ -6586,7 +7000,9 @@ inline bool Server::handle_file_request(const Request &req, Response &res, std::string sub_path = "/" + req.path.substr(entry.mount_point.size()); if (detail::is_valid_path(sub_path)) { auto path = entry.base_dir + sub_path; - if (path.back() == '/') { path += "index.html"; } + if (path.back() == '/') { + path += "index.html"; + } detail::FileStat stat(path); @@ -6601,7 +7017,9 @@ inline bool Server::handle_file_request(const Request &req, Response &res, } auto mm = std::make_shared(path.c_str()); - if (!mm->is_open()) { return false; } + if (!mm->is_open()) { + return false; + } res.set_content_provider( mm->size(), @@ -6624,10 +7042,9 @@ inline bool Server::handle_file_request(const Request &req, Response &res, return false; } -inline socket_t -Server::create_server_socket(const std::string &host, int port, - int socket_flags, - SocketOptions socket_options) const { +inline socket_t Server::create_server_socket( + const std::string &host, int port, int socket_flags, + SocketOptions socket_options) const { return detail::create_socket( host, std::string(), port, address_family_, socket_flags, tcp_nodelay_, ipv6_v6only_, std::move(socket_options), @@ -6635,19 +7052,27 @@ Server::create_server_socket(const std::string &host, int port, if (::bind(sock, ai.ai_addr, static_cast(ai.ai_addrlen))) { return false; } - if (::listen(sock, CPPHTTPLIB_LISTEN_BACKLOG)) { return false; } + if (::listen(sock, CPPHTTPLIB_LISTEN_BACKLOG)) { + return false; + } return true; }); } inline int Server::bind_internal(const std::string &host, int port, int socket_flags) { - if (is_decommisioned) { return -1; } + if (is_decommisioned) { + return -1; + } - if (!is_valid()) { return -1; } + if (!is_valid()) { + return -1; + } svr_sock_ = create_server_socket(host, port, socket_flags, socket_options_); - if (svr_sock_ == INVALID_SOCKET) { return -1; } + if (svr_sock_ == INVALID_SOCKET) { + return -1; + } if (port == 0) { struct sockaddr_storage addr; @@ -6669,7 +7094,9 @@ inline int Server::bind_internal(const std::string &host, int port, } inline bool Server::listen_internal() { - if (is_decommisioned) { return false; } + if (is_decommisioned) { + return false; + } auto ret = true; is_running_ = true; @@ -6684,7 +7111,7 @@ inline bool Server::listen_internal() { #endif auto val = detail::select_read(svr_sock_, idle_interval_sec_, idle_interval_usec_); - if (val == 0) { // Timeout + if (val == 0) { // Timeout task_queue->on_idle(); continue; } @@ -6715,7 +7142,7 @@ inline bool Server::listen_internal() { detail::close_socket(svr_sock_); ret = false; } else { - ; // The server socket was closed by user. + ; // The server socket was closed by user. } break; } @@ -6735,7 +7162,6 @@ inline bool Server::listen_internal() { #endif } { - #ifdef _WIN32 auto timeout = static_cast(write_timeout_sec_ * 1000 + write_timeout_usec_ / 1000); @@ -6819,7 +7245,9 @@ inline bool Server::routing(Request &req, Response &res, Stream &strm) { } // Read content into `req.body` - if (!read_content(strm, req, res)) { return false; } + if (!read_content(strm, req, res)) { + return false; + } } // Regular handler @@ -6975,18 +7403,19 @@ inline bool Server::dispatch_request_for_content_reader( return false; } -inline bool -Server::process_request(Stream &strm, const std::string &remote_addr, - int remote_port, const std::string &local_addr, - int local_port, bool close_connection, - bool &connection_closed, - const std::function &setup_request) { +inline bool Server::process_request( + Stream &strm, const std::string &remote_addr, int remote_port, + const std::string &local_addr, int local_port, bool close_connection, + bool &connection_closed, + const std::function &setup_request) { std::array buf{}; detail::stream_line_reader line_reader(strm, buf.data(), buf.size()); // Connection has been closed on client - if (!line_reader.getline()) { return false; } + if (!line_reader.getline()) { + return false; + } Request req; @@ -7050,7 +7479,9 @@ Server::process_request(Stream &strm, const std::string &remote_addr, } } - if (setup_request) { setup_request(req); } + if (setup_request) { + setup_request(req); + } if (req.get_header_value("Expect") == "100-continue") { int status = StatusCode::Continue_100; @@ -7058,14 +7489,14 @@ Server::process_request(Stream &strm, const std::string &remote_addr, status = expect_100_continue_handler_(req, res); } switch (status) { - case StatusCode::Continue_100: - case StatusCode::ExpectationFailed_417: - detail::write_response_line(strm, status); - strm.write("\r\n"); - break; - default: - connection_closed = true; - return write_response(strm, true, req, res); + case StatusCode::Continue_100: + case StatusCode::ExpectationFailed_417: + detail::write_response_line(strm, status); + strm.write("\r\n"); + break; + default: + connection_closed = true; + return write_response(strm, true, req, res); } } @@ -7087,9 +7518,15 @@ Server::process_request(Stream &strm, const std::string &remote_addr, auto s = e.what(); for (size_t i = 0; s[i]; i++) { switch (s[i]) { - case '\r': val += "\\r"; break; - case '\n': val += "\\n"; break; - default: val += s[i]; break; + case '\r': + val += "\\r"; + break; + case '\n': + val += "\\n"; + break; + default: + val += s[i]; + break; } } res.set_header("EXCEPTION_WHAT", val); @@ -7147,7 +7584,9 @@ Server::process_request(Stream &strm, const std::string &remote_addr, return write_response_with_content(strm, close_connection, req, res); } else { - if (res.status == -1) { res.status = StatusCode::NotFound_404; } + if (res.status == -1) { + res.status = StatusCode::NotFound_404; + } return write_response(strm, close_connection, req, res); } @@ -7189,9 +7628,11 @@ inline ClientImpl::ClientImpl(const std::string &host, int port) inline ClientImpl::ClientImpl(const std::string &host, int port, const std::string &client_cert_path, const std::string &client_key_path) - : host_(detail::escape_abstract_namespace_unix_domain(host)), port_(port), + : host_(detail::escape_abstract_namespace_unix_domain(host)), + port_(port), host_and_port_(adjust_host_string(host_) + ":" + std::to_string(port)), - client_cert_path_(client_cert_path), client_key_path_(client_key_path) {} + client_cert_path_(client_cert_path), + client_key_path_(client_key_path) {} inline ClientImpl::~ClientImpl() { std::lock_guard guard(socket_mutex_); @@ -7260,7 +7701,9 @@ inline socket_t ClientImpl::create_client_socket(Error &error) const { // Check is custom IP specified for host_ std::string ip; auto it = addr_map_.find(host_); - if (it != addr_map_.end()) { ip = it->second; } + if (it != addr_map_.end()) { + ip = it->second; + } return detail::create_client_socket( host_, ip, port_, address_family_, tcp_nodelay_, ipv6_v6only_, @@ -7272,7 +7715,9 @@ inline socket_t ClientImpl::create_client_socket(Error &error) const { inline bool ClientImpl::create_and_connect_socket(Socket &socket, Error &error) { auto sock = create_client_socket(error); - if (sock == INVALID_SOCKET) { return false; } + if (sock == INVALID_SOCKET) { + return false; + } socket.sock = sock; return true; } @@ -7286,7 +7731,9 @@ inline void ClientImpl::shutdown_ssl(Socket & /*socket*/, } inline void ClientImpl::shutdown_socket(Socket &socket) const { - if (socket.sock == INVALID_SOCKET) { return; } + if (socket.sock == INVALID_SOCKET) { + return; + } detail::shutdown_socket(socket.sock); } @@ -7304,7 +7751,9 @@ inline void ClientImpl::close_socket(Socket &socket) { #ifdef CPPHTTPLIB_OPENSSL_SUPPORT assert(socket.ssl == nullptr); #endif - if (socket.sock == INVALID_SOCKET) { return; } + if (socket.sock == INVALID_SOCKET) { + return; + } detail::close_socket(socket.sock); socket.sock = INVALID_SOCKET; } @@ -7315,7 +7764,9 @@ inline bool ClientImpl::read_response_line(Stream &strm, const Request &req, detail::stream_line_reader line_reader(strm, buf.data(), buf.size()); - if (!line_reader.getline()) { return false; } + if (!line_reader.getline()) { + return false; + } #ifdef CPPHTTPLIB_ALLOW_LF_AS_LINE_TERMINATOR const static std::regex re("(HTTP/1\\.[01]) (\\d{3})(?: (.*?))?\r?\n"); @@ -7333,10 +7784,16 @@ inline bool ClientImpl::read_response_line(Stream &strm, const Request &req, // Ignore '100 Continue' while (res.status == StatusCode::Continue_100) { - if (!line_reader.getline()) { return false; } // CRLF - if (!line_reader.getline()) { return false; } // next response line + if (!line_reader.getline()) { + return false; + } // CRLF + if (!line_reader.getline()) { + return false; + } // next response line - if (!std::regex_match(line_reader.ptr(), m, re)) { return false; } + if (!std::regex_match(line_reader.ptr(), m, re)) { + return false; + } res.version = std::string(m[1]); res.status = std::stoi(std::string(m[2])); res.reason = std::string(m[3]); @@ -7379,7 +7836,9 @@ inline bool ClientImpl::send_(Request &req, Response &res, Error &error) { } if (!is_alive) { - if (!create_and_connect_socket(socket_, error)) { return false; } + if (!create_and_connect_socket(socket_, error)) { + return false; + } #ifdef CPPHTTPLIB_OPENSSL_SUPPORT // TODO: refactoring @@ -7392,7 +7851,9 @@ inline bool ClientImpl::send_(Request &req, Response &res, Error &error) { } } - if (!scli.initialize_ssl(socket_, error)) { return false; } + if (!scli.initialize_ssl(socket_, error)) { + return false; + } } #endif } @@ -7438,7 +7899,9 @@ inline bool ClientImpl::send_(Request &req, Response &res, Error &error) { }); if (!ret) { - if (error == Error::Success) { error = Error::Unknown; } + if (error == Error::Success) { + error = Error::Unknown; + } } return ret; @@ -7478,7 +7941,9 @@ inline bool ClientImpl::handle_request(Stream &strm, Request &req, ret = process_request(strm, req, res, close_connection, error); } - if (!ret) { return false; } + if (!ret) { + return false; + } if (res.get_header_value("Connection") == "close" || (res.version == "HTTP/1.0" && res.reason != "Connection established")) { @@ -7524,7 +7989,9 @@ inline bool ClientImpl::handle_request(Stream &strm, Request &req, Response new_res; ret = send(new_req, new_res, error); - if (ret) { res = new_res; } + if (ret) { + res = new_res; + } } } } @@ -7540,19 +8007,25 @@ inline bool ClientImpl::redirect(Request &req, Response &res, Error &error) { } auto location = res.get_header_value("location"); - if (location.empty()) { return false; } + if (location.empty()) { + return false; + } const static std::regex re( R"((?:(https?):)?(?://(?:\[([a-fA-F\d:]+)\]|([^:/?#]+))(?::(\d+))?)?([^?#]*)(\?[^#]*)?(?:#.*)?)"); std::smatch m; - if (!std::regex_match(location, m, re)) { return false; } + if (!std::regex_match(location, m, re)) { + return false; + } auto scheme = is_ssl() ? "https" : "http"; auto next_scheme = m[1].str(); auto next_host = m[2].str(); - if (next_host.empty()) { next_host = m[3].str(); } + if (next_host.empty()) { + next_host = m[3].str(); + } auto port_str = m[4].str(); auto next_path = m[5].str(); auto next_query = m[6].str(); @@ -7564,9 +8037,15 @@ inline bool ClientImpl::redirect(Request &req, Response &res, Error &error) { next_port = next_scheme == "https" ? 443 : 80; } - if (next_scheme.empty()) { next_scheme = scheme; } - if (next_host.empty()) { next_host = host_; } - if (next_path.empty()) { next_path = "/"; } + if (next_scheme.empty()) { + next_scheme = scheme; + } + if (next_host.empty()) { + next_host = host_; + } + if (next_path.empty()) { + next_path = "/"; + } auto path = detail::decode_url(next_path, true) + next_query; @@ -7577,7 +8056,9 @@ inline bool ClientImpl::redirect(Request &req, Response &res, Error &error) { #ifdef CPPHTTPLIB_OPENSSL_SUPPORT SSLClient cli(next_host, next_port); cli.copy_settings(*this); - if (ca_cert_store_) { cli.set_ca_cert_store(ca_cert_store_); } + if (ca_cert_store_) { + cli.set_ca_cert_store(ca_cert_store_); + } return detail::redirect(cli, req, res, path, location, error); #else return false; @@ -7640,7 +8121,9 @@ inline bool ClientImpl::write_request(Stream &strm, Request &req, } } - if (!req.has_header("Accept")) { req.set_header("Accept", "*/*"); } + if (!req.has_header("Accept")) { + req.set_header("Accept", "*/*"); + } #ifndef CPPHTTPLIB_NO_DEFAULT_USER_AGENT if (!req.has_header("User-Agent")) { @@ -7738,10 +8221,14 @@ inline std::unique_ptr ClientImpl::send_with_content_provider( ContentProvider content_provider, ContentProviderWithoutLength content_provider_without_length, const std::string &content_type, Error &error) { - if (!content_type.empty()) { req.set_header("Content-Type", content_type); } + if (!content_type.empty()) { + req.set_header("Content-Type", content_type); + } #ifdef CPPHTTPLIB_ZLIB_SUPPORT - if (compress_) { req.set_header("Content-Encoding", "gzip"); } + if (compress_) { + req.set_header("Content-Encoding", "gzip"); + } #endif #ifdef CPPHTTPLIB_ZLIB_SUPPORT @@ -7832,9 +8319,11 @@ inline Result ClientImpl::send_with_content_provider( return Result{std::move(res), error, std::move(req.headers)}; } -inline std::string -ClientImpl::adjust_host_string(const std::string &host) const { - if (host.find(':') != std::string::npos) { return "[" + host + "]"; } +inline std::string ClientImpl::adjust_host_string( + const std::string &host) const { + if (host.find(':') != std::string::npos) { + return "[" + host + "]"; + } return host; } @@ -7842,7 +8331,9 @@ inline bool ClientImpl::process_request(Stream &strm, Request &req, Response &res, bool close_connection, Error &error) { // Send request - if (!write_request(strm, req, close_connection, error)) { return false; } + if (!write_request(strm, req, close_connection, error)) { + return false; + } #ifdef CPPHTTPLIB_OPENSSL_SUPPORT if (is_ssl()) { @@ -7881,9 +8372,13 @@ inline bool ClientImpl::process_request(Stream &strm, Request &req, req.content_receiver ? static_cast( [&](const char *buf, size_t n, uint64_t off, uint64_t len) { - if (redirect) { return true; } + if (redirect) { + return true; + } auto ret = req.content_receiver(buf, n, off, len); - if (!ret) { error = Error::Canceled; } + if (!ret) { + error = Error::Canceled; + } return ret; }) : static_cast( @@ -7897,9 +8392,13 @@ inline bool ClientImpl::process_request(Stream &strm, Request &req, }); auto progress = [&](uint64_t current, uint64_t total) { - if (!req.progress || redirect) { return true; } + if (!req.progress || redirect) { + return true; + } auto ret = req.progress(current, total); - if (!ret) { error = Error::Canceled; } + if (!ret) { + error = Error::Canceled; + } return ret; }; @@ -7907,7 +8406,9 @@ inline bool ClientImpl::process_request(Stream &strm, Request &req, if (!req.content_receiver) { auto len = std::min(res.get_header_value_u64("Content-Length"), res.body.max_size()); - if (len > 0) { res.body.reserve(len); } + if (len > 0) { + res.body.reserve(len); + } } } @@ -7915,13 +8416,17 @@ inline bool ClientImpl::process_request(Stream &strm, Request &req, if (!detail::read_content(strm, res, (std::numeric_limits::max)(), dummy_status, std::move(progress), std::move(out), decompress_)) { - if (error != Error::Canceled) { error = Error::Read; } + if (error != Error::Canceled) { + error = Error::Read; + } return false; } } // Log - if (logger_) { logger_(req, res); } + if (logger_) { + logger_(req, res); + } return true; } @@ -7970,9 +8475,8 @@ inline ContentProviderWithoutLength ClientImpl::get_multipart_content_provider( }; } -inline bool -ClientImpl::process_socket(const Socket &socket, - std::function callback) { +inline bool ClientImpl::process_socket( + const Socket &socket, std::function callback) { return detail::process_client_socket( socket.sock, read_timeout_sec_, read_timeout_usec_, write_timeout_sec_, write_timeout_usec_, std::move(callback)); @@ -8058,11 +8562,11 @@ inline Result ClientImpl::Get(const std::string &path, const Headers &headers, req.path = path; req.headers = headers; req.response_handler = std::move(response_handler); - req.content_receiver = - [content_receiver](const char *data, size_t data_length, - uint64_t /*offset*/, uint64_t /*total_length*/) { - return content_receiver(data, data_length); - }; + req.content_receiver = [content_receiver]( + const char *data, size_t data_length, + uint64_t /*offset*/, uint64_t /*total_length*/) { + return content_receiver(data, data_length); + }; req.progress = std::move(progress); return send_(std::move(req)); @@ -8070,7 +8574,9 @@ inline Result ClientImpl::Get(const std::string &path, const Headers &headers, inline Result ClientImpl::Get(const std::string &path, const Params ¶ms, const Headers &headers, Progress progress) { - if (params.empty()) { return Get(path, headers); } + if (params.empty()) { + return Get(path, headers); + } std::string path_with_query = append_query_params(path, params); return Get(path_with_query, headers, std::move(progress)); @@ -8245,10 +8751,10 @@ inline Result ClientImpl::Post(const std::string &path, const Headers &headers, return Post(path, headers, body, content_type); } -inline Result -ClientImpl::Post(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items) { +inline Result ClientImpl::Post( + const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items) { const auto &boundary = detail::make_multipart_data_boundary(); const auto &content_type = detail::serialize_multipart_formdata_get_content_type(boundary); @@ -8385,10 +8891,10 @@ inline Result ClientImpl::Put(const std::string &path, const Headers &headers, return Put(path, headers, body, content_type); } -inline Result -ClientImpl::Put(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items) { +inline Result ClientImpl::Put( + const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items) { const auto &boundary = detail::make_multipart_data_boundary(); const auto &content_type = detail::serialize_multipart_formdata_get_content_type(boundary); @@ -8527,7 +9033,9 @@ inline Result ClientImpl::Delete(const std::string &path, req.path = path; req.progress = progress; - if (!content_type.empty()) { req.set_header("Content-Type", content_type); } + if (!content_type.empty()) { + req.set_header("Content-Type", content_type); + } req.body.assign(body, content_length); return send_(std::move(req)); @@ -8650,8 +9158,8 @@ inline void ClientImpl::set_follow_location(bool on) { follow_location_ = on; } inline void ClientImpl::set_url_encode(bool on) { url_encode_ = on; } -inline void -ClientImpl::set_hostname_addr_map(std::map addr_map) { +inline void ClientImpl::set_hostname_addr_map( + std::map addr_map) { addr_map_ = std::move(addr_map); } @@ -8722,19 +9230,29 @@ inline X509_STORE *ClientImpl::create_ca_cert_store(const char *ca_cert, std::size_t size) const { auto mem = BIO_new_mem_buf(ca_cert, static_cast(size)); auto se = detail::scope_exit([&] { BIO_free_all(mem); }); - if (!mem) { return nullptr; } + if (!mem) { + return nullptr; + } auto inf = PEM_X509_INFO_read_bio(mem, nullptr, nullptr, nullptr); - if (!inf) { return nullptr; } + if (!inf) { + return nullptr; + } auto cts = X509_STORE_new(); if (cts) { for (auto i = 0; i < static_cast(sk_X509_INFO_num(inf)); i++) { auto itmp = sk_X509_INFO_value(inf, i); - if (!itmp) { continue; } + if (!itmp) { + continue; + } - if (itmp->x509) { X509_STORE_add_cert(cts, itmp->x509); } - if (itmp->crl) { X509_STORE_add_crl(cts, itmp->crl); } + if (itmp->x509) { + X509_STORE_add_cert(cts, itmp->x509); + } + if (itmp->crl) { + X509_STORE_add_crl(cts, itmp->crl); + } } } @@ -8834,13 +9352,18 @@ bool ssl_connect_or_accept_nonblocking(socket_t sock, SSL *ssl, while ((res = ssl_connect_or_accept(ssl)) != 1) { auto err = SSL_get_error(ssl, res); switch (err) { - case SSL_ERROR_WANT_READ: - if (select_read(sock, timeout_sec, timeout_usec) > 0) { continue; } - break; - case SSL_ERROR_WANT_WRITE: - if (select_write(sock, timeout_sec, timeout_usec) > 0) { continue; } - break; - default: break; + case SSL_ERROR_WANT_READ: + if (select_read(sock, timeout_sec, timeout_usec) > 0) { + continue; + } + break; + case SSL_ERROR_WANT_WRITE: + if (select_write(sock, timeout_sec, timeout_usec) > 0) { + continue; + } + break; + default: + break; } return false; } @@ -8863,17 +9386,18 @@ inline bool process_server_socket_ssl( } template -inline bool -process_client_socket_ssl(SSL *ssl, socket_t sock, time_t read_timeout_sec, - time_t read_timeout_usec, time_t write_timeout_sec, - time_t write_timeout_usec, T callback) { +inline bool process_client_socket_ssl(SSL *ssl, socket_t sock, + time_t read_timeout_sec, + time_t read_timeout_usec, + time_t write_timeout_sec, + time_t write_timeout_usec, T callback) { SSLSocketStream strm(sock, ssl, read_timeout_sec, read_timeout_usec, write_timeout_sec, write_timeout_usec); return callback(strm); } class SSLInit { -public: + public: SSLInit() { OPENSSL_init_ssl( OPENSSL_INIT_LOAD_SSL_STRINGS | OPENSSL_INIT_LOAD_CRYPTO_STRINGS, NULL); @@ -8886,7 +9410,9 @@ inline SSLSocketStream::SSLSocketStream(socket_t sock, SSL *ssl, time_t read_timeout_usec, time_t write_timeout_sec, time_t write_timeout_usec) - : sock_(sock), ssl_(ssl), read_timeout_sec_(read_timeout_sec), + : sock_(sock), + ssl_(ssl), + read_timeout_sec_(read_timeout_sec), read_timeout_usec_(read_timeout_usec), write_timeout_sec_(write_timeout_sec), write_timeout_usec_(write_timeout_usec) { @@ -8924,7 +9450,9 @@ inline ssize_t SSLSocketStream::read(char *ptr, size_t size) { } else if (is_readable()) { std::this_thread::sleep_for(std::chrono::microseconds{10}); ret = SSL_read(ssl_, ptr, static_cast(size)); - if (ret >= 0) { return ret; } + if (ret >= 0) { + return ret; + } err = SSL_get_error(ssl_, ret); } else { return -1; @@ -8955,7 +9483,9 @@ inline ssize_t SSLSocketStream::write(const char *ptr, size_t size) { if (is_writable()) { std::this_thread::sleep_for(std::chrono::microseconds{10}); ret = SSL_write(ssl_, ptr, static_cast(handle_size)); - if (ret >= 0) { return ret; } + if (ret >= 0) { + return ret; + } err = SSL_get_error(ssl_, ret); } else { return -1; @@ -8981,7 +9511,7 @@ inline socket_t SSLSocketStream::socket() const { return sock_; } static SSLInit sslinit_; -} // namespace detail +} // namespace detail // SSL HTTP server implementation inline SSLServer::SSLServer(const char *cert_path, const char *private_key_path, @@ -8991,9 +9521,9 @@ inline SSLServer::SSLServer(const char *cert_path, const char *private_key_path, ctx_ = SSL_CTX_new(TLS_server_method()); if (ctx_) { - SSL_CTX_set_options(ctx_, - SSL_OP_NO_COMPRESSION | - SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION); + SSL_CTX_set_options( + ctx_, + SSL_OP_NO_COMPRESSION | SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION); SSL_CTX_set_min_proto_version(ctx_, TLS1_2_VERSION); @@ -9024,9 +9554,9 @@ inline SSLServer::SSLServer(X509 *cert, EVP_PKEY *private_key, ctx_ = SSL_CTX_new(TLS_server_method()); if (ctx_) { - SSL_CTX_set_options(ctx_, - SSL_OP_NO_COMPRESSION | - SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION); + SSL_CTX_set_options( + ctx_, + SSL_OP_NO_COMPRESSION | SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION); SSL_CTX_set_min_proto_version(ctx_, TLS1_2_VERSION); @@ -9055,7 +9585,9 @@ inline SSLServer::SSLServer( } inline SSLServer::~SSLServer() { - if (ctx_) { SSL_CTX_free(ctx_); } + if (ctx_) { + SSL_CTX_free(ctx_); + } } inline bool SSLServer::is_valid() const { return ctx_; } @@ -9064,7 +9596,6 @@ inline SSL_CTX *SSLServer::ssl_context() const { return ctx_; } inline void SSLServer::update_certs(X509 *cert, EVP_PKEY *private_key, X509_STORE *client_ca_cert_store) { - std::lock_guard guard(ctx_mutex_); SSL_CTX_use_certificate(ctx_, cert); @@ -9181,7 +9712,9 @@ inline SSLClient::SSLClient(const std::string &host, int port, } inline SSLClient::~SSLClient() { - if (ctx_) { SSL_CTX_free(ctx_); } + if (ctx_) { + SSL_CTX_free(ctx_); + } // Make sure to shut down SSL since shutdown_ssl will resolve to the // base function rather than the derived function once we get to the // base class destructor, and won't free the SSL (causing a leak). @@ -9310,9 +9843,11 @@ inline bool SSLClient::load_certs() { #elif defined(CPPHTTPLIB_USE_CERTS_FROM_MACOSX_KEYCHAIN) && defined(__APPLE__) #if TARGET_OS_OSX loaded = detail::load_system_certs_on_macos(SSL_CTX_get_cert_store(ctx_)); -#endif // TARGET_OS_OSX -#endif // _WIN32 - if (!loaded) { SSL_CTX_set_default_verify_paths(ctx_); } +#endif // TARGET_OS_OSX +#endif // _WIN32 + if (!loaded) { + SSL_CTX_set_default_verify_paths(ctx_); + } } }); @@ -9411,9 +9946,8 @@ inline void SSLClient::shutdown_ssl_impl(Socket &socket, assert(socket.ssl == nullptr); } -inline bool -SSLClient::process_socket(const Socket &socket, - std::function callback) { +inline bool SSLClient::process_socket( + const Socket &socket, std::function callback) { assert(socket.ssl); return detail::process_client_socket_ssl( socket.ssl, socket.sock, read_timeout_sec_, read_timeout_usec_, @@ -9448,8 +9982,8 @@ inline bool SSLClient::verify_host(X509 *server_cert) const { verify_host_with_common_name(server_cert); } -inline bool -SSLClient::verify_host_with_subject_alt_name(X509 *server_cert) const { +inline bool SSLClient::verify_host_with_subject_alt_name( + X509 *server_cert) const { auto ret = false; auto type = GEN_DNS; @@ -9485,19 +10019,23 @@ SSLClient::verify_host_with_subject_alt_name(X509 *server_cert) const { auto name_len = static_cast(ASN1_STRING_length(val->d.ia5)); switch (type) { - case GEN_DNS: dsn_matched = check_host_name(name, name_len); break; + case GEN_DNS: + dsn_matched = check_host_name(name, name_len); + break; - case GEN_IPADD: - if (!memcmp(&addr6, name, addr_len) || - !memcmp(&addr, name, addr_len)) { - ip_matched = true; - } - break; + case GEN_IPADD: + if (!memcmp(&addr6, name, addr_len) || + !memcmp(&addr, name, addr_len)) { + ip_matched = true; + } + break; } } } - if (dsn_matched || ip_matched) { ret = true; } + if (dsn_matched || ip_matched) { + ret = true; + } } GENERAL_NAMES_free(const_cast( @@ -9523,7 +10061,9 @@ inline bool SSLClient::verify_host_with_common_name(X509 *server_cert) const { inline bool SSLClient::check_host_name(const char *pattern, size_t pattern_len) const { - if (host_.size() == pattern_len && host_ == pattern) { return true; } + if (host_.size() == pattern_len && host_ == pattern) { + return true; + } // Wildcard match // https://bugs.launchpad.net/ubuntu/+source/firefox-3.0/+bug/376484 @@ -9533,7 +10073,9 @@ inline bool SSLClient::check_host_name(const char *pattern, pattern_components.emplace_back(b, e); }); - if (host_components_.size() != pattern_components.size()) { return false; } + if (host_components_.size() != pattern_components.size()) { + return false; + } auto itr = pattern_components.begin(); for (const auto &h : host_components_) { @@ -9541,7 +10083,9 @@ inline bool SSLClient::check_host_name(const char *pattern, if (p != h && p != "*") { auto partial_match = (p.size() > 0 && p[p.size() - 1] == '*' && !p.compare(0, p.size() - 1, h)); - if (!partial_match) { return false; } + if (!partial_match) { + return false; + } } ++itr; } @@ -9579,7 +10123,9 @@ inline Client::Client(const std::string &scheme_host_port, auto is_ssl = scheme == "https"; auto host = m[2].str(); - if (host.empty()) { host = m[3].str(); } + if (host.empty()) { + host = m[3].str(); + } auto port_str = m[4].str(); auto port = !port_str.empty() ? std::stoi(port_str) : (is_ssl ? 443 : 80); @@ -9600,7 +10146,7 @@ inline Client::Client(const std::string &scheme_host_port, cli_ = detail::make_unique(scheme_host_port, 80, client_cert_path, client_key_path); } -} // namespace detail +} // namespace detail inline Client::Client(const std::string &host, int port) : cli_(detail::make_unique(host, port)) {} @@ -9777,10 +10323,10 @@ inline Result Client::Post(const std::string &path, const Headers &headers, const std::string &boundary) { return cli_->Post(path, headers, items, boundary); } -inline Result -Client::Post(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items) { +inline Result Client::Post( + const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items) { return cli_->Post(path, headers, items, provider_items); } inline Result Client::Put(const std::string &path) { return cli_->Put(path); } @@ -9864,10 +10410,10 @@ inline Result Client::Put(const std::string &path, const Headers &headers, const std::string &boundary) { return cli_->Put(path, headers, items, boundary); } -inline Result -Client::Put(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items) { +inline Result Client::Put( + const std::string &path, const Headers &headers, + const MultipartFormDataItems &items, + const MultipartFormDataProviderItems &provider_items) { return cli_->Put(path, headers, items, provider_items); } inline Result Client::Patch(const std::string &path) { @@ -10011,8 +10557,8 @@ inline size_t Client::is_socket_open() const { return cli_->is_socket_open(); } inline socket_t Client::socket() const { return cli_->socket(); } -inline void -Client::set_hostname_addr_map(std::map addr_map) { +inline void Client::set_hostname_addr_map( + std::map addr_map) { cli_->set_hostname_addr_map(std::move(addr_map)); } @@ -10134,21 +10680,23 @@ inline long Client::get_openssl_verify_result() const { if (is_ssl_) { return static_cast(*cli_).get_openssl_verify_result(); } - return -1; // NOTE: -1 doesn't match any of X509_V_ERR_??? + return -1; // NOTE: -1 doesn't match any of X509_V_ERR_??? } inline SSL_CTX *Client::ssl_context() const { - if (is_ssl_) { return static_cast(*cli_).ssl_context(); } + if (is_ssl_) { + return static_cast(*cli_).ssl_context(); + } return nullptr; } #endif // ---------------------------------------------------------------------------- -} // namespace httplib +} // namespace httplib #if defined(_WIN32) && defined(CPPHTTPLIB_USE_POLL) #undef poll #endif -#endif // CPPHTTPLIB_HTTPLIB_H +#endif // CPPHTTPLIB_HTTPLIB_H diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h index 8d8f6ac2..1ce39eb5 100644 --- a/include/miniocpp/rdma.h +++ b/include/miniocpp/rdma.h @@ -18,25 +18,28 @@ #ifndef MINIO_CPP_RDMA_H_INCLUDED #define MINIO_CPP_RDMA_H_INCLUDED -#include "error.h" -#include "utils.h" #include "credentials.h" -#include "signer.h" -#include "rdma-httplib.h" +#include "error.h" #include "nvidia-cufile.h" #include "nvidia-cuobjclient.h" +#include "rdma-httplib.h" +#include "signer.h" +#include "utils.h" -#define IO_DESC_STR \ - "0102030405060708:01020304:01020304:0102:010203:1:0102030405060708090a0b0c0d0e0f10:0102030405060708:0102030405060708" +#define IO_DESC_STR \ + "0102030405060708:01020304:01020304:0102:010203:1:" \ + "0102030405060708090a0b0c0d0e0f10:0102030405060708:0102030405060708" // SHA256 hash of empty string (for RDMA requests with no body) -inline constexpr const char* kEmptySha256 = "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855"; +inline constexpr const char* kEmptySha256 = + "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855"; inline constexpr const char* kUnsignedPayload = "UNSIGNED-PAYLOAD"; // S3 RDMA Protocol Headers (AWS S3 RDMA spec) inline constexpr const char* kAmzRDMAToken = "x-amz-rdma-token"; inline constexpr const char* kAmzRDMAReply = "x-amz-rdma-reply"; -inline constexpr const char* kAmzRDMABytesTransferred = "x-amz-rdma-bytes-transferred"; +inline constexpr const char* kAmzRDMABytesTransferred = + "x-amz-rdma-bytes-transferred"; // RDMA Reply Status Codes (aligned with HTTP status codes) inline constexpr int kRDMAReplySuccess = 200; @@ -44,12 +47,14 @@ inline constexpr int kRDMAReplyNoContent = 204; inline constexpr int kRDMAReplyPartialContent = 206; inline constexpr int kRDMAReplyNotImplemented = 501; -// These functions are invoked by cufile rdma layer either user shadow pages or direct gpu va address -// depending on whether nvidia-fs driver or nv peer mem is present -inline static ssize_t objectPut(const void *handle, const char* buf, size_t size, [[maybe_unused]] loff_t offset, const cufileRDMAInfo_t *infop) -{ - void *ctx = cuObjClient::getCtx(handle); - s3_rdma_client_ctx_t *sctx = static_cast(ctx); +// These functions are invoked by cufile rdma layer either user shadow pages or +// direct gpu va address depending on whether nvidia-fs driver or nv peer mem is +// present +inline static ssize_t objectPut(const void* handle, const char* buf, + size_t size, [[maybe_unused]] loff_t offset, + const cufileRDMAInfo_t* infop) { + void* ctx = cuObjClient::getCtx(handle); + s3_rdma_client_ctx_t* sctx = static_cast(ctx); char io_str[sizeof IO_DESC_STR]; unsigned io_len = sizeof io_str; @@ -59,8 +64,8 @@ inline static ssize_t objectPut(const void *handle, const char* buf, size_t size } const std::string descr = std::string(infop->desc_str, infop->desc_len); - snprintf(io_str, io_len,"%s:%016lx:%016lx;", - infop->desc_str, (uint64_t)buf, (uint64_t)size); + snprintf(io_str, io_len, "%s:%016lx:%016lx;", infop->desc_str, (uint64_t)buf, + (uint64_t)size); minio::utils::UtcTime date = minio::utils::UtcTime::Now(); minio::creds::Credentials creds = sctx->provider->Fetch(); @@ -81,9 +86,9 @@ inline static ssize_t objectPut(const void *handle, const char* buf, size_t size query_params.Add("partNumber", std::to_string(sctx->partNumber)); } - if (minio::error::Error err = sctx->url.BuildUrl(url, minio::http::Method::kPut, - region, query_params, - sctx->bucket, sctx->object)) { + if (minio::error::Error err = + sctx->url.BuildUrl(url, minio::http::Method::kPut, region, + query_params, sctx->bucket, sctx->object)) { std::cerr << "failed to build url. error=" << err << ". This should not happen" << std::endl; return -1; @@ -107,9 +112,8 @@ inline static ssize_t objectPut(const void *handle, const char* buf, size_t size // Sign the request with SignV4S3 (adds Authorization header) minio::signer::SignV4S3(minio::http::Method::kPut, url.path, region, - sign_headers, query_params, - creds.access_key, creds.secret_key, - kUnsignedPayload, date); + sign_headers, query_params, creds.access_key, + creds.secret_key, kUnsignedPayload, date); // Convert Multimap to httplib::Headers httplib::Headers headers; @@ -123,7 +127,8 @@ inline static ssize_t objectPut(const void *handle, const char* buf, size_t size std::string path = url.path; std::string query_string = query_params.ToQueryString(); - std::string full_path = query_string.empty() ? path : path + "?" + query_string; + std::string full_path = + query_string.empty() ? path : path + "?" + query_string; url.path = ""; url.query_string = ""; @@ -166,10 +171,11 @@ inline static ssize_t objectPut(const void *handle, const char* buf, size_t size return size; } -inline static ssize_t objectGet(const void *handle, char* buf, size_t size, [[maybe_unused]] loff_t offset, const cufileRDMAInfo_t *infop) -{ - void *ctx = cuObjClient::getCtx(handle); - s3_rdma_client_ctx_t *sctx = static_cast(ctx); +inline static ssize_t objectGet(const void* handle, char* buf, size_t size, + [[maybe_unused]] loff_t offset, + const cufileRDMAInfo_t* infop) { + void* ctx = cuObjClient::getCtx(handle); + s3_rdma_client_ctx_t* sctx = static_cast(ctx); char io_str[sizeof IO_DESC_STR]; unsigned io_len = sizeof io_str; @@ -179,8 +185,8 @@ inline static ssize_t objectGet(const void *handle, char* buf, size_t size, [[ma } const std::string descr = std::string(infop->desc_str, infop->desc_len); - snprintf(io_str, io_len,"%s:%016lx:%016lx;", - infop->desc_str, (uint64_t)buf, (uint64_t)size); + snprintf(io_str, io_len, "%s:%016lx:%016lx;", infop->desc_str, (uint64_t)buf, + (uint64_t)size); minio::utils::UtcTime date = minio::utils::UtcTime::Now(); minio::creds::Credentials creds = sctx->provider->Fetch(); @@ -188,14 +194,14 @@ inline static ssize_t objectGet(const void *handle, char* buf, size_t size, [[ma minio::http::Url url; const std::string& region = sctx->region; - if (minio::error::Error err = sctx->url.BuildUrl(url, minio::http::Method::kGet, - region, query_params, - sctx->bucket, sctx->object)) { + if (minio::error::Error err = + sctx->url.BuildUrl(url, minio::http::Method::kGet, region, + query_params, sctx->bucket, sctx->object)) { std::cerr << "failed to build url. error=" << err << ". This should not happen" << std::endl; return -1; } - + std::string host = url.HostHeaderValue(); // Build headers for SignV4S3 @@ -212,9 +218,8 @@ inline static ssize_t objectGet(const void *handle, char* buf, size_t size, [[ma // Sign the request with SignV4S3 (adds Authorization header) minio::signer::SignV4S3(minio::http::Method::kGet, url.path, region, - sign_headers, query_params, - creds.access_key, creds.secret_key, - kUnsignedPayload, date); + sign_headers, query_params, creds.access_key, + creds.secret_key, kUnsignedPayload, date); // Convert Multimap to httplib::Headers httplib::Headers headers; @@ -247,7 +252,8 @@ inline static ssize_t objectGet(const void *handle, char* buf, size_t size, [[ma try { int reply_code = std::stoi(rdma_reply); - if (reply_code != kRDMAReplySuccess && reply_code != kRDMAReplyPartialContent) { + if (reply_code != kRDMAReplySuccess && + reply_code != kRDMAReplyPartialContent) { std::cerr << "Unexpected RDMA reply: " << reply_code << std::endl; return -1; } @@ -257,8 +263,8 @@ inline static ssize_t objectGet(const void *handle, char* buf, size_t size, [[ma if (!bytes_str.empty()) { ssize_t bytes_transferred = std::stoll(bytes_str); if (bytes_transferred != static_cast(size)) { - std::cerr << "RDMA bytes mismatch: expected " << size - << ", got " << bytes_transferred << std::endl; + std::cerr << "RDMA bytes mismatch: expected " << size << ", got " + << bytes_transferred << std::endl; } } } catch (const std::exception& e) { diff --git a/include/miniocpp/utils.h b/include/miniocpp/utils.h index a7ac7210..6e18f144 100644 --- a/include/miniocpp/utils.h +++ b/include/miniocpp/utils.h @@ -37,11 +37,11 @@ namespace minio::utils { -inline constexpr unsigned int kMaxMultipartCount = 10000; // 10000 parts -inline constexpr unsigned int kOptPartSize = 64 * 1024 * 1024; // 64MiB -inline constexpr unsigned int kMinPartSize = 5 * 1024 * 1024; // 5MiB -inline constexpr uint64_t kMaxPartSize = kMinPartSize * 1024; // 5GiB -inline constexpr uint64_t kMaxObjectSize = kMaxPartSize * 1024; // 5TiB +inline constexpr unsigned int kMaxMultipartCount = 10000; // 10000 parts +inline constexpr unsigned int kOptPartSize = 64 * 1024 * 1024; // 64MiB +inline constexpr unsigned int kMinPartSize = 5 * 1024 * 1024; // 5MiB +inline constexpr uint64_t kMaxPartSize = kMinPartSize * 1024; // 5GiB +inline constexpr uint64_t kMaxObjectSize = kMaxPartSize * 1024; // 5TiB // GetEnv copies the environment variable name into var bool GetEnv(std::string& var, const char* name); diff --git a/src/args.cc b/src/args.cc index d7678b33..d8684968 100644 --- a/src/args.cc +++ b/src/args.cc @@ -245,7 +245,7 @@ error::Error PutObjectRDMAArgs::Validate() const { return error::SUCCESS; } - + error::Error GetObjectArgs::Validate() const { if (error::Error err = ObjectConditionalReadArgs::Validate()) { return err; diff --git a/src/baseclient.cc b/src/baseclient.cc index c723859b..46ce92b0 100644 --- a/src/baseclient.cc +++ b/src/baseclient.cc @@ -44,8 +44,8 @@ #include "miniocpp/utils.h" // RDMA specific includes -#include "miniocpp/rdma.h" #include "miniocpp/nvidia-cuobjclient.h" +#include "miniocpp/rdma.h" // We want exactly `minio::s3::BaseClient::GetObject()` symbol and nothing else. #if defined(GetObject) @@ -69,27 +69,27 @@ BaseClient::BaseClient(BaseUrl base_url, creds::Provider* provider) : base_url_(std::move(base_url)), provider_(provider) { if (!base_url_) { std::cerr << "valid base url must be provided; " << base_url_.Error() - << std::endl; + << std::endl; std::terminate(); } } error::Error BaseClient::SetAppInfo(std::string_view app_name, - std::string_view app_version) { + std::string_view app_version) { if (app_name.empty() || app_version.empty()) { return error::Error("Application name/version cannot be empty"); } user_agent_ = std::string(DEFAULT_USER_AGENT) + " " + std::string(app_name) + - "/" + std::string(app_version); + "/" + std::string(app_version); return error::SUCCESS; } void BaseClient::HandleRedirectResponse(std::string& code, std::string& message, - int status_code, http::Method method, - const utils::Multimap& headers, - const std::string& bucket_name, - bool retry) { + int status_code, http::Method method, + const utils::Multimap& headers, + const std::string& bucket_name, + bool retry) { switch (status_code) { case 301: code = "PermanentRedirect"; @@ -123,10 +123,10 @@ void BaseClient::HandleRedirectResponse(std::string& code, std::string& message, } Response BaseClient::GetErrorResponse(http::Response resp, - std::string_view resource, - http::Method method, - const std::string& bucket_name, - const std::string& object_name) { + std::string_view resource, + http::Method method, + const std::string& bucket_name, + const std::string& object_name) { if (!resp.error.empty()) { return error::make(resp.error); } @@ -135,14 +135,14 @@ Response BaseClient::GetErrorResponse(http::Response resp, std::list values = resp.headers.Get("Content-Type"); for (auto& value : values) { if (utils::Contains(utils::ToLower(value), "application/xml")) { - return Response::ParseXML(resp.body, resp.status_code, resp.headers); + return Response::ParseXML(resp.body, resp.status_code, resp.headers); } } auto response = - error::make("invalid response received; status code: " + - std::to_string(resp.status_code) + - "; content-type: " + utils::Join(values, ",")); + error::make("invalid response received; status code: " + + std::to_string(resp.status_code) + + "; content-type: " + utils::Join(values, ",")); response.status_code = resp.status_code; response.headers = resp.headers; return response; @@ -157,7 +157,7 @@ Response BaseClient::GetErrorResponse(http::Response resp, case 307: case 400: HandleRedirectResponse(response.code, response.message, resp.status_code, - method, resp.headers, bucket_name, true); + method, resp.headers, bucket_name, true); break; case 403: response.code = "AccessDenied"; @@ -165,39 +165,39 @@ Response BaseClient::GetErrorResponse(http::Response resp, break; case 404: if (!object_name.empty()) { - response.code = "NoSuchKey"; - response.message = "Object does not exist"; + response.code = "NoSuchKey"; + response.message = "Object does not exist"; } else if (bucket_name.empty()) { - response.code = "NoSuchBucket"; - response.message = "Bucket does not exist"; + response.code = "NoSuchBucket"; + response.message = "Bucket does not exist"; } else { - response.code = "ResourceNotFound"; - response.message = "Request resource not found"; + response.code = "ResourceNotFound"; + response.message = "Request resource not found"; } break; case 405: response.code = "MethodNotAllowed"; response.message = - "The specified method is not allowed against this resource"; + "The specified method is not allowed against this resource"; break; case 409: if (bucket_name.empty()) { - response.code = "NoSuchBucket"; - response.message = "Bucket does not exist"; + response.code = "NoSuchBucket"; + response.message = "Bucket does not exist"; } else { - response.code = "ResourceConflict"; - response.message = "Request resource conflicts"; + response.code = "ResourceConflict"; + response.message = "Request resource conflicts"; } break; case 501: response.code = "MethodNotAllowed"; response.message = - "The specified method is not allowed against this resource"; + "The specified method is not allowed against this resource"; break; default: { auto response = - error::make("server failed with HTTP status code " + - std::to_string(resp.status_code)); + error::make("server failed with HTTP status code " + + std::to_string(resp.status_code)); response.status_code = resp.status_code; response.headers = resp.headers; return response; @@ -229,7 +229,7 @@ Response BaseClient::execute(Request& req) { } Response resp = GetErrorResponse(response, request.url.path, req.method, - req.bucket_name, req.object_name); + req.bucket_name, req.object_name); if (resp.code == "NoSuchBucket" || resp.code == "RetryHead") { region_map_.erase(req.bucket_name); } @@ -248,7 +248,7 @@ Response BaseClient::Execute(Request& req) { std::string code; std::string message; HandleRedirectResponse(code, message, resp.status_code, req.method, - resp.headers, req.bucket_name); + resp.headers, req.bucket_name); resp.code = code; resp.message = message; @@ -256,12 +256,12 @@ Response BaseClient::Execute(Request& req) { } GetRegionResponse BaseClient::GetRegion(const std::string& bucket_name, - const std::string& region) { + const std::string& region) { std::string base_region = base_url_.region; if (!region.empty()) { if (!base_region.empty() && base_region != region) { return error::make("region must be " + base_region + - ", but passed " + region); + ", but passed " + region); } return GetRegionResponse(region); @@ -280,7 +280,7 @@ GetRegionResponse BaseClient::GetRegion(const std::string& bucket_name, return GetRegionResponse(stored_region); } Request req(http::Method::kGet, "us-east-1", base_url_, utils::Multimap(), - utils::Multimap()); + utils::Multimap()); req.query_params.Add("location", ""); req.bucket_name = bucket_name; @@ -322,7 +322,7 @@ AbortMultipartUploadResponse BaseClient::AbortMultipartUpload( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; req.query_params.Add("uploadId", args.upload_id); @@ -339,17 +339,17 @@ BucketExistsResponse BaseClient::BucketExists(BucketExistsArgs args) { region = resp.region; } else { return (resp.code == "NoSuchBucket") ? BucketExistsResponse(false) - : BucketExistsResponse(resp); + : BucketExistsResponse(resp); } Request req(http::Method::kHead, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; if (Response resp = Execute(req)) { return BucketExistsResponse(true); } else { return (resp.code == "NoSuchBucket") ? BucketExistsResponse(false) - : BucketExistsResponse(resp); + : BucketExistsResponse(resp); } } @@ -367,7 +367,7 @@ CompleteMultipartUploadResponse BaseClient::CompleteMultipartUpload( } Request req(http::Method::kPost, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; req.query_params.Add("uploadId", args.upload_id); @@ -413,7 +413,7 @@ CreateMultipartUploadResponse BaseClient::CreateMultipartUpload( } Request req(http::Method::kPost, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; req.query_params.Add("uploads", ""); @@ -426,7 +426,7 @@ CreateMultipartUploadResponse BaseClient::CreateMultipartUpload( return error::make("unable to parse XML"); } auto text = - xdoc.select_node("/InitiateMultipartUploadResult/UploadId/text()"); + xdoc.select_node("/InitiateMultipartUploadResult/UploadId/text()"); return CreateMultipartUploadResponse(std::string(text.node().value())); } else { return CreateMultipartUploadResponse(resp); @@ -447,7 +447,7 @@ DeleteBucketEncryptionResponse BaseClient::DeleteBucketEncryption( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("encryption", ""); @@ -476,7 +476,7 @@ DisableObjectLegalHoldResponse BaseClient::DisableObjectLegalHold( std::string body = "OFF"; Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -503,7 +503,7 @@ DeleteBucketLifecycleResponse BaseClient::DeleteBucketLifecycle( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("lifecycle", ""); @@ -540,7 +540,7 @@ DeleteBucketPolicyResponse BaseClient::DeleteBucketPolicy( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("policy", ""); @@ -561,7 +561,7 @@ DeleteBucketReplicationResponse BaseClient::DeleteBucketReplication( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("replication", ""); @@ -589,7 +589,7 @@ DeleteBucketTagsResponse BaseClient::DeleteBucketTags( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("tagging", ""); @@ -610,7 +610,7 @@ DeleteObjectLockConfigResponse BaseClient::DeleteObjectLockConfig( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("object-lock", ""); @@ -631,7 +631,7 @@ DeleteObjectTagsResponse BaseClient::DeleteObjectTags( } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -658,7 +658,7 @@ EnableObjectLegalHoldResponse BaseClient::EnableObjectLegalHold( std::string body = "ON"; Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -685,7 +685,7 @@ GetBucketEncryptionResponse BaseClient::GetBucketEncryption( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("encryption", ""); @@ -710,7 +710,7 @@ GetBucketLifecycleResponse BaseClient::GetBucketLifecycle( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("lifecycle", ""); @@ -740,7 +740,7 @@ GetBucketNotificationResponse BaseClient::GetBucketNotification( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("notification", ""); @@ -764,7 +764,7 @@ GetBucketPolicyResponse BaseClient::GetBucketPolicy(GetBucketPolicyArgs args) { } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("policy", ""); @@ -789,7 +789,7 @@ GetBucketReplicationResponse BaseClient::GetBucketReplication( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("replication", ""); @@ -813,7 +813,7 @@ GetBucketTagsResponse BaseClient::GetBucketTags(GetBucketTagsArgs args) { } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("tagging", ""); @@ -838,7 +838,7 @@ GetBucketVersioningResponse BaseClient::GetBucketVersioning( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("versioning", ""); @@ -877,7 +877,7 @@ GetObjectResponse BaseClient::GetObject(GetObjectArgs args) { if (args.ssec != nullptr && !base_url_.https) { return error::make( - "SSE-C operation must be performed over a secure connection"); + "SSE-C operation must be performed over a secure connection"); } std::string region; @@ -888,7 +888,7 @@ GetObjectResponse BaseClient::GetObject(GetObjectArgs args) { } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -917,7 +917,7 @@ GetObjectLockConfigResponse BaseClient::GetObjectLockConfig( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("object-lock", ""); @@ -968,7 +968,7 @@ GetObjectRetentionResponse BaseClient::GetObjectRetention( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1015,7 +1015,7 @@ GetObjectTagsResponse BaseClient::GetObjectTags(GetObjectTagsArgs args) { } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1049,9 +1049,9 @@ GetPresignedObjectUrlResponse BaseClient::GetPresignedObjectUrl( http::Url url; if (error::Error err = base_url_.BuildUrl( - url, args.method, region, query_params, args.bucket, args.object)) { + url, args.method, region, query_params, args.bucket, args.object)) { std::cerr << "failed to build url. error=" << err - << ". This should not happen" << std::endl; + << ". This should not happen" << std::endl; std::terminate(); } @@ -1066,8 +1066,8 @@ GetPresignedObjectUrlResponse BaseClient::GetPresignedObjectUrl( std::string host = url.HostHeaderValue(); signer::PresignV4(args.method, host, url.path, region, query_params, - creds.access_key, creds.secret_key, date, - args.expiry_seconds); + creds.access_key, creds.secret_key, date, + args.expiry_seconds); url.query_string = query_params.ToQueryString(); } @@ -1078,12 +1078,12 @@ GetPresignedPostFormDataResponse BaseClient::GetPresignedPostFormData( PostPolicy policy) { if (!policy) { return error::make( - "valid policy must be provided"); + "valid policy must be provided"); } if (provider_ == nullptr) { return error::make( - "Anonymous access does not require pre-signed post form-data"); + "Anonymous access does not require pre-signed post form-data"); } std::string region; @@ -1096,8 +1096,8 @@ GetPresignedPostFormDataResponse BaseClient::GetPresignedPostFormData( creds::Credentials creds = provider_->Fetch(); std::map data; if (error::Error err = - policy.FormData(data, creds.access_key, creds.secret_key, - creds.session_token, region)) { + policy.FormData(data, creds.access_key, creds.secret_key, + creds.session_token, region)) { return GetPresignedPostFormDataResponse(err); } return GetPresignedPostFormDataResponse(data); @@ -1117,7 +1117,7 @@ IsObjectLegalHoldEnabledResponse BaseClient::IsObjectLegalHoldEnabled( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1145,7 +1145,7 @@ IsObjectLegalHoldEnabledResponse BaseClient::IsObjectLegalHoldEnabled( ListBucketsResponse BaseClient::ListBuckets(ListBucketsArgs args) { Request req(http::Method::kGet, base_url_.region, base_url_, - args.extra_headers, args.extra_query_params); + args.extra_headers, args.extra_query_params); Response resp = Execute(req); if (!resp) { return ListBucketsResponse(resp); @@ -1165,7 +1165,7 @@ ListenBucketNotificationResponse BaseClient::ListenBucketNotification( if (!base_url_.aws_domain_suffix.empty()) { return error::make( - "ListenBucketNotification API is not supported in Amazon S3"); + "ListenBucketNotification API is not supported in Amazon S3"); } std::string region; @@ -1176,7 +1176,7 @@ ListenBucketNotificationResponse BaseClient::ListenBucketNotification( } Request req = Request(http::Method::kGet, region, base_url_, - args.extra_headers, args.extra_query_params); + args.extra_headers, args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("prefix", args.prefix); req.query_params.Add("suffix", args.suffix); @@ -1191,7 +1191,7 @@ ListenBucketNotificationResponse BaseClient::ListenBucketNotification( std::string data; auto func = args.func; req.datafunc = [&func = func, - &data = data](http::DataFunctionArgs args) -> bool { + &data = data](http::DataFunctionArgs args) -> bool { data += args.datachunk; while (true) { size_t pos = data.find('\n'); @@ -1207,13 +1207,13 @@ ListenBucketNotificationResponse BaseClient::ListenBucketNotification( nlohmann::json j_records = json["Records"]; std::list records; for (auto& j_record : j_records) { - records.push_back(NotificationRecord::ParseJSON(j_record)); + records.push_back(NotificationRecord::ParseJSON(j_record)); } if (records.size() <= 0) continue; if (!func(records)) { - return false; + return false; } } }; @@ -1234,7 +1234,7 @@ ListObjectsResponse BaseClient::ListObjectsV1(ListObjectsV1Args args) { } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.AddAll(GetCommonListObjectsQueryParams( args.delimiter, args.encoding_type, args.max_keys, args.prefix)); @@ -1261,7 +1261,7 @@ ListObjectsResponse BaseClient::ListObjectsV2(ListObjectsV2Args args) { } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("list-type", "2"); req.query_params.AddAll(GetCommonListObjectsQueryParams( @@ -1299,7 +1299,7 @@ ListObjectsResponse BaseClient::ListObjectVersions( } Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("versions", ""); req.query_params.AddAll(GetCommonListObjectsQueryParams( @@ -1327,7 +1327,7 @@ MakeBucketResponse BaseClient::MakeBucket(MakeBucketArgs args) { std::string base_region = base_url_.region; if (!base_region.empty() && !region.empty() && base_region != region) { return error::make("region must be " + base_region + - ", but passed " + region); + ", but passed " + region); } if (region.empty()) { @@ -1337,7 +1337,7 @@ MakeBucketResponse BaseClient::MakeBucket(MakeBucketArgs args) { region = "us-east-1"; } Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; if (args.object_lock) { req.headers.Add("x-amz-bucket-object-lock-enabled", "true"); @@ -1374,20 +1374,21 @@ PutObjectResponse BaseClient::PutObject(PutObjectApiArgs args) { if (args.rdmaclient != nullptr && args.rdmaclient->isConnected()) { // send the buffer + put operation via RDMA. s3_rdma_client_ctx putCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .uploadId = "", - .partNumber = 0, - .etag = "", - .url = base_url_, - .region = region, - .op = CUOBJ_PUT, + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .uploadId = "", + .partNumber = 0, + .etag = "", + .url = base_url_, + .region = region, + .op = CUOBJ_PUT, }; ssize_t ret = args.rdmaclient->cuObjPut(&putCtx, args.buf, args.size); if (ret < 0) { - return error::make("failed to upload the object "+ args.object); + return error::make("failed to upload the object " + + args.object); } PutObjectResponse resp; @@ -1396,7 +1397,7 @@ PutObjectResponse BaseClient::PutObject(PutObjectApiArgs args) { } Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; req.query_params.AddAll(args.query_params); @@ -1434,7 +1435,7 @@ RemoveBucketResponse BaseClient::RemoveBucket(RemoveBucketArgs args) { } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; return RemoveBucketResponse(Execute(req)); @@ -1453,7 +1454,7 @@ RemoveObjectResponse BaseClient::RemoveObject(RemoveObjectArgs args) { } Request req(http::Method::kDelete, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1476,7 +1477,7 @@ RemoveObjectsResponse BaseClient::RemoveObjects(RemoveObjectsApiArgs args) { } Request req(http::Method::kPost, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("delete", ""); if (args.bypass_governance_mode) { @@ -1515,7 +1516,7 @@ SelectObjectContentResponse BaseClient::SelectObjectContent( if (args.ssec != nullptr && !base_url_.https) { return error::make( - "SSE-C operation must be performed over a secure connection"); + "SSE-C operation must be performed over a secure connection"); } std::string region; @@ -1526,7 +1527,7 @@ SelectObjectContentResponse BaseClient::SelectObjectContent( } Request req(http::Method::kPost, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; req.query_params.Add("select", ""); @@ -1568,7 +1569,7 @@ SetBucketEncryptionResponse BaseClient::SetBucketEncryption( std::string body = ss.str(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("encryption", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1593,7 +1594,7 @@ SetBucketLifecycleResponse BaseClient::SetBucketLifecycle( std::string body = args.config.ToXML(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("lifecycle", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1618,7 +1619,7 @@ SetBucketNotificationResponse BaseClient::SetBucketNotification( std::string body = args.config.ToXML(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("notification", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1640,7 +1641,7 @@ SetBucketPolicyResponse BaseClient::SetBucketPolicy(SetBucketPolicyArgs args) { } Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("policy", ""); req.body = args.policy; @@ -1665,7 +1666,7 @@ SetBucketReplicationResponse BaseClient::SetBucketReplication( std::string body = args.config.ToXML(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("replication", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1692,7 +1693,7 @@ SetBucketTagsResponse BaseClient::SetBucketTags(SetBucketTagsArgs args) { ss << ""; for (auto& [key, value] : args.tags) { ss << "" << "" << key << "" << "" << value - << "" << ""; + << "" << ""; } ss << ""; } @@ -1701,7 +1702,7 @@ SetBucketTagsResponse BaseClient::SetBucketTags(SetBucketTagsArgs args) { std::string body = ss.str(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("tagging", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1737,7 +1738,7 @@ SetBucketVersioningResponse BaseClient::SetBucketVersioning( std::string body = ss.str(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("versioning", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1768,13 +1769,13 @@ SetObjectLockConfigResponse BaseClient::SetObjectLockConfig( << ""; if (args.config.retention_duration_days) { ss << "" - << std::to_string(args.config.retention_duration_days.Get()) - << ""; + << std::to_string(args.config.retention_duration_days.Get()) + << ""; } if (args.config.retention_duration_years) { ss << "" - << std::to_string(args.config.retention_duration_years.Get()) - << ""; + << std::to_string(args.config.retention_duration_years.Get()) + << ""; } ss << ""; } @@ -1783,7 +1784,7 @@ SetObjectLockConfigResponse BaseClient::SetObjectLockConfig( std::string body = ss.str(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.query_params.Add("object-lock", ""); req.headers.Add("Content-MD5", utils::Md5sumHash(body)); @@ -1814,7 +1815,7 @@ SetObjectRetentionResponse BaseClient::SetObjectRetention( std::string body = ss.str(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1845,7 +1846,7 @@ SetObjectTagsResponse BaseClient::SetObjectTags(SetObjectTagsArgs args) { ss << ""; for (auto& [key, value] : args.tags) { ss << "" << "" << key << "" << "" << value - << "" << ""; + << "" << ""; } ss << ""; } @@ -1854,7 +1855,7 @@ SetObjectTagsResponse BaseClient::SetObjectTags(SetObjectTagsArgs args) { std::string body = ss.str(); Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1874,7 +1875,7 @@ StatObjectResponse BaseClient::StatObject(StatObjectArgs args) { if (args.ssec != nullptr && !base_url_.https) { return error::make( - "SSE-C operation must be performed over a secure connection"); + "SSE-C operation must be performed over a secure connection"); } std::string region; @@ -1885,7 +1886,7 @@ StatObjectResponse BaseClient::StatObject(StatObjectArgs args) { } Request req(http::Method::kHead, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; if (!args.version_id.empty()) { @@ -1918,7 +1919,7 @@ StatObjectResponse BaseClient::StatObject(StatObjectArgs args) { value = response.headers.GetFront("x-amz-object-lock-retain-until-date"); if (!value.empty()) { resp.retention_retain_until_date = - utils::UtcTime::FromISO8601UTC(value.c_str()); + utils::UtcTime::FromISO8601UTC(value.c_str()); } value = response.headers.GetFront("x-amz-object-lock-legal-hold"); @@ -1956,20 +1957,22 @@ UploadPartResponse BaseClient::UploadPart(UploadPartArgs args) { // send the buffer + put operation via RDMA. s3_rdma_client_ctx putCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .uploadId = args.upload_id, - .partNumber = args.part_number, - .etag = "", - .url = base_url_, - .region = region, - .op = CUOBJ_PUT, + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .uploadId = args.upload_id, + .partNumber = args.part_number, + .etag = "", + .url = base_url_, + .region = region, + .op = CUOBJ_PUT, }; ssize_t ret = args.rdmaclient->cuObjPut(&putCtx, args.buf, args.part_size); if (ret < 0) { - return UploadPartResponse(error::Error("failed to upload to object with uploadId "+ args.object + "uploadId=" + args.upload_id)); + return UploadPartResponse( + error::Error("failed to upload to object with uploadId " + + args.object + "uploadId=" + args.upload_id)); } UploadPartResponse resp; @@ -2008,7 +2011,7 @@ UploadPartCopyResponse BaseClient::UploadPartCopy(UploadPartCopyArgs args) { } Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); + args.extra_query_params); req.bucket_name = args.bucket; req.object_name = args.object; req.query_params.AddAll(args.extra_query_params); diff --git a/src/client.cc b/src/client.cc index 44a1bc65..4cc1af13 100644 --- a/src/client.cc +++ b/src/client.cc @@ -16,6 +16,7 @@ // SPDX-License-Identifier: Apache-2.0 #include "miniocpp/client.h" + #include #include @@ -39,948 +40,959 @@ #include "miniocpp/utils.h" // RDMA specific includes -#include "miniocpp/rdma.h" #include "miniocpp/nvidia-cuobjclient.h" +#include "miniocpp/rdma.h" namespace minio::s3 { - ListObjectsResult::ListObjectsResult(error::Error err) : failed_(true) { - this->resp_.contents.push_back(Item(std::move(err))); - this->itr_ = resp_.contents.begin(); - } +ListObjectsResult::ListObjectsResult(error::Error err) : failed_(true) { + this->resp_.contents.push_back(Item(std::move(err))); + this->itr_ = resp_.contents.begin(); +} - ListObjectsResult::ListObjectsResult(Client* const client, - const ListObjectsArgs& args) +ListObjectsResult::ListObjectsResult(Client* const client, + const ListObjectsArgs& args) : client_(client), args_(args) { - Populate(); - } + Populate(); +} - ListObjectsResult::ListObjectsResult(Client* const client, - ListObjectsArgs&& args) +ListObjectsResult::ListObjectsResult(Client* const client, + ListObjectsArgs&& args) : client_(client), args_(std::move(args)) { - Populate(); + Populate(); +} + +void ListObjectsResult::Populate() { + if (args_.include_versions) { + args_.key_marker = resp_.next_key_marker; + args_.version_id_marker = resp_.next_version_id_marker; + } else if (args_.use_api_v1) { + args_.marker = resp_.next_marker; + } else { + args_.start_after = resp_.start_after; + args_.continuation_token = resp_.next_continuation_token; } - void ListObjectsResult::Populate() { - if (args_.include_versions) { - args_.key_marker = resp_.next_key_marker; - args_.version_id_marker = resp_.next_version_id_marker; + std::string region; + if (GetRegionResponse resp = client_->GetRegion(args_.bucket, args_.region)) { + region = resp.region; + if (args_.recursive) { + args_.delimiter = ""; + } else if (args_.delimiter.empty()) { + args_.delimiter = "/"; + } + + if (args_.include_versions || !args_.version_id_marker.empty()) { + resp_ = client_->ListObjectVersions(ListObjectVersionsArgs(args_)); } else if (args_.use_api_v1) { - args_.marker = resp_.next_marker; + resp_ = client_->ListObjectsV1(ListObjectsV1Args(args_)); } else { - args_.start_after = resp_.start_after; - args_.continuation_token = resp_.next_continuation_token; + resp_ = client_->ListObjectsV2(ListObjectsV2Args(args_)); } - std::string region; - if (GetRegionResponse resp = client_->GetRegion(args_.bucket, args_.region)) { - region = resp.region; - if (args_.recursive) { - args_.delimiter = ""; - } else if (args_.delimiter.empty()) { - args_.delimiter = "/"; - } - - if (args_.include_versions || !args_.version_id_marker.empty()) { - resp_ = client_->ListObjectVersions(ListObjectVersionsArgs(args_)); - } else if (args_.use_api_v1) { - resp_ = client_->ListObjectsV1(ListObjectsV1Args(args_)); - } else { - resp_ = client_->ListObjectsV2(ListObjectsV2Args(args_)); - } - - if (!resp_) { - failed_ = true; - resp_.contents.push_back(Item(resp_)); - } - } else { + if (!resp_) { failed_ = true; - resp_.contents.push_back(Item(resp)); + resp_.contents.push_back(Item(resp_)); } - - itr_ = resp_.contents.begin(); + } else { + failed_ = true; + resp_.contents.push_back(Item(resp)); } - RemoveObjectsResult::RemoveObjectsResult(error::Error err) { - done_ = true; - resp_.errors.push_back(DeleteError(err)); - itr_ = resp_.errors.begin(); - } + itr_ = resp_.contents.begin(); +} - RemoveObjectsResult::RemoveObjectsResult(Client* const client, - const RemoveObjectsArgs& args) +RemoveObjectsResult::RemoveObjectsResult(error::Error err) { + done_ = true; + resp_.errors.push_back(DeleteError(err)); + itr_ = resp_.errors.begin(); +} + +RemoveObjectsResult::RemoveObjectsResult(Client* const client, + const RemoveObjectsArgs& args) : client_(client), args_(args) { - Populate(); - } + Populate(); +} - RemoveObjectsResult::RemoveObjectsResult(Client* const client, - RemoveObjectsArgs&& args) +RemoveObjectsResult::RemoveObjectsResult(Client* const client, + RemoveObjectsArgs&& args) : client_(client), args_(args) { - Populate(); - } - - void RemoveObjectsResult::Populate() { - while (!done_ && resp_.errors.size() == 0) { - RemoveObjectsApiArgs args; - args.extra_headers = args_.extra_headers; - args.extra_query_params = args_.extra_query_params; - args.bucket = args_.bucket; - args.region = args_.region; - args.quiet = true; - args.bypass_governance_mode = args_.bypass_governance_mode; - - for (int i = 0; i < 1000; i++) { - DeleteObject object; - if (!args_.func(object)) { - break; - } - args.objects.push_back(object); + Populate(); +} + +void RemoveObjectsResult::Populate() { + while (!done_ && resp_.errors.size() == 0) { + RemoveObjectsApiArgs args; + args.extra_headers = args_.extra_headers; + args.extra_query_params = args_.extra_query_params; + args.bucket = args_.bucket; + args.region = args_.region; + args.quiet = true; + args.bypass_governance_mode = args_.bypass_governance_mode; + + for (int i = 0; i < 1000; i++) { + DeleteObject object; + if (!args_.func(object)) { + break; } + args.objects.push_back(object); + } - if (args.objects.size() != 0) { - resp_ = client_->BaseClient::RemoveObjects(args); - if (!resp_) { - resp_.errors.push_back(DeleteError(resp_)); - } - itr_ = resp_.errors.begin(); - } else { - done_ = true; + if (args.objects.size() != 0) { + resp_ = client_->BaseClient::RemoveObjects(args); + if (!resp_) { + resp_.errors.push_back(DeleteError(resp_)); } + itr_ = resp_.errors.begin(); + } else { + done_ = true; } } +} - Client::Client(BaseUrl& base_url, creds::Provider* const provider) +Client::Client(BaseUrl& base_url, creds::Provider* const provider) : BaseClient(base_url, provider) {} - StatObjectResponse Client::CalculatePartCount(size_t& part_count, std::list sources) { - size_t object_size = 0; - size_t i = 0; - for (auto& source : sources) { - if (source.ssec != nullptr && !base_url_.https) { - std::string msg = "source " + source.bucket + "/" + source.object; - if (!source.version_id.empty()) { - msg += "?versionId=" + source.version_id; - } - msg += ": SSE-C operation must be performed over a secure connection"; - return error::make(msg); +StatObjectResponse Client::CalculatePartCount( + size_t& part_count, std::list sources) { + size_t object_size = 0; + size_t i = 0; + for (auto& source : sources) { + if (source.ssec != nullptr && !base_url_.https) { + std::string msg = "source " + source.bucket + "/" + source.object; + if (!source.version_id.empty()) { + msg += "?versionId=" + source.version_id; } + msg += ": SSE-C operation must be performed over a secure connection"; + return error::make(msg); + } - i++; + i++; - std::string etag; - size_t size; + std::string etag; + size_t size; - StatObjectResponse resp = StatObject(source); - if (!resp) { - return resp; - } - etag = resp.etag; - size = resp.size; - if (error::Error err = source.BuildHeaders(size, etag)) { - return StatObjectResponse(err); - } - if (source.length != nullptr) { - size = *source.length; - } else if (source.offset != nullptr) { - size -= *source.offset; - } + StatObjectResponse resp = StatObject(source); + if (!resp) { + return resp; + } + etag = resp.etag; + size = resp.size; + if (error::Error err = source.BuildHeaders(size, etag)) { + return StatObjectResponse(err); + } + if (source.length != nullptr) { + size = *source.length; + } else if (source.offset != nullptr) { + size -= *source.offset; + } - if (size < utils::kMinPartSize && sources.size() != 1 && - i != sources.size()) { - std::string msg = "source " + source.bucket + "/" + source.object; - if (!source.version_id.empty()) msg += "?versionId=" + source.version_id; - msg += ": size " + std::to_string(size) + " must be greater than " + - std::to_string(utils::kMinPartSize); - return error::make(msg); - } + if (size < utils::kMinPartSize && sources.size() != 1 && + i != sources.size()) { + std::string msg = "source " + source.bucket + "/" + source.object; + if (!source.version_id.empty()) msg += "?versionId=" + source.version_id; + msg += ": size " + std::to_string(size) + " must be greater than " + + std::to_string(utils::kMinPartSize); + return error::make(msg); + } - object_size += size; - if (object_size > utils::kMaxObjectSize) { - return error::make( - "destination object size must be less than " + - std::to_string(utils::kMaxObjectSize)); - } + object_size += size; + if (object_size > utils::kMaxObjectSize) { + return error::make( + "destination object size must be less than " + + std::to_string(utils::kMaxObjectSize)); + } - if (size > utils::kMaxPartSize) { - size_t count = size / utils::kMaxPartSize; - size_t last_part_size = size - (count * utils::kMaxPartSize); - if (last_part_size > 0) { - count++; - } else { - last_part_size = utils::kMaxPartSize; - } - - if (last_part_size < utils::kMinPartSize && sources.size() != 1 && - i != sources.size()) { - std::string msg = "source " + source.bucket + "/" + source.object; - if (!source.version_id.empty()) { - msg += "?versionId=" + source.version_id; - } - msg += ": size " + std::to_string(size) + - " for multipart split upload of " + std::to_string(size) + - ", last part size is less than " + - std::to_string(utils::kMinPartSize); - return error::make(msg); - } - - part_count += count; + if (size > utils::kMaxPartSize) { + size_t count = size / utils::kMaxPartSize; + size_t last_part_size = size - (count * utils::kMaxPartSize); + if (last_part_size > 0) { + count++; } else { - part_count++; + last_part_size = utils::kMaxPartSize; } - if (part_count > utils::kMaxMultipartCount) { - return error::make( - "Compose sources create more than allowed multipart count " + - std::to_string(utils::kMaxMultipartCount)); + if (last_part_size < utils::kMinPartSize && sources.size() != 1 && + i != sources.size()) { + std::string msg = "source " + source.bucket + "/" + source.object; + if (!source.version_id.empty()) { + msg += "?versionId=" + source.version_id; + } + msg += ": size " + std::to_string(size) + + " for multipart split upload of " + std::to_string(size) + + ", last part size is less than " + + std::to_string(utils::kMinPartSize); + return error::make(msg); } + + part_count += count; + } else { + part_count++; } - return StatObjectResponse(error::SUCCESS); + if (part_count > utils::kMaxMultipartCount) { + return error::make( + "Compose sources create more than allowed multipart count " + + std::to_string(utils::kMaxMultipartCount)); + } } - ComposeObjectResponse Client::ComposeObject(ComposeObjectArgs args, - std::string& upload_id) { - size_t part_count = 0; - { - StatObjectResponse resp = CalculatePartCount(part_count, args.sources); - if (!resp) { - return ComposeObjectResponse(resp); - } + return StatObjectResponse(error::SUCCESS); +} + +ComposeObjectResponse Client::ComposeObject(ComposeObjectArgs args, + std::string& upload_id) { + size_t part_count = 0; + { + StatObjectResponse resp = CalculatePartCount(part_count, args.sources); + if (!resp) { + return ComposeObjectResponse(resp); } + } - ComposeSource& source = args.sources.front(); - if (part_count == 1 && source.offset == nullptr && source.length == nullptr) { - CopyObjectArgs coargs; - coargs.extra_headers = args.extra_headers; - coargs.extra_query_params = args.extra_query_params; - coargs.bucket = args.bucket; - coargs.region = args.region; - coargs.object = args.object; - coargs.sse = args.sse; - coargs.source = source; + ComposeSource& source = args.sources.front(); + if (part_count == 1 && source.offset == nullptr && source.length == nullptr) { + CopyObjectArgs coargs; + coargs.extra_headers = args.extra_headers; + coargs.extra_query_params = args.extra_query_params; + coargs.bucket = args.bucket; + coargs.region = args.region; + coargs.object = args.object; + coargs.sse = args.sse; + coargs.source = source; + + return ComposeObjectResponse(CopyObject(coargs)); + } - return ComposeObjectResponse(CopyObject(coargs)); - } + utils::Multimap headers = args.Headers(); - utils::Multimap headers = args.Headers(); + { + CreateMultipartUploadArgs cmu_args; + cmu_args.extra_query_params = args.extra_query_params; + cmu_args.bucket = args.bucket; + cmu_args.region = args.region; + cmu_args.object = args.object; + cmu_args.headers = headers; + if (CreateMultipartUploadResponse resp = CreateMultipartUpload(cmu_args)) { + upload_id = resp.upload_id; + } else { + return ComposeObjectResponse(resp); + } + } - { - CreateMultipartUploadArgs cmu_args; - cmu_args.extra_query_params = args.extra_query_params; - cmu_args.bucket = args.bucket; - cmu_args.region = args.region; - cmu_args.object = args.object; - cmu_args.headers = headers; - if (CreateMultipartUploadResponse resp = CreateMultipartUpload(cmu_args)) { - upload_id = resp.upload_id; - } else { - return ComposeObjectResponse(resp); - } + unsigned int part_number = 0; + utils::Multimap ssecheaders; + if (args.sse != nullptr) { + if (SseCustomerKey* ssec = dynamic_cast(args.sse)) { + ssecheaders = ssec->Headers(); } + } - unsigned int part_number = 0; - utils::Multimap ssecheaders; - if (args.sse != nullptr) { - if (SseCustomerKey* ssec = dynamic_cast(args.sse)) { - ssecheaders = ssec->Headers(); - } + std::list parts; + for (auto& source : args.sources) { + size_t size = source.ObjectSize(); + if (source.length != nullptr) { + size = *source.length; + } else if (source.offset != nullptr) { + size -= *source.offset; } - std::list parts; - for (auto& source : args.sources) { - size_t size = source.ObjectSize(); + size_t offset = 0; + if (source.offset != nullptr) offset = *source.offset; + + utils::Multimap headers; + headers.AddAll(source.Headers()); + headers.AddAll(ssecheaders); + + if (size <= utils::kMaxPartSize) { + part_number++; if (source.length != nullptr) { - size = *source.length; + headers.Add("x-amz-copy-source-range", + "bytes=" + std::to_string(offset) + "-" + + std::to_string(offset + *source.length - 1)); } else if (source.offset != nullptr) { - size -= *source.offset; + headers.Add("x-amz-copy-source-range", + "bytes=" + std::to_string(offset) + "-" + + std::to_string(offset + size - 1)); + } + + UploadPartCopyArgs upc_args; + upc_args.bucket = args.bucket; + upc_args.region = args.region; + upc_args.object = args.object; + upc_args.headers = headers; + upc_args.upload_id = upload_id; + upc_args.part_number = part_number; + UploadPartCopyResponse resp = UploadPartCopy(upc_args); + if (!resp) { + return ComposeObjectResponse(resp); } - - size_t offset = 0; - if (source.offset != nullptr) offset = *source.offset; - - utils::Multimap headers; - headers.AddAll(source.Headers()); - headers.AddAll(ssecheaders); - - if (size <= utils::kMaxPartSize) { - part_number++; - if (source.length != nullptr) { - headers.Add("x-amz-copy-source-range", - "bytes=" + std::to_string(offset) + "-" + - std::to_string(offset + *source.length - 1)); - } else if (source.offset != nullptr) { - headers.Add("x-amz-copy-source-range", - "bytes=" + std::to_string(offset) + "-" + - std::to_string(offset + size - 1)); - } - - UploadPartCopyArgs upc_args; - upc_args.bucket = args.bucket; - upc_args.region = args.region; - upc_args.object = args.object; - upc_args.headers = headers; - upc_args.upload_id = upload_id; - upc_args.part_number = part_number; - UploadPartCopyResponse resp = UploadPartCopy(upc_args); - if (!resp) { - return ComposeObjectResponse(resp); - } - parts.push_back(Part(part_number, std::move(resp.etag))); - } else { - while (size > 0) { - part_number++; - - size_t length = size; - if (length > utils::kMaxPartSize) length = utils::kMaxPartSize; - size_t end_bytes = offset + length - 1; - - utils::Multimap headerscopy; - headerscopy.AddAll(headers); - headerscopy.Add("x-amz-copy-source-range", - "bytes=" + std::to_string(offset) + "-" + - std::to_string(end_bytes)); - - UploadPartCopyArgs upc_args; - upc_args.bucket = args.bucket; - upc_args.region = args.region; - upc_args.object = args.object; - upc_args.headers = headerscopy; - upc_args.upload_id = upload_id; - upc_args.part_number = part_number; - { - UploadPartCopyResponse resp = UploadPartCopy(upc_args); - if (!resp) { - return ComposeObjectResponse(resp); - } - parts.push_back(Part(part_number, std::move(resp.etag))); - } - offset += length; - size -= length; - } + parts.push_back(Part(part_number, std::move(resp.etag))); + } else { + while (size > 0) { + part_number++; + + size_t length = size; + if (length > utils::kMaxPartSize) length = utils::kMaxPartSize; + size_t end_bytes = offset + length - 1; + + utils::Multimap headerscopy; + headerscopy.AddAll(headers); + headerscopy.Add("x-amz-copy-source-range", + "bytes=" + std::to_string(offset) + "-" + + std::to_string(end_bytes)); + + UploadPartCopyArgs upc_args; + upc_args.bucket = args.bucket; + upc_args.region = args.region; + upc_args.object = args.object; + upc_args.headers = headerscopy; + upc_args.upload_id = upload_id; + upc_args.part_number = part_number; + { + UploadPartCopyResponse resp = UploadPartCopy(upc_args); + if (!resp) { + return ComposeObjectResponse(resp); + } + parts.push_back(Part(part_number, std::move(resp.etag))); + } + offset += length; + size -= length; } } - - CompleteMultipartUploadArgs cmu_args; - cmu_args.bucket = args.bucket; - cmu_args.region = args.region; - cmu_args.object = args.object; - cmu_args.upload_id = upload_id; - cmu_args.parts = parts; - return ComposeObjectResponse(CompleteMultipartUpload(cmu_args)); } - GetObjectResponse Client::GetObject(GetObjectArgs args) { - return BaseClient::GetObject(args); + CompleteMultipartUploadArgs cmu_args; + cmu_args.bucket = args.bucket; + cmu_args.region = args.region; + cmu_args.object = args.object; + cmu_args.upload_id = upload_id; + cmu_args.parts = parts; + return ComposeObjectResponse(CompleteMultipartUpload(cmu_args)); +} + +GetObjectResponse Client::GetObject(GetObjectArgs args) { + return BaseClient::GetObject(args); +} + +GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { + if (error::Error err = args.Validate()) { + return GetObjectResponse(err); } - GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { - if (error::Error err = args.Validate()) { - return GetObjectResponse(err); - } + std::string region; + if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { + region = resp.region; + } else { + return GetObjectResponse(resp); + } - std::string region; - if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { - region = resp.region; - } else { - return GetObjectResponse(resp); - } + CUObjIOOps ops = {.get = objectGet, .put = objectPut}; + cuObjClient rdmaclient(ops, CUOBJ_PROTO_RDMA_DC_V1); - CUObjIOOps ops = { - .get = objectGet, - .put = objectPut - }; - cuObjClient rdmaclient(ops, CUOBJ_PROTO_RDMA_DC_V1); - - const size_t size = *args.size; - - if (rdmaclient.isConnected()) { - int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); - if (res) { - return error::make("unable to register RDMA buffer for object "+ args.object); - } + const size_t size = *args.size; - // get the buffer + get operation. - s3_rdma_client_ctx getCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .uploadId = "", - .partNumber = 0, - .etag = "", - .url = base_url_, - .region = region, - .op = CUOBJ_GET, - }; + bool connected = rdmaclient.isConnected(); + std::cerr << "[RDMA_DEBUG] GetObject: cuObjClient.isConnected() = " + << (connected ? "true" : "false") << ", object=" << args.object + << ", size=" << size << std::endl; - ssize_t ret = rdmaclient.cuObjGet(&getCtx, args.buf, size); - if (ret < 0) { - rdmaclient.cuMemObjPutDescriptor(args.buf); - return error::make("failed to download to object "+ args.object); - } + if (connected) { + int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); + if (res) { + return error::make( + "unable to register RDMA buffer for object " + args.object); + } + + // get the buffer + get operation. + s3_rdma_client_ctx getCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .uploadId = "", + .partNumber = 0, + .etag = "", + .url = base_url_, + .region = region, + .op = CUOBJ_GET, + }; - res = rdmaclient.cuMemObjPutDescriptor(args.buf); - if (res) { - return error::make("unable to deregister RDMA buffer for object "+ args.object); - } + ssize_t ret = rdmaclient.cuObjGet(&getCtx, args.buf, size); + if (ret < 0) { + rdmaclient.cuMemObjPutDescriptor(args.buf); + return error::make("failed to download to object " + + args.object); + } - GetObjectResponse resp; - resp.etag = getCtx.etag; - return resp; + res = rdmaclient.cuMemObjPutDescriptor(args.buf); + if (res) { + return error::make( + "unable to deregister RDMA buffer for object " + args.object); } - GetObjectArgs targs; - std::stringstream ss(std::ios_base::in | std::ios_base::out); - ss.rdbuf()->pubsetbuf(args.buf, size); + GetObjectResponse resp; + resp.etag = getCtx.etag; + return resp; + } - targs.bucket = args.bucket; - targs.object = args.object; - targs.datafunc = [&ss = ss](minio::http::DataFunctionArgs args) -> bool { - ss << args.datachunk; - return true; - }; + GetObjectArgs targs; + std::stringstream ss(std::ios_base::in | std::ios_base::out); + ss.rdbuf()->pubsetbuf(args.buf, size); - return BaseClient::GetObject(targs); - } + targs.bucket = args.bucket; + targs.object = args.object; + targs.datafunc = [&ss = ss](minio::http::DataFunctionArgs args) -> bool { + ss << args.datachunk; + return true; + }; - PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { - if (error::Error err = args.Validate()) { - return PutObjectResponse(err); - } + return BaseClient::GetObject(targs); +} - std::string region; - if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { - region = resp.region; - } else { - return PutObjectResponse(resp); - } - - CUObjIOOps ops = { - .get = objectGet, - .put = objectPut - }; - cuObjClient rdmaclient(ops, CUOBJ_PROTO_RDMA_DC_V1); +PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { + if (error::Error err = args.Validate()) { + return PutObjectResponse(err); + } - const size_t size = *args.size; + std::string region; + if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { + region = resp.region; + } else { + return PutObjectResponse(resp); + } - if (rdmaclient.isConnected()) { - int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); - if (res) { - return error::make("unable to register RDMA buffer for object "+ args.object); - } + CUObjIOOps ops = {.get = objectGet, .put = objectPut}; + cuObjClient rdmaclient(ops, CUOBJ_PROTO_RDMA_DC_V1); - // put the buffer + put operation. - s3_rdma_client_ctx putCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .uploadId = "", - .partNumber = 0, - .etag = "", - .url = base_url_, - .region = region, - .op = CUOBJ_PUT, - }; + const size_t size = *args.size; - ssize_t ret = rdmaclient.cuObjPut(&putCtx, args.buf, size); - if (ret < 0) { - rdmaclient.cuMemObjPutDescriptor(args.buf); - return error::make("failed to upload to object "+ args.object); - } + bool connected = rdmaclient.isConnected(); + std::cerr << "[RDMA_DEBUG] PutObject: cuObjClient.isConnected() = " + << (connected ? "true" : "false") << ", object=" << args.object + << ", size=" << size << std::endl; - res = rdmaclient.cuMemObjPutDescriptor(args.buf); - if (res) { - return error::make("unable to deregister RDMA buffer for object "+ args.object); - } + if (connected) { + int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); + if (res) { + return error::make( + "unable to register RDMA buffer for object " + args.object); + } + + // put the buffer + put operation. + s3_rdma_client_ctx putCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .uploadId = "", + .partNumber = 0, + .etag = "", + .url = base_url_, + .region = region, + .op = CUOBJ_PUT, + }; - PutObjectResponse resp; - resp.etag = putCtx.etag; - return resp; + ssize_t ret = rdmaclient.cuObjPut(&putCtx, args.buf, size); + if (ret < 0) { + rdmaclient.cuMemObjPutDescriptor(args.buf); + return error::make("failed to upload to object " + + args.object); } - std::stringstream ss(std::ios_base::in | std::ios_base::out); - ss.rdbuf()->pubsetbuf(args.buf, size); - - minio::s3::PutObjectArgs aargs(ss, static_cast(size), 16*1024*1024UL); + res = rdmaclient.cuMemObjPutDescriptor(args.buf); + if (res) { + return error::make( + "unable to deregister RDMA buffer for object " + args.object); + } - return PutObject(aargs); + PutObjectResponse resp; + resp.etag = putCtx.etag; + return resp; } - PutObjectResponse Client::PutObject(PutObjectArgs args, std::string& upload_id, - char* buf) { - utils::Multimap headers = args.Headers(); - if (!headers.Contains("Content-Type")) { - if (args.content_type.empty()) { - headers.Add("Content-Type", "application/octet-stream"); - } else { - headers.Add("Content-Type", args.content_type); - } - } + std::stringstream ss(std::ios_base::in | std::ios_base::out); + ss.rdbuf()->pubsetbuf(args.buf, size); - long object_size = args.object_size; - size_t part_size = args.part_size; - size_t uploaded_size = 0; - unsigned int part_number = 0; - std::string one_byte; - bool stop = false; - std::list parts; - long part_count = args.part_count; - double uploaded_bytes = 0; // for progress - double upload_speed = -1; // for progress + minio::s3::PutObjectArgs aargs(ss, static_cast(size), + 16 * 1024 * 1024UL); - while (!stop) { - part_number++; + return PutObject(aargs); +} - size_t bytes_read = 0; - if (part_count > 0) { - if (part_number == part_count) { - part_size = object_size - uploaded_size; - stop = true; - } - - if (error::Error err = - utils::ReadPart(args.stream, buf, part_size, bytes_read)) { - - return PutObjectResponse(err); - } - - if (bytes_read != part_size) { - return error::make( - "not enough data in the stream; expected: " + - std::to_string(part_size) + ", got: " + std::to_string(bytes_read) + - " bytes"); - } - } else { - char* b = buf; - size_t size = part_size + 1; - - if (!one_byte.empty()) { - buf[0] = one_byte.front(); - b = buf + 1; - size--; - bytes_read = 1; - one_byte = ""; - } - - size_t n = 0; - if (error::Error err = utils::ReadPart(args.stream, b, size, n)) { - return PutObjectResponse(err); - } - - bytes_read += n; - - // If bytes read is less than or equals to part size, then we have reached - // last part. - if (bytes_read <= part_size) { - part_count = part_number; - part_size = bytes_read; - stop = true; - } else { - one_byte = buf[part_size + 1]; - } - } +PutObjectResponse Client::PutObject(PutObjectArgs args, std::string& upload_id, + char* buf) { + utils::Multimap headers = args.Headers(); + if (!headers.Contains("Content-Type")) { + if (args.content_type.empty()) { + headers.Add("Content-Type", "application/octet-stream"); + } else { + headers.Add("Content-Type", args.content_type); + } + } - std::string_view data(buf, part_size); + long object_size = args.object_size; + size_t part_size = args.part_size; + size_t uploaded_size = 0; + unsigned int part_number = 0; + std::string one_byte; + bool stop = false; + std::list parts; + long part_count = args.part_count; + double uploaded_bytes = 0; // for progress + double upload_speed = -1; // for progress - uploaded_size += part_size; + while (!stop) { + part_number++; - if (part_count == 1) { - PutObjectApiArgs api_args; - api_args.extra_query_params = args.extra_query_params; - api_args.bucket = args.bucket; - api_args.region = args.region; - api_args.object = args.object; - api_args.data = data; - api_args.buf = buf; - api_args.size = part_size; - api_args.progressfunc = args.progressfunc; - api_args.progress_userdata = args.progress_userdata; - api_args.headers = headers; + size_t bytes_read = 0; + if (part_count > 0) { + if (part_number == part_count) { + part_size = object_size - uploaded_size; + stop = true; + } - return BaseClient::PutObject(api_args); + if (error::Error err = + utils::ReadPart(args.stream, buf, part_size, bytes_read)) { + return PutObjectResponse(err); } - if (upload_id.empty()) { - CreateMultipartUploadArgs cmu_args; - cmu_args.extra_query_params = args.extra_query_params; - cmu_args.bucket = args.bucket; - cmu_args.region = args.region; - cmu_args.object = args.object; - cmu_args.headers = headers; - if (CreateMultipartUploadResponse resp = - CreateMultipartUpload(cmu_args)) { - upload_id = resp.upload_id; - } else { - return PutObjectResponse(resp); - } + if (bytes_read != part_size) { + return error::make( + "not enough data in the stream; expected: " + + std::to_string(part_size) + ", got: " + std::to_string(bytes_read) + + " bytes"); } + } else { + char* b = buf; + size_t size = part_size + 1; - UploadPartArgs up_args; - up_args.bucket = args.bucket; - up_args.region = args.region; - up_args.object = args.object; - up_args.upload_id = upload_id; - up_args.part_number = part_number; - up_args.data = data; - up_args.buf = buf; - up_args.part_size = part_size; - if (args.progressfunc != nullptr) { - up_args.progressfunc = - [&object_size = object_size, &uploaded_bytes = uploaded_bytes, - &upload_speed = upload_speed, &progressfunc = args.progressfunc, - &progress_userdata = args.progress_userdata]( - http::ProgressFunctionArgs args) -> bool { - if (args.upload_speed > 0) { - if (upload_speed == -1) { - upload_speed = args.upload_speed; - } else { - upload_speed = (upload_speed + args.upload_speed) / 2; - } - return true; - } - - http::ProgressFunctionArgs actual_args; - actual_args.upload_total_bytes = static_cast(object_size); - actual_args.uploaded_bytes = uploaded_bytes + args.uploaded_bytes; - actual_args.userdata = progress_userdata; - return progressfunc(actual_args); - }; + if (!one_byte.empty()) { + buf[0] = one_byte.front(); + b = buf + 1; + size--; + bytes_read = 1; + one_byte = ""; } - if (args.sse != nullptr) { - if (SseCustomerKey* ssec = dynamic_cast(args.sse)) { - up_args.headers = ssec->Headers(); - } + + size_t n = 0; + if (error::Error err = utils::ReadPart(args.stream, b, size, n)) { + return PutObjectResponse(err); } - if (UploadPartResponse resp = UploadPart(up_args)) { - if (args.progressfunc != nullptr) { - uploaded_bytes += static_cast(data.length()); - http::ProgressFunctionArgs actual_args; - actual_args.upload_total_bytes = static_cast(object_size); - actual_args.uploaded_bytes = uploaded_bytes; - actual_args.userdata = args.progress_userdata; - if (!args.progressfunc(actual_args)) { - return UploadPartResponse( - error::Error("aborted by progress function")); - } - } - parts.push_back(Part(part_number, std::move(resp.etag))); + bytes_read += n; + + // If bytes read is less than or equals to part size, then we have reached + // last part. + if (bytes_read <= part_size) { + part_count = part_number; + part_size = bytes_read; + stop = true; } else { - return resp; + one_byte = buf[part_size + 1]; } } - CompleteMultipartUploadArgs cmu_args; - cmu_args.bucket = args.bucket; - cmu_args.region = args.region; - cmu_args.object = args.object; - cmu_args.upload_id = upload_id; - cmu_args.parts = parts; - CompleteMultipartUploadResponse resp = CompleteMultipartUpload(cmu_args); - if (resp && args.progressfunc != nullptr) { - http::ProgressFunctionArgs actual_args; - actual_args.upload_speed = upload_speed; - actual_args.userdata = args.progress_userdata; - // ignore the return value as we completed the upload - args.progressfunc(actual_args); - } - return PutObjectResponse(resp); - } + std::string_view data(buf, part_size); - ComposeObjectResponse Client::ComposeObject(ComposeObjectArgs args) { - if (error::Error err = args.Validate()) { - return ComposeObjectResponse(err); - } + uploaded_size += part_size; + + if (part_count == 1) { + PutObjectApiArgs api_args; + api_args.extra_query_params = args.extra_query_params; + api_args.bucket = args.bucket; + api_args.region = args.region; + api_args.object = args.object; + api_args.data = data; + api_args.buf = buf; + api_args.size = part_size; + api_args.progressfunc = args.progressfunc; + api_args.progress_userdata = args.progress_userdata; + api_args.headers = headers; - if (args.sse != nullptr && args.sse->TlsRequired() && !base_url_.https) { - return error::make( - "SSE operation must be performed over a secure connection"); + return BaseClient::PutObject(api_args); } - std::string upload_id; - ComposeObjectResponse resp = ComposeObject(args, upload_id); - if (!resp && !upload_id.empty()) { - AbortMultipartUploadArgs amu_args; - amu_args.bucket = args.bucket; - amu_args.region = args.region; - amu_args.object = args.object; - amu_args.upload_id = upload_id; - AbortMultipartUpload(amu_args); + if (upload_id.empty()) { + CreateMultipartUploadArgs cmu_args; + cmu_args.extra_query_params = args.extra_query_params; + cmu_args.bucket = args.bucket; + cmu_args.region = args.region; + cmu_args.object = args.object; + cmu_args.headers = headers; + if (CreateMultipartUploadResponse resp = + CreateMultipartUpload(cmu_args)) { + upload_id = resp.upload_id; + } else { + return PutObjectResponse(resp); + } + } + + UploadPartArgs up_args; + up_args.bucket = args.bucket; + up_args.region = args.region; + up_args.object = args.object; + up_args.upload_id = upload_id; + up_args.part_number = part_number; + up_args.data = data; + up_args.buf = buf; + up_args.part_size = part_size; + if (args.progressfunc != nullptr) { + up_args.progressfunc = + [&object_size = object_size, &uploaded_bytes = uploaded_bytes, + &upload_speed = upload_speed, &progressfunc = args.progressfunc, + &progress_userdata = args.progress_userdata]( + http::ProgressFunctionArgs args) -> bool { + if (args.upload_speed > 0) { + if (upload_speed == -1) { + upload_speed = args.upload_speed; + } else { + upload_speed = (upload_speed + args.upload_speed) / 2; + } + return true; + } + + http::ProgressFunctionArgs actual_args; + actual_args.upload_total_bytes = static_cast(object_size); + actual_args.uploaded_bytes = uploaded_bytes + args.uploaded_bytes; + actual_args.userdata = progress_userdata; + return progressfunc(actual_args); + }; + } + if (args.sse != nullptr) { + if (SseCustomerKey* ssec = dynamic_cast(args.sse)) { + up_args.headers = ssec->Headers(); + } } - return resp; + if (UploadPartResponse resp = UploadPart(up_args)) { + if (args.progressfunc != nullptr) { + uploaded_bytes += static_cast(data.length()); + http::ProgressFunctionArgs actual_args; + actual_args.upload_total_bytes = static_cast(object_size); + actual_args.uploaded_bytes = uploaded_bytes; + actual_args.userdata = args.progress_userdata; + if (!args.progressfunc(actual_args)) { + return UploadPartResponse( + error::Error("aborted by progress function")); + } + } + parts.push_back(Part(part_number, std::move(resp.etag))); + } else { + return resp; + } } - CopyObjectResponse Client::CopyObject(CopyObjectArgs args) { - if (error::Error err = args.Validate()) { - return CopyObjectResponse(err); - } + CompleteMultipartUploadArgs cmu_args; + cmu_args.bucket = args.bucket; + cmu_args.region = args.region; + cmu_args.object = args.object; + cmu_args.upload_id = upload_id; + cmu_args.parts = parts; + CompleteMultipartUploadResponse resp = CompleteMultipartUpload(cmu_args); + if (resp && args.progressfunc != nullptr) { + http::ProgressFunctionArgs actual_args; + actual_args.upload_speed = upload_speed; + actual_args.userdata = args.progress_userdata; + // ignore the return value as we completed the upload + args.progressfunc(actual_args); + } + return PutObjectResponse(resp); +} - if (args.sse != nullptr && args.sse->TlsRequired() && !base_url_.https) { - return error::make( - "SSE operation must be performed over a secure connection"); - } +ComposeObjectResponse Client::ComposeObject(ComposeObjectArgs args) { + if (error::Error err = args.Validate()) { + return ComposeObjectResponse(err); + } - if (args.source.ssec != nullptr && !base_url_.https) { - return error::make( - "SSE-C operation must be performed over a secure connection"); - } + if (args.sse != nullptr && args.sse->TlsRequired() && !base_url_.https) { + return error::make( + "SSE operation must be performed over a secure connection"); + } - std::string etag; - size_t size; - { - StatObjectResponse resp = StatObject(args.source); - if (!resp) { - return CopyObjectResponse(resp); - } - etag = resp.etag; - size = resp.size; - } + std::string upload_id; + ComposeObjectResponse resp = ComposeObject(args, upload_id); + if (!resp && !upload_id.empty()) { + AbortMultipartUploadArgs amu_args; + amu_args.bucket = args.bucket; + amu_args.region = args.region; + amu_args.object = args.object; + amu_args.upload_id = upload_id; + AbortMultipartUpload(amu_args); + } - if (args.source.offset != nullptr || args.source.length != nullptr || - size > utils::kMaxPartSize) { - if (args.metadata_directive != nullptr && - *args.metadata_directive == Directive::kCopy) { - return error::make( - "COPY metadata directive is not applicable to source object size " - "greater than 5 GiB"); - } + return resp; +} - if (args.tagging_directive != nullptr && - *args.tagging_directive == Directive::kCopy) { - return error::make( - "COPY tagging directive is not applicable to source object size " - "greater than 5 GiB"); - } +CopyObjectResponse Client::CopyObject(CopyObjectArgs args) { + if (error::Error err = args.Validate()) { + return CopyObjectResponse(err); + } - ComposeSource src; - src.extra_headers = args.source.extra_headers; - src.extra_query_params = args.source.extra_query_params; - src.bucket = args.source.bucket; - src.region = args.source.region; - src.object = args.source.object; - src.ssec = args.source.ssec; - src.offset = args.source.offset; - src.length = args.source.length; - src.match_etag = args.source.match_etag; - src.not_match_etag = args.source.not_match_etag; - src.modified_since = args.source.modified_since; - src.unmodified_since = args.source.unmodified_since; - - ComposeObjectArgs coargs; - coargs.extra_headers = args.extra_headers; - coargs.extra_query_params = args.extra_query_params; - coargs.bucket = args.bucket; - coargs.region = args.region; - coargs.object = args.object; - coargs.sse = args.sse; - coargs.sources.push_back(src); - - return CopyObjectResponse(ComposeObject(coargs)); - } + if (args.sse != nullptr && args.sse->TlsRequired() && !base_url_.https) { + return error::make( + "SSE operation must be performed over a secure connection"); + } - utils::Multimap headers; - headers.AddAll(args.extra_headers); - headers.AddAll(args.Headers()); - if (args.metadata_directive != nullptr) { - headers.Add("x-amz-metadata-directive", - DirectiveToString(*args.metadata_directive)); - } - if (args.tagging_directive != nullptr) { - headers.Add("x-amz-tagging-directive", - DirectiveToString(*args.tagging_directive)); - } - headers.AddAll(args.source.CopyHeaders()); + if (args.source.ssec != nullptr && !base_url_.https) { + return error::make( + "SSE-C operation must be performed over a secure connection"); + } - std::string region; - if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { - region = resp.region; - } else { + std::string etag; + size_t size; + { + StatObjectResponse resp = StatObject(args.source); + if (!resp) { return CopyObjectResponse(resp); } + etag = resp.etag; + size = resp.size; + } - Request req(http::Method::kPut, region, base_url_, args.extra_headers, - args.extra_query_params); - req.bucket_name = args.bucket; - req.object_name = args.object; - req.headers.AddAll(headers); - - Response response = Execute(req); - if (!response) { - return CopyObjectResponse(response); + if (args.source.offset != nullptr || args.source.length != nullptr || + size > utils::kMaxPartSize) { + if (args.metadata_directive != nullptr && + *args.metadata_directive == Directive::kCopy) { + return error::make( + "COPY metadata directive is not applicable to source object size " + "greater than 5 GiB"); } - CopyObjectResponse resp; - resp.etag = utils::Trim(response.headers.GetFront("etag"), '"'); - resp.version_id = response.headers.GetFront("x-amz-version-id"); + if (args.tagging_directive != nullptr && + *args.tagging_directive == Directive::kCopy) { + return error::make( + "COPY tagging directive is not applicable to source object size " + "greater than 5 GiB"); + } + + ComposeSource src; + src.extra_headers = args.source.extra_headers; + src.extra_query_params = args.source.extra_query_params; + src.bucket = args.source.bucket; + src.region = args.source.region; + src.object = args.source.object; + src.ssec = args.source.ssec; + src.offset = args.source.offset; + src.length = args.source.length; + src.match_etag = args.source.match_etag; + src.not_match_etag = args.source.not_match_etag; + src.modified_since = args.source.modified_since; + src.unmodified_since = args.source.unmodified_since; + + ComposeObjectArgs coargs; + coargs.extra_headers = args.extra_headers; + coargs.extra_query_params = args.extra_query_params; + coargs.bucket = args.bucket; + coargs.region = args.region; + coargs.object = args.object; + coargs.sse = args.sse; + coargs.sources.push_back(src); + + return CopyObjectResponse(ComposeObject(coargs)); + } - return resp; + utils::Multimap headers; + headers.AddAll(args.extra_headers); + headers.AddAll(args.Headers()); + if (args.metadata_directive != nullptr) { + headers.Add("x-amz-metadata-directive", + DirectiveToString(*args.metadata_directive)); + } + if (args.tagging_directive != nullptr) { + headers.Add("x-amz-tagging-directive", + DirectiveToString(*args.tagging_directive)); } + headers.AddAll(args.source.CopyHeaders()); - DownloadObjectResponse Client::DownloadObject(DownloadObjectArgs args) { - if (error::Error err = args.Validate()) { - return DownloadObjectResponse(err); - } + std::string region; + if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { + region = resp.region; + } else { + return CopyObjectResponse(resp); + } - if (args.ssec != nullptr && !base_url_.https) { - return error::make( - "SSE-C operation must be performed over a secure connection"); - } + Request req(http::Method::kPut, region, base_url_, args.extra_headers, + args.extra_query_params); + req.bucket_name = args.bucket; + req.object_name = args.object; + req.headers.AddAll(headers); - std::string etag; - { - StatObjectArgs soargs; - soargs.bucket = args.bucket; - soargs.region = args.region; - soargs.object = args.object; - soargs.version_id = args.version_id; - soargs.ssec = args.ssec; - StatObjectResponse resp = StatObject(soargs); - if (!resp) { - return DownloadObjectResponse(resp); - } - etag = resp.etag; - } + Response response = Execute(req); + if (!response) { + return CopyObjectResponse(response); + } - std::string temp_filename = - args.filename + "." + curlpp::escape(etag) + ".part.minio"; - std::ofstream fout(temp_filename, - std::ios::trunc | std::ios::out | std::ios::binary); - if (!fout.is_open()) { - return error::make("unable to open file " + - temp_filename); - } + CopyObjectResponse resp; + resp.etag = utils::Trim(response.headers.GetFront("etag"), '"'); + resp.version_id = response.headers.GetFront("x-amz-version-id"); - std::string region; - if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { - region = resp.region; - } else { - return DownloadObjectResponse(resp); - } + return resp; +} - Request req(http::Method::kGet, region, base_url_, args.extra_headers, - args.extra_query_params); - req.bucket_name = args.bucket; - req.object_name = args.object; - if (!args.version_id.empty()) { - req.query_params.Add("versionId", args.version_id); - } - req.datafunc = [&fout = fout](http::DataFunctionArgs args) -> bool { - fout << args.datachunk; - return true; - }; - req.progressfunc = args.progressfunc; - req.progress_userdata = args.progress_userdata; +DownloadObjectResponse Client::DownloadObject(DownloadObjectArgs args) { + if (error::Error err = args.Validate()) { + return DownloadObjectResponse(err); + } - Response response = Execute(req); - fout.close(); - if (response) { - std::filesystem::rename(temp_filename, args.filename); - } - return DownloadObjectResponse(response); + if (args.ssec != nullptr && !base_url_.https) { + return error::make( + "SSE-C operation must be performed over a secure connection"); } - ListObjectsResult Client::ListObjects(ListObjectsArgs args) { - if (error::Error err = args.Validate()) { - return ListObjectsResult(err); + std::string etag; + { + StatObjectArgs soargs; + soargs.bucket = args.bucket; + soargs.region = args.region; + soargs.object = args.object; + soargs.version_id = args.version_id; + soargs.ssec = args.ssec; + StatObjectResponse resp = StatObject(soargs); + if (!resp) { + return DownloadObjectResponse(resp); } - return ListObjectsResult(this, std::move(args)); + etag = resp.etag; } - PutObjectResponse Client::PutObject(PutObjectArgs args) { - if (error::Error err = args.Validate()) { - return PutObjectResponse(err); - } + std::string temp_filename = + args.filename + "." + curlpp::escape(etag) + ".part.minio"; + std::ofstream fout(temp_filename, std::ios::trunc | std::ios::out); + if (!fout.is_open()) { + return error::make("unable to open file " + + temp_filename); + } - if (args.sse != nullptr && args.sse->TlsRequired() && !base_url_.https) { - return error::make( - "SSE operation must be performed over a secure connection"); - } + std::string region; + if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { + region = resp.region; + } else { + return DownloadObjectResponse(resp); + } - char *buf; - int res = posix_memalign((void **)&buf, getpagesize(), (args.part_count > 0) ? args.part_size : args.part_size + 1); - if (res) { - return error::make("unable to allocate system memory with alignment"); - } + Request req(http::Method::kGet, region, base_url_, args.extra_headers, + args.extra_query_params); + req.bucket_name = args.bucket; + req.object_name = args.object; + if (!args.version_id.empty()) { + req.query_params.Add("versionId", args.version_id); + } + req.datafunc = [&fout = fout](http::DataFunctionArgs args) -> bool { + fout << args.datachunk; + return true; + }; + req.progressfunc = args.progressfunc; + req.progress_userdata = args.progress_userdata; + + Response response = Execute(req); + fout.close(); + if (response) { + std::filesystem::rename(temp_filename, args.filename); + } + return DownloadObjectResponse(response); +} - CUObjIOOps ops = { - .get = objectGet, - .put = objectPut - }; - std::unique_ptr rdmaclient(new cuObjClient(ops, CUOBJ_PROTO_RDMA_DC_V1)); +ListObjectsResult Client::ListObjects(ListObjectsArgs args) { + if (error::Error err = args.Validate()) { + return ListObjectsResult(err); + } + return ListObjectsResult(this, std::move(args)); +} - if (rdmaclient->isConnected()) { - res = rdmaclient->cuMemObjGetDescriptor(buf, args.part_size); - if (res) { - free(buf); - return error::make("unable to register RDMA buffer"); - } - } +PutObjectResponse Client::PutObject(PutObjectArgs args) { + if (error::Error err = args.Validate()) { + return PutObjectResponse(err); + } - std::string upload_id; - args.rdmaclient = rdmaclient.get(); - PutObjectResponse resp = PutObject(args, upload_id, buf); + if (args.sse != nullptr && args.sse->TlsRequired() && !base_url_.https) { + return error::make( + "SSE operation must be performed over a secure connection"); + } - if (!resp && !upload_id.empty()) { - AbortMultipartUploadArgs amu_args; - amu_args.bucket = std::move(args.bucket); - amu_args.region = std::move(args.region); - amu_args.object = std::move(args.object); - amu_args.upload_id = upload_id; - AbortMultipartUpload(amu_args); - } + char* buf; + int res = posix_memalign( + (void**)&buf, getpagesize(), + (args.part_count > 0) ? args.part_size : args.part_size + 1); + if (res) { + return error::make( + "unable to allocate system memory with alignment"); + } - if (rdmaclient->isConnected()) { - res = rdmaclient->cuMemObjPutDescriptor(buf); - if (res) { - free(buf); - return error::make("unable to deregister RDMA buffer"); - } + CUObjIOOps ops = {.get = objectGet, .put = objectPut}; + std::unique_ptr rdmaclient( + new cuObjClient(ops, CUOBJ_PROTO_RDMA_DC_V1)); + + if (rdmaclient->isConnected()) { + res = rdmaclient->cuMemObjGetDescriptor(buf, args.part_size); + if (res) { + free(buf); + return error::make("unable to register RDMA buffer"); } + } - free(buf); - return resp; + std::string upload_id; + args.rdmaclient = rdmaclient.get(); + PutObjectResponse resp = PutObject(args, upload_id, buf); + + if (!resp && !upload_id.empty()) { + AbortMultipartUploadArgs amu_args; + amu_args.bucket = std::move(args.bucket); + amu_args.region = std::move(args.region); + amu_args.object = std::move(args.object); + amu_args.upload_id = upload_id; + AbortMultipartUpload(amu_args); } - UploadObjectResponse Client::UploadObject(UploadObjectArgs args) { - if (error::Error err = args.Validate()) { - return UploadObjectResponse(err); + if (rdmaclient->isConnected()) { + res = rdmaclient->cuMemObjPutDescriptor(buf); + if (res) { + free(buf); + return error::make("unable to deregister RDMA buffer"); } + } - std::ifstream file; - file.exceptions(std::ifstream::failbit | std::ifstream::badbit); - try { - file.open(args.filename); - } catch (std::system_error& err) { - return error::make( - "unable to open file " + args.filename + "; " + err.code().message()); - } + free(buf); + return resp; +} - PutObjectArgs po_args(file, args.object_size, 0); - po_args.extra_headers = std::move(args.extra_headers); - po_args.extra_query_params = std::move(args.extra_query_params); - po_args.bucket = std::move(args.bucket); - po_args.region = std::move(args.region); - po_args.object = std::move(args.object); - po_args.headers = std::move(args.headers); - po_args.user_metadata = std::move(args.user_metadata); - po_args.sse = std::move(args.sse); - po_args.tags = std::move(args.tags); - po_args.retention = std::move(args.retention); - po_args.legal_hold = std::move(args.legal_hold); - po_args.content_type = std::move(args.content_type); - po_args.progressfunc = std::move(args.progressfunc); - po_args.progress_userdata = std::move(args.progress_userdata); +UploadObjectResponse Client::UploadObject(UploadObjectArgs args) { + if (error::Error err = args.Validate()) { + return UploadObjectResponse(err); + } - PutObjectResponse resp = PutObject(std::move(po_args)); - file.close(); - return UploadObjectResponse(resp); + std::ifstream file; + file.exceptions(std::ifstream::failbit | std::ifstream::badbit); + try { + file.open(args.filename); + } catch (std::system_error& err) { + return error::make( + "unable to open file " + args.filename + "; " + err.code().message()); } - RemoveObjectsResult Client::RemoveObjects(RemoveObjectsArgs args) { - if (error::Error err = args.Validate()) { - return RemoveObjectsResult(err); - } - return RemoveObjectsResult(this, std::move(args)); + PutObjectArgs po_args(file, args.object_size, 0); + po_args.extra_headers = std::move(args.extra_headers); + po_args.extra_query_params = std::move(args.extra_query_params); + po_args.bucket = std::move(args.bucket); + po_args.region = std::move(args.region); + po_args.object = std::move(args.object); + po_args.headers = std::move(args.headers); + po_args.user_metadata = std::move(args.user_metadata); + po_args.sse = std::move(args.sse); + po_args.tags = std::move(args.tags); + po_args.retention = std::move(args.retention); + po_args.legal_hold = std::move(args.legal_hold); + po_args.content_type = std::move(args.content_type); + po_args.progressfunc = std::move(args.progressfunc); + po_args.progress_userdata = std::move(args.progress_userdata); + + PutObjectResponse resp = PutObject(std::move(po_args)); + file.close(); + return UploadObjectResponse(resp); +} + +RemoveObjectsResult Client::RemoveObjects(RemoveObjectsArgs args) { + if (error::Error err = args.Validate()) { + return RemoveObjectsResult(err); } + return RemoveObjectsResult(this, std::move(args)); +} } // namespace minio::s3 diff --git a/src/request.cc b/src/request.cc index 9b6130cd..cdcec5e8 100644 --- a/src/request.cc +++ b/src/request.cc @@ -164,6 +164,10 @@ BaseUrl::BaseUrl(std::string host, bool https, std::string region) this->host = url.host; this->port = url.port; + // Use parsed URL's https setting if URL was provided with scheme + if (host.find("://") != std::string::npos) { + this->https = url.https; + } if (!this->region.empty() && !awsRegexMatch(this->region, REGION_REGEX)) { this->err_ = error::Error("invalid region " + this->region); diff --git a/src/response.cc b/src/response.cc index a778e6eb..b77f5456 100644 --- a/src/response.cc +++ b/src/response.cc @@ -42,13 +42,13 @@ error::Error Response::Error() const { } if (status_code && (status_code < 200 || status_code > 299)) { return error::Error("failed with HTTP status code " + - std::to_string(status_code)); + std::to_string(status_code)); } return error::SUCCESS; } Response Response::ParseXML(std::string_view data, int status_code, - utils::Multimap headers) { + utils::Multimap headers) { Response resp; resp.status_code = status_code; resp.headers = headers; @@ -157,7 +157,7 @@ CompleteMultipartUploadResponse CompleteMultipartUploadResponse::ParseXML( } ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, - bool version) { + bool version) { ListObjectsResponse resp; pugi::xml_document xdoc; @@ -198,12 +198,12 @@ ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, text = root.node().select_node("Marker/text()"); value = text.node().value(); resp.marker = - (resp.encoding_type == "url") ? curlpp::unescape(value) : value; + (resp.encoding_type == "url") ? curlpp::unescape(value) : value; text = root.node().select_node("NextMarker/text()"); value = text.node().value(); resp.next_marker = - (resp.encoding_type == "url") ? curlpp::unescape(value) : value; + (resp.encoding_type == "url") ? curlpp::unescape(value) : value; } // ListBucketResult V2 @@ -216,7 +216,7 @@ ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, text = root.node().select_node("StartAfter/text()"); value = text.node().value(); resp.start_after = - (resp.encoding_type == "url") ? curlpp::unescape(value) : value; + (resp.encoding_type == "url") ? curlpp::unescape(value) : value; text = root.node().select_node("ContinuationToken/text()"); resp.continuation_token = text.node().value(); @@ -230,12 +230,12 @@ ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, text = root.node().select_node("KeyMarker/text()"); value = text.node().value(); resp.key_marker = - (resp.encoding_type == "url") ? curlpp::unescape(value) : value; + (resp.encoding_type == "url") ? curlpp::unescape(value) : value; text = root.node().select_node("NextKeyMarker/text()"); value = text.node().value(); resp.next_key_marker = - (resp.encoding_type == "url") ? curlpp::unescape(value) : value; + (resp.encoding_type == "url") ? curlpp::unescape(value) : value; text = root.node().select_node("VersionIdMarker/text()"); resp.version_id_marker = text.node().value(); @@ -247,8 +247,8 @@ ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, Item last_item; auto populate = [&resp = resp, &last_item = last_item]( - std::list& items, pugi::xpath_node_set& contents, - bool is_delete_marker) -> void { + std::list& items, pugi::xpath_node_set& contents, + bool is_delete_marker) -> void { for (auto content : contents) { pugi::xpath_node text; std::string value; @@ -260,7 +260,7 @@ ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, text = content.node().select_node("Key/text()"); value = text.node().value(); item.name = - (resp.encoding_type == "url") ? curlpp::unescape(value) : value; + (resp.encoding_type == "url") ? curlpp::unescape(value) : value; text = content.node().select_node("LastModified/text()"); value = text.node().value(); @@ -288,8 +288,8 @@ ListObjectsResponse ListObjectsResponse::ParseXML(std::string_view data, auto user_metadata = content.node().select_node("UserMetadata"); for (auto metadata = user_metadata.node().first_child(); metadata; - metadata = metadata.next_sibling()) { - item.user_metadata[metadata.name()] = metadata.child_value(); + metadata = metadata.next_sibling()) { + item.user_metadata[metadata.name()] = metadata.child_value(); } item.is_delete_marker = is_delete_marker; @@ -405,17 +405,17 @@ GetBucketNotificationResponse GetBucketNotificationResponse::ParseXML( if (common.node().select_node("Filter")) { auto filters = common.node().select_nodes("Filter/S3Key/FilterRule"); for (auto filter : filters) { - text = filter.node().select_node("Name/text()"); - auto name = text.node().value(); + text = filter.node().select_node("Name/text()"); + auto name = text.node().value(); - text = filter.node().select_node("Value/text()"); - auto value = text.node().value(); + text = filter.node().select_node("Value/text()"); + auto value = text.node().value(); - if (strcmp(name, "prefix") == 0) { - cfg.prefix_filter_rule = PrefixFilterRule(value); - } else { - cfg.suffix_filter_rule = SuffixFilterRule(value); - } + if (strcmp(name, "prefix") == 0) { + cfg.prefix_filter_rule = PrefixFilterRule(value); + } else { + cfg.suffix_filter_rule = SuffixFilterRule(value); + } } } @@ -542,27 +542,27 @@ GetBucketReplicationResponse GetBucketReplicationResponse::ParseXML( if (destination.node().select_node("AccessControlTranslation")) { rrule.destination.access_control_translation.Enable(); text = destination.node().select_node( - "AccessControlTranslation/Owner/text()"); + "AccessControlTranslation/Owner/text()"); rrule.destination.access_control_translation.owner = text.node().value(); } if (destination.node().select_node("EncryptionConfiguration")) { rrule.destination.encryption_config.Enable(); text = destination.node().select_node( - "EncryptionConfiguration/ReplicaKmsKeyID/text()"); + "EncryptionConfiguration/ReplicaKmsKeyID/text()"); rrule.destination.encryption_config.replica_kms_key_id = - text.node().value(); + text.node().value(); } if (destination.node().select_node("Metrics")) { rrule.destination.metrics.Enable(); text = destination.node().select_node( - "Metrics/EventThreshold/Minutes/text()"); + "Metrics/EventThreshold/Minutes/text()"); value = text.node().value(); rrule.destination.metrics.event_threshold_minutes = - static_cast(std::stoul(value)); + static_cast(std::stoul(value)); text = destination.node().select_node( - "Metrics/EventThreshold/Status/text()"); + "Metrics/EventThreshold/Status/text()"); value = text.node().value(); rrule.destination.metrics.status = (value == "Enabled"); } @@ -572,7 +572,7 @@ GetBucketReplicationResponse GetBucketReplicationResponse::ParseXML( text = destination.node().select_node("ReplicationTime/Time/text()"); value = text.node().value(); rrule.destination.replication_time.time_minutes = - static_cast(std::stoul(value)); + static_cast(std::stoul(value)); text = destination.node().select_node("ReplicationTime/Status/text()"); value = text.node().value(); @@ -595,37 +595,37 @@ GetBucketReplicationResponse GetBucketReplicationResponse::ParseXML( auto filter = rule.node().select_node("Filter"); if (filter.node().select_node("And")) { - if (filter.node().select_node("And/Prefix")) { - text = filter.node().select_node("And/Prefix/text()"); - rrule.filter.and_operator.prefix = Prefix(text.node().value()); - } - - if (filter.node().select_node("And/Tag")) { - auto tags = root.node().select_nodes("And/Tag"); - for (auto& tag : tags) { - (void)tag; - text = filter.node().select_node("Key/text()"); - std::string key = text.node().value(); - - text = filter.node().select_node("Value/text()"); - std::string value = text.node().value(); - - rrule.filter.and_operator.tags[key] = value; - } - } + if (filter.node().select_node("And/Prefix")) { + text = filter.node().select_node("And/Prefix/text()"); + rrule.filter.and_operator.prefix = Prefix(text.node().value()); + } + + if (filter.node().select_node("And/Tag")) { + auto tags = root.node().select_nodes("And/Tag"); + for (auto& tag : tags) { + (void)tag; + text = filter.node().select_node("Key/text()"); + std::string key = text.node().value(); + + text = filter.node().select_node("Value/text()"); + std::string value = text.node().value(); + + rrule.filter.and_operator.tags[key] = value; + } + } } if (filter.node().select_node("Prefix")) { - text = filter.node().select_node("Prefix/text()"); - rrule.filter.prefix = Prefix(text.node().value()); + text = filter.node().select_node("Prefix/text()"); + rrule.filter.prefix = Prefix(text.node().value()); } if (filter.node().select_node("Tag")) { - text = filter.node().select_node("Tag/Key/text()"); - rrule.filter.tag.key = text.node().value(); + text = filter.node().select_node("Tag/Key/text()"); + rrule.filter.tag.key = text.node().value(); - text = filter.node().select_node("Tag/Value/text()"); - rrule.filter.tag.value = text.node().value(); + text = filter.node().select_node("Tag/Value/text()"); + rrule.filter.tag.value = text.node().value(); } } @@ -643,12 +643,12 @@ GetBucketReplicationResponse GetBucketReplicationResponse::ParseXML( if (rule.node().select_node("SourceSelectionCriteria")) { rrule.source_selection_criteria.Enable(); if (rule.node().select_node( - "SourceSelectionCriteria/SseKmsEncryptedObjects")) { - text = rule.node().select_node( - "SourceSelectionCriteria/SseKmsEncryptedObjects/Status/text()"); - value = text.node().value(); - rrule.source_selection_criteria.sse_kms_encrypted_objects_status = - (value == "Enabled"); + "SourceSelectionCriteria/SseKmsEncryptedObjects")) { + text = rule.node().select_node( + "SourceSelectionCriteria/SseKmsEncryptedObjects/Status/text()"); + value = text.node().value(); + rrule.source_selection_criteria.sse_kms_encrypted_objects_status = + (value == "Enabled"); } } @@ -684,52 +684,52 @@ GetBucketLifecycleResponse GetBucketLifecycleResponse::ParseXML( if (rule.node().select_node("AbortIncompleteMultipartUpload")) { text = rule.node().select_node( - "AbortIncompleteMultipartUpload/DaysAfterInitiation/text()"); + "AbortIncompleteMultipartUpload/DaysAfterInitiation/text()"); value = text.node().value(); lrule.abort_incomplete_multipart_upload_days_after_initiation = - std::stoi(value); + std::stoi(value); } if (rule.node().select_node("Expiration")) { if (rule.node().select_node("Expiration/Date")) { - text = rule.node().select_node("Expiration/Date/text()"); - lrule.expiration_date = - utils::UtcTime::FromISO8601UTC(text.node().value()); + text = rule.node().select_node("Expiration/Date/text()"); + lrule.expiration_date = + utils::UtcTime::FromISO8601UTC(text.node().value()); } if (rule.node().select_node("Expiration/Days")) { - text = rule.node().select_node("Expiration/Days/text()"); - value = text.node().value(); - lrule.expiration_days = std::stoi(value); + text = rule.node().select_node("Expiration/Days/text()"); + value = text.node().value(); + lrule.expiration_days = std::stoi(value); } if (rule.node().select_node("Expiration/ExpiredObjectDeleteMarker")) { - text = rule.node().select_node( - "Expiration/ExpiredObjectDeleteMarker/text()"); - lrule.expiration_expired_object_delete_marker = - utils::BoolToString(text.node().value()); + text = rule.node().select_node( + "Expiration/ExpiredObjectDeleteMarker/text()"); + lrule.expiration_expired_object_delete_marker = + utils::BoolToString(text.node().value()); } } auto filter = rule.node().select_node("Filter"); if (filter.node().select_node("And")) { if (filter.node().select_node("And/Prefix")) { - text = filter.node().select_node("And/Prefix/text()"); - lrule.filter.and_operator.prefix = Prefix(text.node().value()); + text = filter.node().select_node("And/Prefix/text()"); + lrule.filter.and_operator.prefix = Prefix(text.node().value()); } if (filter.node().select_node("And/Tag")) { - auto tags = root.node().select_nodes("And/Tag"); - for (auto& tag : tags) { - (void)tag; - text = filter.node().select_node("Key/text()"); - std::string key = text.node().value(); + auto tags = root.node().select_nodes("And/Tag"); + for (auto& tag : tags) { + (void)tag; + text = filter.node().select_node("Key/text()"); + std::string key = text.node().value(); - text = filter.node().select_node("Value/text()"); - std::string value = text.node().value(); + text = filter.node().select_node("Value/text()"); + std::string value = text.node().value(); - lrule.filter.and_operator.tags[key] = value; - } + lrule.filter.and_operator.tags[key] = value; + } } } if (filter.node().select_node("Prefix")) { @@ -749,19 +749,19 @@ GetBucketLifecycleResponse GetBucketLifecycleResponse::ParseXML( if (rule.node().select_node("NoncurrentVersionExpiration")) { text = rule.node().select_node( - "NoncurrentVersionExpiration/NoncurrentDays/text()"); + "NoncurrentVersionExpiration/NoncurrentDays/text()"); value = text.node().value(); lrule.noncurrent_version_expiration_noncurrent_days = std::stoi(value); } if (rule.node().select_node("NoncurrentVersionTransition")) { text = rule.node().select_node( - "NoncurrentVersionTransition/NoncurrentDays/text()"); + "NoncurrentVersionTransition/NoncurrentDays/text()"); value = text.node().value(); lrule.noncurrent_version_transition_noncurrent_days = std::stoi(value); text = rule.node().select_node( - "NoncurrentVersionTransition/StorageClass/text()"); + "NoncurrentVersionTransition/StorageClass/text()"); lrule.noncurrent_version_transition_storage_class = text.node().value(); } @@ -771,15 +771,15 @@ GetBucketLifecycleResponse GetBucketLifecycleResponse::ParseXML( if (rule.node().select_node("Transition")) { if (rule.node().select_node("Transition/Date")) { - text = rule.node().select_node("Transition/Date/text()"); - lrule.transition_date = - utils::UtcTime::FromISO8601UTC(text.node().value()); + text = rule.node().select_node("Transition/Date/text()"); + lrule.transition_date = + utils::UtcTime::FromISO8601UTC(text.node().value()); } if (rule.node().select_node("Transition/Days")) { - text = rule.node().select_node("Transition/Days/text()"); - value = text.node().value(); - lrule.transition_days = std::stoi(value); + text = rule.node().select_node("Transition/Days/text()"); + value = text.node().value(); + lrule.transition_days = std::stoi(value); } text = rule.node().select_node("Transition/StorageClass/text()"); From d851e5052e36c0d279947d39d161db0035d81200 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Fri, 16 Jan 2026 18:46:14 -0800 Subject: [PATCH 04/25] feat: Add CRC64NVME checksum support for RDMA multipart uploads - Add checksum_crc64nvme field to UploadPartArgs, PutObjectArgs - Add checksum field to s3_rdma_client_ctx_t for RDMA context - Add x-amz-checksum-crc64nvme header in RDMA objectPut callback - Return checksum in PutObjectResponse and UploadPartResponse - Support checksum pass-through from Go to C++ RDMA layer --- include/miniocpp/args.h | 3 +++ include/miniocpp/nvidia-cuobjclient.h | 1 + include/miniocpp/rdma.h | 5 +++++ include/miniocpp/response.h | 2 ++ src/baseclient.cc | 3 +++ 5 files changed, 14 insertions(+) diff --git a/include/miniocpp/args.h b/include/miniocpp/args.h index 9f58b347..aafa03d4 100644 --- a/include/miniocpp/args.h +++ b/include/miniocpp/args.h @@ -163,6 +163,7 @@ struct PutObjectApiArgs : public PutObjectBaseArgs { http::ProgressFunction progressfunc = nullptr; void* progress_userdata = nullptr; cuObjClient* rdmaclient = nullptr; + std::string checksum_crc64nvme; // CRC64NVME checksum for multipart uploads PutObjectApiArgs() = default; ~PutObjectApiArgs() = default; @@ -177,6 +178,7 @@ struct UploadPartArgs : public ObjectWriteArgs { http::ProgressFunction progressfunc = nullptr; void* progress_userdata = nullptr; cuObjClient* rdmaclient = nullptr; + std::string checksum_crc64nvme; // CRC64NVME checksum for multipart uploads UploadPartArgs() = default; ~UploadPartArgs() = default; @@ -335,6 +337,7 @@ struct PutObjectArgs : public PutObjectBaseArgs { http::ProgressFunction progressfunc = nullptr; void* progress_userdata = nullptr; cuObjClient* rdmaclient = nullptr; + std::string checksum_crc64nvme; // CRC64NVME checksum for multipart uploads PutObjectArgs(std::istream& stream, long object_size, long part_size); ~PutObjectArgs() = default; diff --git a/include/miniocpp/nvidia-cuobjclient.h b/include/miniocpp/nvidia-cuobjclient.h index a7dc0a15..13a89bfd 100644 --- a/include/miniocpp/nvidia-cuobjclient.h +++ b/include/miniocpp/nvidia-cuobjclient.h @@ -255,6 +255,7 @@ typedef struct s3_rdma_client_ctx { minio::s3::BaseUrl url; std::string region; cuObjOpType_t op; + std::string checksum; // CRC64NVME checksum for multipart uploads } s3_rdma_client_ctx_t; #endif diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h index 1ce39eb5..861c4cf4 100644 --- a/include/miniocpp/rdma.h +++ b/include/miniocpp/rdma.h @@ -105,6 +105,11 @@ inline static ssize_t objectPut(const void* handle, const char* buf, sign_headers.Add("Content-Type", "application/octet-stream"); sign_headers.Add("Content-Length", "0"); + // Add CRC64NVME checksum for multipart uploads + if (!sctx->checksum.empty()) { + sign_headers.Add("x-amz-checksum-crc64nvme", sctx->checksum); + } + // Add session token if present if (!creds.session_token.empty()) { sign_headers.Add("X-Amz-Security-Token", creds.session_token); diff --git a/include/miniocpp/response.h b/include/miniocpp/response.h index 60d3b502..031af0e8 100644 --- a/include/miniocpp/response.h +++ b/include/miniocpp/response.h @@ -158,6 +158,7 @@ struct CompleteMultipartUploadResponse : public Response { std::string checksumCRC32C; std::string checksumSHA1; std::string checksumSHA256; + std::string checksum_crc64nvme; CompleteMultipartUploadResponse() = default; @@ -195,6 +196,7 @@ struct PutObjectResponse : public Response { std::string checksumCRC32C; std::string checksumSHA1; std::string checksumSHA256; + std::string checksum_crc64nvme; PutObjectResponse() = default; diff --git a/src/baseclient.cc b/src/baseclient.cc index 46ce92b0..b8b0ff69 100644 --- a/src/baseclient.cc +++ b/src/baseclient.cc @@ -1393,6 +1393,7 @@ PutObjectResponse BaseClient::PutObject(PutObjectApiArgs args) { PutObjectResponse resp; resp.etag = putCtx.etag; + resp.checksum_crc64nvme = putCtx.checksum; return resp; } @@ -1966,6 +1967,7 @@ UploadPartResponse BaseClient::UploadPart(UploadPartArgs args) { .url = base_url_, .region = region, .op = CUOBJ_PUT, + .checksum = args.checksum_crc64nvme, }; ssize_t ret = args.rdmaclient->cuObjPut(&putCtx, args.buf, args.part_size); @@ -1977,6 +1979,7 @@ UploadPartResponse BaseClient::UploadPart(UploadPartArgs args) { UploadPartResponse resp; resp.etag = putCtx.etag; + resp.checksum_crc64nvme = putCtx.checksum; return resp; } From 1e7dc9636c20bae38ce159b648dced411cde3dcd Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Sat, 17 Jan 2026 19:01:15 -0800 Subject: [PATCH 05/25] fix: Fall back to HTTP when RDMA buffer registration fails When cuMemObjGetDescriptor fails (e.g., buffer is regular heap memory instead of GPU/pinned memory), fall back to HTTP transfer instead of returning an error. This allows RDMA operations to gracefully degrade when the caller provides non-RDMA-capable buffers. Affected functions: - GetObject(GetObjectRDMAArgs): Falls back to HTTP on registration failure - PutObject(PutObjectRDMAArgs): Falls back to HTTP on registration failure --- src/client.cc | 69 ++++++++++++++++++++++++++++++--------------------- 1 file changed, 41 insertions(+), 28 deletions(-) diff --git a/src/client.cc b/src/client.cc index 4cc1af13..eb41afe6 100644 --- a/src/client.cc +++ b/src/client.cc @@ -397,13 +397,19 @@ GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { << (connected ? "true" : "false") << ", object=" << args.object << ", size=" << size << std::endl; + bool use_rdma = false; if (connected) { int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); if (res) { - return error::make( - "unable to register RDMA buffer for object " + args.object); + // Buffer registration failed (not GPU/pinned memory), fall back to HTTP + std::cerr << "[RDMA_DEBUG] GetObject: buffer registration failed for " + << args.object << ", falling back to HTTP" << std::endl; + } else { + use_rdma = true; } + } + if (use_rdma) { // get the buffer + get operation. s3_rdma_client_ctx getCtx = { .provider = provider_, @@ -420,19 +426,19 @@ GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { ssize_t ret = rdmaclient.cuObjGet(&getCtx, args.buf, size); if (ret < 0) { rdmaclient.cuMemObjPutDescriptor(args.buf); - return error::make("failed to download to object " + - args.object); - } - - res = rdmaclient.cuMemObjPutDescriptor(args.buf); - if (res) { - return error::make( - "unable to deregister RDMA buffer for object " + args.object); + // RDMA transfer failed, fall back to HTTP + std::cerr << "[RDMA_DEBUG] GetObject: RDMA transfer failed for " + << args.object << ", falling back to HTTP" << std::endl; + } else { + int res = rdmaclient.cuMemObjPutDescriptor(args.buf); + if (res) { + std::cerr << "[RDMA_DEBUG] GetObject: buffer deregistration failed for " + << args.object << std::endl; + } + GetObjectResponse resp; + resp.etag = getCtx.etag; + return resp; } - - GetObjectResponse resp; - resp.etag = getCtx.etag; - return resp; } GetObjectArgs targs; @@ -471,13 +477,19 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { << (connected ? "true" : "false") << ", object=" << args.object << ", size=" << size << std::endl; + bool use_rdma = false; if (connected) { int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); if (res) { - return error::make( - "unable to register RDMA buffer for object " + args.object); + // Buffer registration failed (not GPU/pinned memory), fall back to HTTP + std::cerr << "[RDMA_DEBUG] PutObject: buffer registration failed for " + << args.object << ", falling back to HTTP" << std::endl; + } else { + use_rdma = true; } + } + if (use_rdma) { // put the buffer + put operation. s3_rdma_client_ctx putCtx = { .provider = provider_, @@ -494,21 +506,22 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { ssize_t ret = rdmaclient.cuObjPut(&putCtx, args.buf, size); if (ret < 0) { rdmaclient.cuMemObjPutDescriptor(args.buf); - return error::make("failed to upload to object " + - args.object); - } - - res = rdmaclient.cuMemObjPutDescriptor(args.buf); - if (res) { - return error::make( - "unable to deregister RDMA buffer for object " + args.object); + // RDMA transfer failed, fall back to HTTP + std::cerr << "[RDMA_DEBUG] PutObject: RDMA transfer failed for " + << args.object << ", falling back to HTTP" << std::endl; + } else { + int res = rdmaclient.cuMemObjPutDescriptor(args.buf); + if (res) { + std::cerr << "[RDMA_DEBUG] PutObject: buffer deregistration failed for " + << args.object << std::endl; + } + PutObjectResponse resp; + resp.etag = putCtx.etag; + return resp; } - - PutObjectResponse resp; - resp.etag = putCtx.etag; - return resp; } + // HTTP fallback path std::stringstream ss(std::ios_base::in | std::ios_base::out); ss.rdbuf()->pubsetbuf(args.buf, size); From 2fdb4ccbeb7af1de0a468bd2fcbe0784c46c9776 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Tue, 31 Mar 2026 13:54:20 -0700 Subject: [PATCH 06/25] feat: Switch RDMA to direct token API, update cuObj bindings to resiliency_v2 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Replace callback-based RDMA flow (objectPut/objectGet) with direct token acquisition via cuMemObjGetRDMAToken/cuMemObjPutRDMAToken. This removes the callback indirection and gives the application full control over the S3 control-path HTTP request. - nvidia-cuobjclient.h: Add cuMemObjGetRDMAToken, cuMemObjPutRDMAToken, shutdownTelemetry, and telemetry classes (cuObjTelem, cuObjSpan, cuObjTelem_ostream) - nvidia-cufile.h: Update to upstream v1.17.0 — new error codes (37-50), P2P flags, async stream APIs, scatter/gather IO, version/topology APIs - rdma.h: Replace objectPut/objectGet callbacks with rdmaPut/rdmaGet functions that accept a token string directly - client.cc/baseclient.cc: Use token-based RDMA path with HTTP fallback when token acquisition fails or server declines RDMA --- include/miniocpp/nvidia-cufile.h | 554 +++++++++----------------- include/miniocpp/nvidia-cuobjclient.h | 77 +++- include/miniocpp/rdma.h | 93 ++--- src/baseclient.cc | 100 ++--- src/client.cc | 118 +++--- 5 files changed, 389 insertions(+), 553 deletions(-) diff --git a/include/miniocpp/nvidia-cufile.h b/include/miniocpp/nvidia-cufile.h index c33ad949..845f94cc 100644 --- a/include/miniocpp/nvidia-cufile.h +++ b/include/miniocpp/nvidia-cufile.h @@ -1,5 +1,5 @@ /* - * Copyright 1993-2020 NVIDIA Corporation. All rights reserved. + * Copyright 1993-2023 NVIDIA Corporation. All rights reserved. * * NOTICE TO LICENSEE: * @@ -75,83 +75,110 @@ extern "C" { // Note :Data path errors are captured via standard error codes #define CUFILEOP_STATUS_ENTRIES \ CUFILE_OP(0, CU_FILE_SUCCESS, cufile success) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 1, CU_FILE_DRIVER_NOT_INITIALIZED, \ - nvidia - fs driver is not loaded) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 2, CU_FILE_DRIVER_INVALID_PROPS, \ - invalid property) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 3, CU_FILE_DRIVER_UNSUPPORTED_LIMIT, \ - property range error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 4, CU_FILE_DRIVER_VERSION_MISMATCH, \ - nvidia - fs driver version mismatch) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 5, CU_FILE_DRIVER_VERSION_READ_ERROR, \ - nvidia - fs driver version read error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 6, CU_FILE_DRIVER_CLOSING, \ - driver shutdown in progress) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 7, CU_FILE_PLATFORM_NOT_SUPPORTED, \ - GPUDirect Storage not supported on current platform) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 8, CU_FILE_IO_NOT_SUPPORTED, \ - GPUDirect Storage not supported on current file) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 9, CU_FILE_DEVICE_NOT_SUPPORTED, \ - GPUDirect Storage not supported on current GPU) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 10, CU_FILE_NVFS_DRIVER_ERROR, \ - nvidia - fs driver ioctl error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 11, CU_FILE_CUDA_DRIVER_ERROR, \ - CUDA Driver API error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 12, CU_FILE_CUDA_POINTER_INVALID, \ - invalid device pointer) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 13, CU_FILE_CUDA_MEMORY_TYPE_INVALID, \ - invalid pointer memory type) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 14, CU_FILE_CUDA_POINTER_RANGE_ERROR, \ - pointer range exceeds allocated address range) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 15, CU_FILE_CUDA_CONTEXT_MISMATCH, \ - cuda context mismatch) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 16, CU_FILE_INVALID_MAPPING_SIZE, \ - access beyond maximum pinned size) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 17, CU_FILE_INVALID_MAPPING_RANGE, \ - access beyond mapped size) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 18, CU_FILE_INVALID_FILE_TYPE, \ - unsupported file type) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 19, CU_FILE_INVALID_FILE_OPEN_FLAG, \ - unsupported file open flags) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 20, CU_FILE_DIO_NOT_SET, fd direct IO not set) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 22, CU_FILE_INVALID_VALUE, invalid arguments) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 23, CU_FILE_MEMORY_ALREADY_REGISTERED, \ - device pointer already registered) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 24, CU_FILE_MEMORY_NOT_REGISTERED, \ - device pointer lookup failure) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 25, CU_FILE_PERMISSION_DENIED, \ - driver or file access error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 26, CU_FILE_DRIVER_ALREADY_OPEN, \ - driver is already open) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 27, CU_FILE_HANDLE_NOT_REGISTERED, \ - file descriptor is not registered) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 28, CU_FILE_HANDLE_ALREADY_REGISTERED, \ - file descriptor is already registered) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 29, CU_FILE_DEVICE_NOT_FOUND, \ - GPU device not found) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 30, CU_FILE_INTERNAL_ERROR, internal error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 31, CU_FILE_GETNEWFD_FAILED, \ - failed to obtain new file descriptor) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 33, CU_FILE_NVFS_SETUP_ERROR, \ - NVFS driver initialization error) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 34, CU_FILE_IO_DISABLED, \ - GPUDirect Storage disabled by config on current file) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 35, CU_FILE_BATCH_SUBMIT_FAILED, \ - failes to submit batch operation) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 36, CU_FILE_GPU_MEMORY_PINNING_FAILED, \ - Failed to allocate pinned GPU Memory) \ - CUFILE_OP(CUFILEOP_BASE_ERR + 37, CU_FILE_IO_MAX_ERROR, \ + CUFILE_OP(CUFILEOP_BASE_ERR + 1, CU_FILE_DRIVER_NOT_INITIALIZED, \ + nvidia - fs driver is not loaded.Set allow_compat_mode to true in \ + cufile.json file to enable compatible mode) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 2, CU_FILE_DRIVER_INVALID_PROPS, \ + invalid property) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 3, CU_FILE_DRIVER_UNSUPPORTED_LIMIT, \ + property range error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 4, CU_FILE_DRIVER_VERSION_MISMATCH, \ + nvidia - fs driver version mismatch) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 5, CU_FILE_DRIVER_VERSION_READ_ERROR, \ + nvidia - fs driver version read error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 6, CU_FILE_DRIVER_CLOSING, \ + driver shutdown in progress) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 7, CU_FILE_PLATFORM_NOT_SUPPORTED, \ + GPUDirect Storage not supported on current platform) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 8, CU_FILE_IO_NOT_SUPPORTED, \ + GPUDirect Storage not supported on current file) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 9, CU_FILE_DEVICE_NOT_SUPPORTED, \ + GPUDirect Storage not supported on current GPU) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 10, CU_FILE_NVFS_DRIVER_ERROR, \ + nvidia - fs driver ioctl error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 11, CU_FILE_CUDA_DRIVER_ERROR, \ + CUDA Driver API error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 12, CU_FILE_CUDA_POINTER_INVALID, \ + invalid device pointer) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 13, CU_FILE_CUDA_MEMORY_TYPE_INVALID, \ + invalid pointer memory type) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 14, CU_FILE_CUDA_POINTER_RANGE_ERROR, \ + pointer range exceeds allocated address range) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 15, CU_FILE_CUDA_CONTEXT_MISMATCH, \ + cuda context mismatch) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 16, CU_FILE_INVALID_MAPPING_SIZE, \ + access beyond maximum pinned size) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 17, CU_FILE_INVALID_MAPPING_RANGE, \ + access beyond mapped size) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 18, CU_FILE_INVALID_FILE_TYPE, \ + unsupported file type) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 19, CU_FILE_INVALID_FILE_OPEN_FLAG, \ + unsupported file open flags) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 20, CU_FILE_DIO_NOT_SET, \ + fd direct IO not set) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 22, CU_FILE_INVALID_VALUE, \ + invalid arguments) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 23, CU_FILE_MEMORY_ALREADY_REGISTERED, \ + device pointer already registered) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 24, CU_FILE_MEMORY_NOT_REGISTERED, \ + device pointer lookup failure) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 25, CU_FILE_PERMISSION_DENIED, \ + driver or file access error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 26, CU_FILE_DRIVER_ALREADY_OPEN, \ + driver is already open) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 27, CU_FILE_HANDLE_NOT_REGISTERED, \ + file descriptor is not registered) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 28, CU_FILE_HANDLE_ALREADY_REGISTERED, \ + file descriptor is already registered) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 29, CU_FILE_DEVICE_NOT_FOUND, \ + GPU device not found) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 30, CU_FILE_INTERNAL_ERROR, internal error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 31, CU_FILE_GETNEWFD_FAILED, \ + failed to obtain new file descriptor) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 33, CU_FILE_NVFS_SETUP_ERROR, \ + NVFS driver initialization error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 34, CU_FILE_IO_DISABLED, \ + GPUDirect Storage disabled by config on current file) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 35, CU_FILE_BATCH_SUBMIT_FAILED, \ + failed to submit batch operation) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 36, CU_FILE_GPU_MEMORY_PINNING_FAILED, \ + Failed to allocate pinned GPU Memory) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 37, CU_FILE_BATCH_FULL, \ + queue full for batch operation) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 38, CU_FILE_ASYNC_NOT_SUPPORTED, \ + cuFile stream operation not supported) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 39, \ + CU_FILE_INTERNAL_BATCH_SETUP_ERROR, \ + batch setup internal error - retry later) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 40, \ + CU_FILE_INTERNAL_BATCH_SUBMIT_ERROR, \ + batch submit internal error - retry later) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 41, \ + CU_FILE_INTERNAL_BATCH_GETSTATUS_ERROR, \ + batch get status internal error - retry later) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 42, \ + CU_FILE_INTERNAL_BATCH_CANCEL_ERROR, \ + batch cancel internal error - retry later) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 43, CU_FILE_NOMEM_ERROR, \ + cufile no memory error - retry later) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 44, CU_FILE_IO_ERROR, cufile io error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 45, \ + CU_FILE_INTERNAL_BUF_REGISTER_ERROR, \ + cufile buf registration error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 46, CU_FILE_HASH_OPR_ERROR, \ + cufile hash operation error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 47, CU_FILE_INVALID_CONTEXT_ERROR, \ + cufile invalid context error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 48, \ + CU_FILE_NVFS_INTERNAL_DRIVER_ERROR, \ + nvfs internal driver error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 49, CU_FILE_BATCH_NOCOMPAT_ERROR, \ + compat mode off error) \ + CUFILE_OP(CUFILEOP_BASE_ERR + 50, CU_FILE_IO_MAX_ERROR, \ GPUDirect Storage Max Error) /** * @brief cufileop status enum - * - * @note on success the error code is set to @ref CU_FILE_SUCCESS. - * @note The error code can be inspected using @ref IS_CUFILE_ERR and @ref - * CUFILE_ERRSTR. - * @note The error code if set to @ref CU_FILE_CUDA_DRIVER_ERROR, then cuda - * error can be inspected using @ref IS_CUDA_ERR and @ref CU_FILE_CUDA_ERR. - * @note Data path errors are captured via standard error codes */ typedef enum CUfileOpError { /// @cond DOXYGEN_SKIP_MACRO @@ -204,44 +231,51 @@ typedef struct CUfileError { /* driver properties */ typedef enum CUfileDriverStatusFlags { - CU_FILE_LUSTRE_SUPPORTED = 0, /*!< Support for DDN LUSTRE */ - - CU_FILE_WEKAFS_SUPPORTED = 1, /*!< Support for WEKAFS */ - - CU_FILE_NFS_SUPPORTED = 2, /*!< Support for NFS */ - - CU_FILE_GPFS_SUPPORTED = 3, /*! < Support for GPFS */ - - CU_FILE_NVME_SUPPORTED = 4, /*!< Support for NVMe */ - - CU_FILE_NVMEOF_SUPPORTED = 5, /*!< Support for NVMeOF */ - - CU_FILE_SCSI_SUPPORTED = 6, /*!< Support for SCSI */ - - CU_FILE_SCALEFLUX_CSD_SUPPORTED = 7, /*!< Support for Scaleflux CSD*/ - - CU_FILE_NVMESH_SUPPORTED = 8, /*!< Support for NVMesh Block Dev*/ - CU_FILE_BEEGFS_SUPPORTED = 9, /*!< Support for BeeGFS */ - + CU_FILE_LUSTRE_SUPPORTED = 0, /*!< Support for DDN LUSTRE */ + CU_FILE_WEKAFS_SUPPORTED = 1, /*!< Support for WEKAFS */ + CU_FILE_NFS_SUPPORTED = 2, /*!< Support for NFS */ + CU_FILE_GPFS_SUPPORTED = 3, /*!< Support for GPFS */ + CU_FILE_NVME_SUPPORTED = 4, /*!< Support for NVMe */ + CU_FILE_NVMEOF_SUPPORTED = 5, /*!< Support for NVMeOF */ + CU_FILE_SCSI_SUPPORTED = 6, /*!< Support for SCSI */ + CU_FILE_SCALEFLUX_CSD_SUPPORTED = 7, /*!< Support for Scaleflux CSD */ + CU_FILE_NVMESH_SUPPORTED = 8, /*!< Support for NVMesh Block Dev */ + CU_FILE_BEEGFS_SUPPORTED = 9, /*!< Support for BeeGFS */ + // 10 is reserved for YRCloudFile + CU_FILE_NVME_P2P_SUPPORTED = 11, /*!< Deprecated */ + CU_FILE_SCATEFS_SUPPORTED = 12, /*!< Support for ScateFS */ + CU_FILE_VIRTIOFS_SUPPORTED = 13, /*!< Support for VirtioFS */ + CU_FILE_MAX_TARGET_TYPES, /*!< Maximum FS supported */ } CUfileDriverStatusFlags_t; typedef enum CUfileDriverControlFlags { - CU_FILE_USE_POLL_MODE = 0, /*!< use POLL mode. properties.use_poll_mode*/ - - CU_FILE_ALLOW_COMPAT_MODE = - 1 /*!< allow COMPATIBILITY mode. properties.allow_compat_mode*/ - + CU_FILE_USE_POLL_MODE = 0, /*!< use POLL mode */ + CU_FILE_ALLOW_COMPAT_MODE = 1, /*!< allow COMPATIBILITY mode */ + CU_FILE_POSIX_IO_MODE = 2, /*!< Vanilla posix io mode */ + CU_FILE_FALLBACK_IO_MODE = 4 /*!< Fallback io mode */ } CUfileDriverControlFlags_t; typedef enum CUfileFeatureFlags { - CU_FILE_DYN_ROUTING_SUPPORTED = 0, /*!< Support for Dynamic routing to handle - devices across the PCIe bridges */ - - CU_FILE_BATCH_IO_SUPPORTED = 1, /*!< Unsupported */ + CU_FILE_DYN_ROUTING_SUPPORTED = 0, /*!< Dynamic routing support */ + CU_FILE_BATCH_IO_SUPPORTED = 1, /*!< Batch IO support */ + CU_FILE_STREAMS_SUPPORTED = 2, /*!< Streams support */ + CU_FILE_PARALLEL_IO_SUPPORTED = 3, /*!< Parallel IO support */ + CU_FILE_P2P_SUPPORTED = 4 /*!< PCI P2PDMA support */ +} CUfileFeatureFlags_t; - CU_FILE_STREAMS_SUPPORTED = 2 /*!< Unsupported */ +typedef enum CUfileP2PFlags { + CUFILE_P2PDMA = 0, /*!< Support for PCI P2PDMA */ + CUFILE_NVFS = 1, /*!< Support for nvidia-fs */ + CUFILE_DMABUF = 2, /*!< Support for DMA Buffer */ + CUFILE_C2C = 3, /*!< Support for Chip-to-Chip (Grace) */ + CUFILE_NVIDIA_PEERMEM = 4 /*!< Only for IBM Spectrum Scale and WekaFS */ +} CUfileP2PFlags_t; -} CUfileFeatureFlags_t; +/* P2P Flag constants */ +#define CU_FILE_P2P_FLAG_PCI_P2PDMA ((CUfileP2PFlags_t)(1 << CUFILE_P2PDMA)) +#define CU_FILE_P2P_FLAG_NVFS ((CUfileP2PFlags_t)(1 << CUFILE_NVFS)) +#define CU_FILE_P2P_FLAG_DMABUF ((CUfileP2PFlags_t)(1 << CUFILE_DMABUF)) +#define CU_FILE_P2P_FLAG_C2C ((CUfileP2PFlags_t)(1 << CUFILE_C2C)) typedef struct CUfileDrvProps { struct { @@ -321,299 +355,44 @@ typedef struct CUfileDescr_t { /** * @brief File handle type - * */ typedef void *CUfileHandle_t; #pragma GCC visibility push(default) -/** - * @brief cuFileHandleRegister is required, and performs extra checking that is - * memoized to provide increased performance on later cuFile operations. - * - * @param fh @ref CUfileHandle_t opaque file handle for IO operations - * @param descr @ref CUfileDescr_t file descriptor (OS agnostic) - * - * @return CU_FILE_SUCCESS on successful completion. fh will be updated for - * use in @ref cuFileRead, @ref cuFileWrite, @ref cuFileHandleDeregister - * @return CU_FILE_DRIVER_NOT_INITIALIZED on failure to load driver - * @return CU_FILE_IO_NOT_SUPPORTED - if filesystem is not supported - * @return CU_FILE_INVALID_VALUE if null or bad api arguments - * @return CU_FILE_INVALID_FILE_OPEN_FLAG if file is opened with - * unsupported modes like no O_DIRECT - * @return CU_FILE_INVALID_FILE_TYPE if filepath is not valid or is not a - * regular file - * @return CU_FILE_HANDLE_ALREADY_REGISTERED if file handle/descriptor is - * already registered - * - * Description - * cuFileHandleRegister registers the open file descriptor for use with cuFile - * IO operations. - * - * This API will ensure that the file’s descriptor is checked for GPUDirect - * Storage support and returns a valid file handle on CU_FILE_SUCCESS. - * - * @note the file needs to be opened in O_DIRECT mode to support GPUDirect - * Storage. - * - * @see cuFileRead - * @see cuFileWrite - * @see cuFileHandleDeregister - * - */ CUfileError_t cuFileHandleRegister(CUfileHandle_t *fh, CUfileDescr_t *descr); - -/** - * @brief releases a registered filehandle from cuFile - * - * @param fh @ref CUfileHandle_t file handle - * - * @return void - * - * @see cuFileHandleRegister - */ void cuFileHandleDeregister(CUfileHandle_t fh); - -/** - * @brief register an existing cudaMalloced memory with cuFile to pin for - * GPUDirect Storage access. - * - * @param devPtr_base device pointer to allocated - * @param length size of memory region from the above specified devPtr - * @param flags CU_FILE_RDMA_REGISTER - * - * @return CU_FILE_SUCCESS on success - * @return CU_FILE_NVFS_DRIVER_ERROR - * @return CU_FILE_INVALID_VALUE - * @return CU_FILE_CUDA_ERROR for unsuported memory type - * @return CU_FILE_MEMORY_ALREADY_REGISTERED on error - * @return CU_FILE_GPU_MEMORY_PINNING_FAILED if not enough pinned memory is - * available - * @note This memory will be use to perform GPU direct DMA from the supported - * storage. - * @warning This API is intended for usecases where the memory is used as - * streaming buffer that is reused across multiple cuFile IO operations before - * calling @ref cuFileBufDeregister - * - * @see cuFileBufDeregister - * @see cuFileRead - * @see cuFileWrite - */ -CUfileError_t cuFileBufRegister(const void *devPtr_base, size_t length, +CUfileError_t cuFileBufRegister(const void *bufPtr_base, size_t length, int flags); - -/** - * @brief deregister an already registered device memory from cuFile - * - * @param devPtr_base device pointer to deregister - * - * @return CU_FILE_SUCCESS on success - * @return CU_FILE_INVALID_VALUE on invalid memory pointer or unregistered - * memory pointer - * - * @see cuFileBufRegister - * @see cuFileRead - * @see cuFileWrite - */ - -CUfileError_t cuFileBufDeregister(const void *devPtr_base); - -/** - * @brief read data from a registered file handle to a specified device memory - * - * @param fh @ref CUfileHandle_t opaque file handle - * @param devPtr_base base address of buffer in device memory - * @param size size bytes to read - * @param file_offset file-offset from begining of the file - * @param devPtr_offset offset relative to the devPtr_base pointer to read - * into. - * - * @return size of bytes successfully read - * @return -1 on error, in which case errno is set to indicate filesystem - * errors. - * @return all other errors will return a negative integer value of @ref - * CUfileOpError enum value. - * - * @note If the devPtr is not registered with @ref cuFileBufRegister, the data - * will be buffered through preallocated pinned buffers. - * @note This is useful for applications that need to perform IO to unaligned - * file offsets and/or size. This is also recommended for cases where the BAR1 - * memory size is smaller than the size of the allocated memory. - * - * @see cuFileBufRegister - * @see cuFileHandleRegister - * @see cuFileWrite - */ - -ssize_t cuFileRead(CUfileHandle_t fh, void *devPtr_base, size_t size, - off_t file_offset, off_t devPtr_offset); - -/** - * @brief write data from a specified device memory to a registered file handle - * - * @param fh @ref CUfileHandle_t opaque file handle - * @param devPtr_base base address of buffer in device memory - * @param size size bytes to write - * @param file_offset file-offset from begining of the file - * @param devPtr_offset offset relative to the devPtr_base pointer to read - * into. - * - * @return size of bytes successfully written - * @return -1 on error, in which case errno is set to indicate filesystem - * errors. - * @return all other errors will return a negative integer value of @ref - * CUfileOpError enum value. - * - * @note If the devPtr is not registered with @ref cuFileBufRegister, the data - * will be buffered through preallocated pinned buffers. - * @note This is useful for applications that need to perform IO to unaligned - * file offsets and/or size. This is also recommended for cases where the BAR1 - * memory size is smaller than the size of the allocated memory. - * - * @see cuFileBufRegister - * @see cuFileHandleRegister - * @see cuFileRead - */ - -ssize_t cuFileWrite(CUfileHandle_t fh, const void *devPtr_base, size_t size, - off_t file_offset, off_t devPtr_offset); +CUfileError_t cuFileBufDeregister(const void *bufPtr_base); +ssize_t cuFileRead(CUfileHandle_t fh, void *bufPtr_base, size_t size, + off_t file_offset, off_t bufPtr_offset); +ssize_t cuFileWrite(CUfileHandle_t fh, const void *bufPtr_base, size_t size, + off_t file_offset, off_t bufPtr_offset); // CUFile Driver APIs - -/** - * @brief - * Initialize the cuFile library and open the nvidia-fs driver - * - * @return CU_FILE_SUCCESS on success - * @return CU_FILE_DRIVER_NOT_INITIALIZED - * @return CU_FILE_DRIVER_VERSION_MISMATCH on driver version mismatch error - * - * @see cuFileDriverClose - */ CUfileError_t cuFileDriverOpen(void); CUfileError_t cuFileDriverClose(void); #define cuFileDriverClose cuFileDriverClose_v2 -/** - * @brief - * reset the cuFile library and release the nvidia-fs driver - * - * @return CU_FILE_SUCCESS on success - * @return CU_FILE_DRIVER_CLOSING if there are any active IO operations using - * @ref cuFileRead or @ref cuFileWrite - * - * @see cuFileDriverOpen - */ CUfileError_t cuFileDriverClose(void); -/** - * @brief - * returns use count of cufile drivers at that moment by the process. - */ long cuFileUseCount(void); - -/** - * @brief - * Gets the Driver session properties - * - * @return CU_FILE_SUCCESS on success - * - * @see cuFileDriverSetPollMode - * @see cuFileDriverSetMaxDirectIOSize - * @see cuFileDriverSetMaxCacheSize - * @see cuFileDriverSetMaxPinnedMemSize - */ CUfileError_t cuFileDriverGetProperties(CUfileDrvProps_t *props); - -/** - * @brief - * Sets whether the Read/Write APIs use polling to do IO operations - * - * @param poll boolean to indicate whether to use poll mode or not - * @param poll_threshold_size max IO size to use for POLLING mode in KB - * - * @return CU_FILE_SUCCESS on success - * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized - * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on - * error - * - * @warning This is an advanced command and should be tuned based on available - * system memory - * - * @see cuFileDriverGetProperties - */ CUfileError_t cuFileDriverSetPollMode(bool poll, size_t poll_threshold_size); - -/** - * @brief - * Control parameter to set max IO size(KB) used by the library to talk to - * nvidia-fs driver - * - * @param max_direct_io_size maximum allowed direct io size in KB - * - * @return CU_FILE_SUCCESS on success - * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized - * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on - * error - * - * @warning This is an advanced command and should be tuned based on available - * system memory - * - * @see cuFileDriverGetProperties - * - */ CUfileError_t cuFileDriverSetMaxDirectIOSize(size_t max_direct_io_size); - -/** - * @brief - * Control parameter to set maximum GPU memory reserved per device by the - * library for internal buffering - * - * @param max_cache_size The maximum GPU buffer space per device used for - * internal use in KB - * - * @return CU_FILE_SUCCESS on success - * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized - * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on - * error - * - * @warning This is an advanced command and should be tuned based on supported - * GPU memory - * - * @see cuFileDriverGetProperties - */ CUfileError_t cuFileDriverSetMaxCacheSize(size_t max_cache_size); - -/** - * @brief - * Sets maximum buffer space that is pinned in KB for use by @ref - * cuFileBufRegister - * - * @param max_pinned_size maximum buffer space that is pinned in KB - * - * @return CU_FILE_SUCCESS on success - * @return CU_FILE_DRIVER_NOT_INITIALIZED if the driver is not initialized - * @return CU_FILE_DRIVER_VERSION_MISMATCH, CU_FILE_DRIVER_UNSUPPORTED_LIMIT on - * error - * - * @warning This is an advanced command and should be tuned based on supported - * GPU memory - * - * @see cuFileDriverGetProperties - * - */ CUfileError_t cuFileDriverSetMaxPinnedMemSize(size_t max_pinned_size); -// Experimental Batch API's +// Batch API's typedef enum CUfileOpcode { CUFILE_READ = 0, CUFILE_WRITE } CUfileOpcode_t; typedef enum CUFILEStatus_enum { - CUFILE_WAITING = 0x000001, /* required value prior to submission */ - CUFILE_PENDING = 0x000002, /* once enqueued */ - CUFILE_INVALID = - 0x000004, /* request was ill-formed or could not be enqueued */ - CUFILE_CANCELED = 0x000008, /* request successfully canceled */ + CUFILE_WAITING = 0x000001, /* required value prior to submission */ + CUFILE_PENDING = 0x000002, /* once enqueued */ + CUFILE_INVALID = 0x000004, /* ill-formed or could not be enqueued */ + CUFILE_CANCELED = 0x000008, /* request successfully canceled */ CUFILE_COMPLETE = 0x0000010, /* request successfully completed */ CUFILE_TIMEOUT = 0x0000020, /* request timed out */ CUFILE_FAILED = 0x0000040 /* unable to complete */ @@ -656,6 +435,41 @@ CUfileError_t cuFileBatchIOGetStatus(CUfileBatchHandle_t batch_idp, CUfileError_t cuFileBatchIOCancel(CUfileBatchHandle_t batch_idp); void cuFileBatchIODestroy(CUfileBatchHandle_t batch_idp); +// Async API's with CUDA streams + +#define CU_FILE_STREAM_FIXED_BUF_OFFSET 1 +#define CU_FILE_STREAM_FIXED_FILE_OFFSET 2 +#define CU_FILE_STREAM_FIXED_FILE_SIZE 4 +#define CU_FILE_STREAM_PAGE_ALIGNED_INPUTS 8 + +CUfileError_t cuFileReadAsync(CUfileHandle_t fh, void *bufPtr_base, + size_t *size_p, off_t *file_offset_p, + off_t *bufPtr_offset_p, ssize_t *bytes_read_p, + CUstream stream); +CUfileError_t cuFileWriteAsync(CUfileHandle_t fh, void *bufPtr_base, + size_t *size_p, off_t *file_offset_p, + off_t *bufPtr_offset_p, ssize_t *bytes_written_p, + CUstream stream); +CUfileError_t cuFileStreamRegister(CUstream stream, unsigned flags); +CUfileError_t cuFileStreamDeregister(CUstream stream); + +// Scatter/gather IO + +typedef struct CUfileIOVec { + void *base; // Pointer to data (device or host memory) + size_t len; // Length of data +} CUfileIOVec_t; + +ssize_t cuFileReadv(CUfileHandle_t fh, const CUfileIOVec_t *iov, + size_t iovcnt, off_t file_offset, unsigned flags); +ssize_t cuFileWritev(CUfileHandle_t fh, const CUfileIOVec_t *iov, + size_t iovcnt, off_t file_offset, unsigned flags); + +// Version and topology + +CUfileError_t cuFileGetVersion(int *version); +CUfileError_t cuFileExportPCIeTopology(const char *filename); + #pragma GCC visibility pop /// @cond DOXYGEN_SKIP_MACRO diff --git a/include/miniocpp/nvidia-cuobjclient.h b/include/miniocpp/nvidia-cuobjclient.h index 13a89bfd..1aa5a35d 100644 --- a/include/miniocpp/nvidia-cuobjclient.h +++ b/include/miniocpp/nvidia-cuobjclient.h @@ -17,7 +17,10 @@ #include #include +#include +#include #include +#include #include "nvidia-cufile.h" #include "providers.h" @@ -214,11 +217,36 @@ class cuObjClient { * @brief check if the client is connected */ bool isConnected(void); + /** + * @brief Acquire an RDMA token for the registered memory + * @param ptr start address of registered user memory + * @param size size of the transfer + * @param offset offset within the buffer + * @param op operation type (CUOBJ_GET or CUOBJ_PUT) + * @param token output pointer to the token string (caller must release with + * cuMemObjPutRDMAToken) + * @return CU_OBJ_SUCCESS on success, CU_OBJ_FAIL on failure + */ + cuObjErr_t cuMemObjGetRDMAToken(void *ptr, size_t size, size_t offset, + cuObjOpType_t op, char **token); + + /** + * @brief Release an RDMA token acquired by cuMemObjGetRDMAToken + * @param token the token string to release + * @return CU_OBJ_SUCCESS on success, CU_OBJ_FAIL on failure + */ + cuObjErr_t cuMemObjPutRDMAToken(char *token); + /** * @brief setup telemetry output stream */ static void setupTelemetry(bool use_OTEL, std::ostream *os); + /** + * @brief shutdown telemetry + */ + static void shutdownTelemetry(); + /** * @brief setup telemetry stream logging level */ @@ -245,17 +273,60 @@ class cuObjClient { static bool _useOTEL; }; +/** + * @brief Abstract base class for cuObject telemetry + */ +class cuObjTelem { + public: + virtual ~cuObjTelem() = default; +}; + +/** + * @brief Telemetry span for tracing cuObject operations + */ +class cuObjSpan { + public: + cuObjSpan(std::string name, std::ostream &os); + ~cuObjSpan(); + + private: + std::string _name; + std::ostream &_os; +}; + +/** + * @brief ostream-based telemetry implementation for cuObject + */ +class cuObjTelem_ostream : public cuObjTelem { + public: + cuObjTelem_ostream(std::ostream &os); + ~cuObjTelem_ostream() override; + + cuObjSpan getSpan(std::string name); + void incPutCounter(int count); + void incGetCounter(int count); + void logError(const char *fmt, ...); + void logDebug(const char *fmt, ...); + void logInfo(const char *fmt, ...); + + private: + std::ostream &_os; +}; + +std::shared_ptr getSpan(std::shared_ptr &telem, + std::string name); + typedef struct s3_rdma_client_ctx { minio::creds::Provider *const provider = nullptr; std::string bucket; std::string object; std::string uploadId; - size_t partNumber; + size_t partNumber = 0; std::string etag; minio::s3::BaseUrl url; std::string region; - cuObjOpType_t op; - std::string checksum; // CRC64NVME checksum for multipart uploads + cuObjOpType_t op = CUOBJ_INVALID; + std::string checksum; } s3_rdma_client_ctx_t; #endif diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h index 861c4cf4..ff15e3d6 100644 --- a/include/miniocpp/rdma.h +++ b/include/miniocpp/rdma.h @@ -26,10 +26,6 @@ #include "signer.h" #include "utils.h" -#define IO_DESC_STR \ - "0102030405060708:01020304:01020304:0102:010203:1:" \ - "0102030405060708090a0b0c0d0e0f10:0102030405060708:0102030405060708" - // SHA256 hash of empty string (for RDMA requests with no body) inline constexpr const char* kEmptySha256 = "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855"; @@ -47,33 +43,18 @@ inline constexpr int kRDMAReplyNoContent = 204; inline constexpr int kRDMAReplyPartialContent = 206; inline constexpr int kRDMAReplyNotImplemented = 501; -// These functions are invoked by cufile rdma layer either user shadow pages or -// direct gpu va address depending on whether nvidia-fs driver or nv peer mem is -// present -inline static ssize_t objectPut(const void* handle, const char* buf, - size_t size, [[maybe_unused]] loff_t offset, - const cufileRDMAInfo_t* infop) { - void* ctx = cuObjClient::getCtx(handle); - s3_rdma_client_ctx_t* sctx = static_cast(ctx); - char io_str[sizeof IO_DESC_STR]; - unsigned io_len = sizeof io_str; - - if (infop == nullptr) { - std::cerr << "obtained NULL descr" << std::endl; - return -1; - } - - const std::string descr = std::string(infop->desc_str, infop->desc_len); - snprintf(io_str, io_len, "%s:%016lx:%016lx;", infop->desc_str, (uint64_t)buf, - (uint64_t)size); +// Return codes for rdmaPut/rdmaGet +inline constexpr ssize_t kRDMANotSupported = -2; +inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, + size_t size) { minio::utils::UtcTime date = minio::utils::UtcTime::Now(); minio::creds::Credentials creds = sctx->provider->Fetch(); minio::utils::Multimap query_params; minio::http::Url url; const std::string& region = sctx->region; - if (sctx->uploadId != "") { + if (!sctx->uploadId.empty()) { query_params.Add("uploadId", sctx->uploadId); if (sctx->partNumber == 0) { std::cerr << "partNumber cannot be zero" << std::endl; @@ -89,38 +70,32 @@ inline static ssize_t objectPut(const void* handle, const char* buf, if (minio::error::Error err = sctx->url.BuildUrl(url, minio::http::Method::kPut, region, query_params, sctx->bucket, sctx->object)) { - std::cerr << "failed to build url. error=" << err - << ". This should not happen" << std::endl; + std::cerr << "failed to build url. error=" << err << std::endl; return -1; } std::string host = url.HostHeaderValue(); - // Build headers for SignV4S3 minio::utils::Multimap sign_headers; sign_headers.Add("Host", host); sign_headers.Add("x-amz-date", date.ToAmzDate()); sign_headers.Add("x-amz-content-sha256", kUnsignedPayload); - sign_headers.Add(kAmzRDMAToken, io_str); + sign_headers.Add(kAmzRDMAToken, token); sign_headers.Add("Content-Type", "application/octet-stream"); sign_headers.Add("Content-Length", "0"); - // Add CRC64NVME checksum for multipart uploads if (!sctx->checksum.empty()) { sign_headers.Add("x-amz-checksum-crc64nvme", sctx->checksum); } - // Add session token if present if (!creds.session_token.empty()) { sign_headers.Add("X-Amz-Security-Token", creds.session_token); } - // Sign the request with SignV4S3 (adds Authorization header) minio::signer::SignV4S3(minio::http::Method::kPut, url.path, region, sign_headers, query_params, creds.access_key, creds.secret_key, kUnsignedPayload, date); - // Convert Multimap to httplib::Headers httplib::Headers headers; std::list keys = sign_headers.Keys(); for (const auto& key : keys) { @@ -141,24 +116,20 @@ inline static ssize_t objectPut(const void* handle, const char* buf, auto res = cli.Put(full_path, headers, "", ""); if (res.error() != httplib::Error::Success) { - std::cout << "Upload failed with error " << res.error() << std::endl; + std::cerr << "Upload failed with error " << res.error() << std::endl; return -1; } - // Check HTTP status first - 200 OK with ETag means success std::string etag = res->get_header_value("ETag"); if (res->status == 200 && !etag.empty()) { - // Success - got 200 OK with ETag, RDMA transfer completed sctx->etag = minio::utils::Trim(etag, '"'); - return size; + return static_cast(size); } - // Check x-amz-rdma-reply header per AWS S3 RDMA protocol spec std::string rdma_reply = res->get_header_value(kAmzRDMAReply); if (rdma_reply.empty() || rdma_reply == "501") { - // RDMA declined by server - fallback needed std::cerr << "RDMA declined by server, fallback needed" << std::endl; - return -2; + return kRDMANotSupported; } try { @@ -172,27 +143,19 @@ inline static ssize_t objectPut(const void* handle, const char* buf, return -1; } - sctx->etag = minio::utils::Trim(etag, '"'); - return size; -} - -inline static ssize_t objectGet(const void* handle, char* buf, size_t size, - [[maybe_unused]] loff_t offset, - const cufileRDMAInfo_t* infop) { - void* ctx = cuObjClient::getCtx(handle); - s3_rdma_client_ctx_t* sctx = static_cast(ctx); - char io_str[sizeof IO_DESC_STR]; - unsigned io_len = sizeof io_str; - - if (infop == nullptr) { - std::cerr << "obtained NULL descr" << std::endl; - return -1; + // Extract checksum from response if present + std::string resp_checksum = + res->get_header_value("x-amz-checksum-crc64nvme"); + if (!resp_checksum.empty()) { + sctx->checksum = resp_checksum; } - const std::string descr = std::string(infop->desc_str, infop->desc_len); - snprintf(io_str, io_len, "%s:%016lx:%016lx;", infop->desc_str, (uint64_t)buf, - (uint64_t)size); + sctx->etag = minio::utils::Trim(etag, '"'); + return static_cast(size); +} +inline static ssize_t rdmaGet(s3_rdma_client_ctx_t* sctx, const char* token, + size_t size) { minio::utils::UtcTime date = minio::utils::UtcTime::Now(); minio::creds::Credentials creds = sctx->provider->Fetch(); minio::utils::Multimap query_params; @@ -202,31 +165,26 @@ inline static ssize_t objectGet(const void* handle, char* buf, size_t size, if (minio::error::Error err = sctx->url.BuildUrl(url, minio::http::Method::kGet, region, query_params, sctx->bucket, sctx->object)) { - std::cerr << "failed to build url. error=" << err - << ". This should not happen" << std::endl; + std::cerr << "failed to build url. error=" << err << std::endl; return -1; } std::string host = url.HostHeaderValue(); - // Build headers for SignV4S3 minio::utils::Multimap sign_headers; sign_headers.Add("Host", host); sign_headers.Add("x-amz-date", date.ToAmzDate()); sign_headers.Add("x-amz-content-sha256", kUnsignedPayload); - sign_headers.Add(kAmzRDMAToken, io_str); + sign_headers.Add(kAmzRDMAToken, token); - // Add session token if present if (!creds.session_token.empty()) { sign_headers.Add("X-Amz-Security-Token", creds.session_token); } - // Sign the request with SignV4S3 (adds Authorization header) minio::signer::SignV4S3(minio::http::Method::kGet, url.path, region, sign_headers, query_params, creds.access_key, creds.secret_key, kUnsignedPayload, date); - // Convert Multimap to httplib::Headers httplib::Headers headers; std::list hdr_keys = sign_headers.Keys(); for (const auto& key : hdr_keys) { @@ -247,12 +205,10 @@ inline static ssize_t objectGet(const void* handle, char* buf, size_t size, return -1; } - // Check x-amz-rdma-reply header per AWS S3 RDMA protocol spec std::string rdma_reply = res->get_header_value(kAmzRDMAReply); if (rdma_reply.empty() || rdma_reply == "501") { - // RDMA declined by server - fallback needed std::cerr << "RDMA declined by server" << std::endl; - return -2; + return kRDMANotSupported; } try { @@ -263,7 +219,6 @@ inline static ssize_t objectGet(const void* handle, char* buf, size_t size, return -1; } - // Verify bytes transferred per spec std::string bytes_str = res->get_header_value(kAmzRDMABytesTransferred); if (!bytes_str.empty()) { ssize_t bytes_transferred = std::stoll(bytes_str); @@ -277,7 +232,7 @@ inline static ssize_t objectGet(const void* handle, char* buf, size_t size, return -1; } - return size; + return static_cast(size); } #endif // _MINIO_CPP_RDMA_H_INCLUDED diff --git a/src/baseclient.cc b/src/baseclient.cc index b8b0ff69..3696d90f 100644 --- a/src/baseclient.cc +++ b/src/baseclient.cc @@ -1372,29 +1372,32 @@ PutObjectResponse BaseClient::PutObject(PutObjectApiArgs args) { } if (args.rdmaclient != nullptr && args.rdmaclient->isConnected()) { - // send the buffer + put operation via RDMA. - s3_rdma_client_ctx putCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .uploadId = "", - .partNumber = 0, - .etag = "", - .url = base_url_, - .region = region, - .op = CUOBJ_PUT, - }; - - ssize_t ret = args.rdmaclient->cuObjPut(&putCtx, args.buf, args.size); - if (ret < 0) { - return error::make("failed to upload the object " + - args.object); - } + char* token = nullptr; + cuObjErr_t terr = args.rdmaclient->cuMemObjGetRDMAToken( + args.buf, args.size, 0, CUOBJ_PUT, &token); + if (terr == CU_OBJ_SUCCESS && token != nullptr) { + s3_rdma_client_ctx putCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .url = base_url_, + .region = region, + .op = CUOBJ_PUT, + }; + + ssize_t ret = rdmaPut(&putCtx, token, args.size); + args.rdmaclient->cuMemObjPutRDMAToken(token); + + if (ret < 0) { + return error::make("failed to upload the object " + + args.object); + } - PutObjectResponse resp; - resp.etag = putCtx.etag; - resp.checksum_crc64nvme = putCtx.checksum; - return resp; + PutObjectResponse resp; + resp.etag = putCtx.etag; + resp.checksum_crc64nvme = putCtx.checksum; + return resp; + } } Request req(http::Method::kPut, region, base_url_, args.extra_headers, @@ -1956,31 +1959,36 @@ UploadPartResponse BaseClient::UploadPart(UploadPartArgs args) { return UploadPartResponse(resp); } - // send the buffer + put operation via RDMA. - s3_rdma_client_ctx putCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .uploadId = args.upload_id, - .partNumber = args.part_number, - .etag = "", - .url = base_url_, - .region = region, - .op = CUOBJ_PUT, - .checksum = args.checksum_crc64nvme, - }; - - ssize_t ret = args.rdmaclient->cuObjPut(&putCtx, args.buf, args.part_size); - if (ret < 0) { - return UploadPartResponse( - error::Error("failed to upload to object with uploadId " + - args.object + "uploadId=" + args.upload_id)); - } + char* token = nullptr; + cuObjErr_t terr = args.rdmaclient->cuMemObjGetRDMAToken( + args.buf, args.part_size, 0, CUOBJ_PUT, &token); + if (terr == CU_OBJ_SUCCESS && token != nullptr) { + s3_rdma_client_ctx putCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .uploadId = args.upload_id, + .partNumber = args.part_number, + .url = base_url_, + .region = region, + .op = CUOBJ_PUT, + .checksum = args.checksum_crc64nvme, + }; + + ssize_t ret = rdmaPut(&putCtx, token, args.part_size); + args.rdmaclient->cuMemObjPutRDMAToken(token); + + if (ret < 0) { + return UploadPartResponse( + error::Error("failed to upload to object with uploadId " + + args.object + " uploadId=" + args.upload_id)); + } - UploadPartResponse resp; - resp.etag = putCtx.etag; - resp.checksum_crc64nvme = putCtx.checksum; - return resp; + UploadPartResponse resp; + resp.etag = putCtx.etag; + resp.checksum_crc64nvme = putCtx.checksum; + return resp; + } } utils::Multimap query_params; diff --git a/src/client.cc b/src/client.cc index eb41afe6..2e16ec00 100644 --- a/src/client.cc +++ b/src/client.cc @@ -387,21 +387,15 @@ GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { return GetObjectResponse(resp); } - CUObjIOOps ops = {.get = objectGet, .put = objectPut}; + CUObjIOOps ops = {}; cuObjClient rdmaclient(ops, CUOBJ_PROTO_RDMA_DC_V1); const size_t size = *args.size; - bool connected = rdmaclient.isConnected(); - std::cerr << "[RDMA_DEBUG] GetObject: cuObjClient.isConnected() = " - << (connected ? "true" : "false") << ", object=" << args.object - << ", size=" << size << std::endl; - bool use_rdma = false; - if (connected) { + if (rdmaclient.isConnected()) { int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); if (res) { - // Buffer registration failed (not GPU/pinned memory), fall back to HTTP std::cerr << "[RDMA_DEBUG] GetObject: buffer registration failed for " << args.object << ", falling back to HTTP" << std::endl; } else { @@ -410,34 +404,34 @@ GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { } if (use_rdma) { - // get the buffer + get operation. - s3_rdma_client_ctx getCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .uploadId = "", - .partNumber = 0, - .etag = "", - .url = base_url_, - .region = region, - .op = CUOBJ_GET, - }; - - ssize_t ret = rdmaclient.cuObjGet(&getCtx, args.buf, size); - if (ret < 0) { + char* token = nullptr; + cuObjErr_t err = + rdmaclient.cuMemObjGetRDMAToken(args.buf, size, 0, CUOBJ_GET, &token); + if (err != CU_OBJ_SUCCESS || token == nullptr) { rdmaclient.cuMemObjPutDescriptor(args.buf); - // RDMA transfer failed, fall back to HTTP - std::cerr << "[RDMA_DEBUG] GetObject: RDMA transfer failed for " + std::cerr << "[RDMA_DEBUG] GetObject: token acquisition failed for " << args.object << ", falling back to HTTP" << std::endl; } else { - int res = rdmaclient.cuMemObjPutDescriptor(args.buf); - if (res) { - std::cerr << "[RDMA_DEBUG] GetObject: buffer deregistration failed for " - << args.object << std::endl; + s3_rdma_client_ctx getCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .url = base_url_, + .region = region, + .op = CUOBJ_GET, + }; + + ssize_t ret = rdmaGet(&getCtx, token, size); + rdmaclient.cuMemObjPutRDMAToken(token); + rdmaclient.cuMemObjPutDescriptor(args.buf); + + if (ret > 0) { + GetObjectResponse resp; + resp.etag = getCtx.etag; + return resp; } - GetObjectResponse resp; - resp.etag = getCtx.etag; - return resp; + std::cerr << "[RDMA_DEBUG] GetObject: RDMA transfer failed for " + << args.object << ", falling back to HTTP" << std::endl; } } @@ -467,21 +461,15 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { return PutObjectResponse(resp); } - CUObjIOOps ops = {.get = objectGet, .put = objectPut}; + CUObjIOOps ops = {}; cuObjClient rdmaclient(ops, CUOBJ_PROTO_RDMA_DC_V1); const size_t size = *args.size; - bool connected = rdmaclient.isConnected(); - std::cerr << "[RDMA_DEBUG] PutObject: cuObjClient.isConnected() = " - << (connected ? "true" : "false") << ", object=" << args.object - << ", size=" << size << std::endl; - bool use_rdma = false; - if (connected) { + if (rdmaclient.isConnected()) { int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); if (res) { - // Buffer registration failed (not GPU/pinned memory), fall back to HTTP std::cerr << "[RDMA_DEBUG] PutObject: buffer registration failed for " << args.object << ", falling back to HTTP" << std::endl; } else { @@ -490,34 +478,34 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { } if (use_rdma) { - // put the buffer + put operation. - s3_rdma_client_ctx putCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .uploadId = "", - .partNumber = 0, - .etag = "", - .url = base_url_, - .region = region, - .op = CUOBJ_PUT, - }; - - ssize_t ret = rdmaclient.cuObjPut(&putCtx, args.buf, size); - if (ret < 0) { + char* token = nullptr; + cuObjErr_t err = + rdmaclient.cuMemObjGetRDMAToken(args.buf, size, 0, CUOBJ_PUT, &token); + if (err != CU_OBJ_SUCCESS || token == nullptr) { rdmaclient.cuMemObjPutDescriptor(args.buf); - // RDMA transfer failed, fall back to HTTP - std::cerr << "[RDMA_DEBUG] PutObject: RDMA transfer failed for " + std::cerr << "[RDMA_DEBUG] PutObject: token acquisition failed for " << args.object << ", falling back to HTTP" << std::endl; } else { - int res = rdmaclient.cuMemObjPutDescriptor(args.buf); - if (res) { - std::cerr << "[RDMA_DEBUG] PutObject: buffer deregistration failed for " - << args.object << std::endl; + s3_rdma_client_ctx putCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .url = base_url_, + .region = region, + .op = CUOBJ_PUT, + }; + + ssize_t ret = rdmaPut(&putCtx, token, size); + rdmaclient.cuMemObjPutRDMAToken(token); + rdmaclient.cuMemObjPutDescriptor(args.buf); + + if (ret > 0) { + PutObjectResponse resp; + resp.etag = putCtx.etag; + return resp; } - PutObjectResponse resp; - resp.etag = putCtx.etag; - return resp; + std::cerr << "[RDMA_DEBUG] PutObject: RDMA transfer failed for " + << args.object << ", falling back to HTTP" << std::endl; } } @@ -929,7 +917,7 @@ PutObjectResponse Client::PutObject(PutObjectArgs args) { "unable to allocate system memory with alignment"); } - CUObjIOOps ops = {.get = objectGet, .put = objectPut}; + CUObjIOOps ops = {}; std::unique_ptr rdmaclient( new cuObjClient(ops, CUOBJ_PROTO_RDMA_DC_V1)); From 8dd5a879a07d3ae98f9b75914468b5e27c49f161 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Tue, 31 Mar 2026 14:15:23 -0700 Subject: [PATCH 07/25] feat: Vendor cuObj resiliency_v2 libs and update build paths Vendor libcuobjclient.so.1.0.0, libcufile.so.1.17.0, and libcufile_rdma.so.1.17.0 into vendor/cuobj/lib/ so the build no longer depends on an external eos path. CMakeLists.txt and configure.sh now reference ${CMAKE_SOURCE_DIR}/vendor/cuobj/lib. --- CMakeLists.txt | 2 +- configure.sh | 3 +- vendor/cuobj/cuobj.json | 57 ++++++++++++++++++++++ vendor/cuobj/lib/libcufile.so | 1 + vendor/cuobj/lib/libcufile.so.1 | 1 + vendor/cuobj/lib/libcufile.so.1.17.0 | Bin 0 -> 3855224 bytes vendor/cuobj/lib/libcufile_rdma.so | 1 + vendor/cuobj/lib/libcufile_rdma.so.1 | 1 + vendor/cuobj/lib/libcufile_rdma.so.1.17.0 | Bin 0 -> 82024 bytes vendor/cuobj/lib/libcuobjclient.so | 1 + vendor/cuobj/lib/libcuobjclient.so.1 | 1 + vendor/cuobj/lib/libcuobjclient.so.1.0.0 | Bin 0 -> 408728 bytes vendor/cuobj/lib/libcuobjserver.so | 1 + vendor/cuobj/lib/libcuobjserver.so.1 | 1 + vendor/cuobj/lib/libcuobjserver.so.1.0.0 | Bin 0 -> 723472 bytes 15 files changed, 68 insertions(+), 2 deletions(-) create mode 100644 vendor/cuobj/cuobj.json create mode 120000 vendor/cuobj/lib/libcufile.so create mode 120000 vendor/cuobj/lib/libcufile.so.1 create mode 100755 vendor/cuobj/lib/libcufile.so.1.17.0 create mode 120000 vendor/cuobj/lib/libcufile_rdma.so create mode 120000 vendor/cuobj/lib/libcufile_rdma.so.1 create mode 100755 vendor/cuobj/lib/libcufile_rdma.so.1.17.0 create mode 120000 vendor/cuobj/lib/libcuobjclient.so create mode 120000 vendor/cuobj/lib/libcuobjclient.so.1 create mode 100755 vendor/cuobj/lib/libcuobjclient.so.1.0.0 create mode 120000 vendor/cuobj/lib/libcuobjserver.so create mode 120000 vendor/cuobj/lib/libcuobjserver.so.1 create mode 100755 vendor/cuobj/lib/libcuobjserver.so.1.0.0 diff --git a/CMakeLists.txt b/CMakeLists.txt index cffd77bd..27d71ba6 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -51,7 +51,7 @@ else() # GCC/Clang/AppleClang/... list(APPEND MINIO_CPP_CFLAGS -Wall -Wextra -Wconversion) list(APPEND MINIO_CPP_INCLUDES /usr/local/cuda/include) - list(APPEND MINIO_CPP_LIBS "-Bdynamic -L /usr/local/cuda/lib64 -lcufile -lpthread -lnuma -ldl -libverbs -lrdmacm -lrt -lcuobjclient") + list(APPEND MINIO_CPP_LIBS "-Bdynamic -L${CMAKE_SOURCE_DIR}/vendor/cuobj/lib -L/usr/local/cuda/lib64 -lcufile -lpthread -lnuma -ldl -libverbs -lrdmacm -lrt -lcuobjclient") if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0 AND CMAKE_CXX_COMPILER_VERSION VERSION_LESS 9.0 AND NOT MINGW) list(APPEND MINIO_CPP_LIBS stdc++fs) endif() diff --git a/configure.sh b/configure.sh index 21747a28..ba395901 100755 --- a/configure.sh +++ b/configure.sh @@ -2,7 +2,8 @@ set -x -BUILD_OPTIONS="-DCMAKE_EXPORT_COMPILE_COMMANDS=ON -DBUILD_SHARED_LIBS=ON -DCMAKE_SHARED_LINKER_FLAGS=-L/home/harsha/go/src/github.com/miniohq/eos/cuObject-0.8.5-Linux/src/lib/" +SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)" +BUILD_OPTIONS="-DCMAKE_EXPORT_COMPILE_COMMANDS=ON -DBUILD_SHARED_LIBS=ON -DCMAKE_SHARED_LINKER_FLAGS=-L${SCRIPT_DIR}/vendor/cuobj/lib/" if [ -n "$VCPKG_ROOT" ]; then BUILD_OPTIONS="${BUILD_OPTIONS} -DVCPKG_ROOT=${VCPKG_ROOT}" diff --git a/vendor/cuobj/cuobj.json b/vendor/cuobj/cuobj.json new file mode 100644 index 00000000..c68d5362 --- /dev/null +++ b/vendor/cuobj/cuobj.json @@ -0,0 +1,57 @@ +{ + // NOTE : Application can override custom configuration via export CUFILE_ENV_PATH_JSON= + // e.g : export CUFILE_ENV_PATH_JSON="/home//cuobj.json" + "logging": { + // log directory, if not enabled will create log file under current working directory + //"dir": "/home/", + + // NOTICE|ERROR|WARN|INFO|DEBUG|TRACE (in decreasing order of severity) + "level": "TRACE", + + // max log file size in MB (default: 32, -1 = no limit) + // can also be set via env var CUFILE_LOGFILE_MAX_SIZE_MB + //"max_file_size_mb": 32 + }, + + "execution": { + "parallel_io" : false + }, + + "properties": { + "allow_compat_mode": true, + "use_pci_p2pdma": true, + "rdma_peer_type": "dmabuf", + + // client-side rdma addr list for user-space file-systems(e.g ["10.0.1.0", "10.0.2.0"]) + "rdma_dev_addr_list": ["192.168.1.1"], + //32-bit dc key value in hex + //"rdma_dc_key": "0xffeeddcc", + //To enable/disable different rdma OPs use the below bit map + //Bit 0 - If set enables Local RDMA WRITE + //Bit 1 - If set enables Remote RDMA WRITE + //Bit 2 - If set enables Remote RDMA READ + //Bit 3 - If set enables REMOTE RDMA Atomics + //Bit 4 - If set enables Relaxed ordering. + //"rdma_access_mask": "0x1f", + + // RDMA Multipath Configuration + // Enable multipath for RDMA failover across multiple NICs + "rdma_multipath_enabled": false, + // Maximum number of backup RDMA devices (0-8) + "rdma_max_backup_devices": 2, + // Number of IO retries on retryable errors before giving up (0-10) + "rdma_io_retry_count": 3, + // Delay in ms between IO retries (0-10000) + "rdma_io_retry_delay_ms": 100, + // Enable automatic failback to primary device when it recovers + "rdma_failback_enabled": true, + // Minimum delay in ms after failover before attempting failback (0-60000) + "rdma_failback_delay_ms": 100, + // Health check polling interval in ms (100-60000) + "rdma_health_check_interval_ms": 1000, + // Enable IBV async event monitoring for fast failure detection + "rdma_async_event_monitoring": true, + // Consecutive health check failures before marking device unhealthy (1-100) + "rdma_unhealthy_threshold": 3 + } +} diff --git a/vendor/cuobj/lib/libcufile.so b/vendor/cuobj/lib/libcufile.so new file mode 120000 index 00000000..f5a4af07 --- /dev/null +++ b/vendor/cuobj/lib/libcufile.so @@ -0,0 +1 @@ +libcufile.so.1 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcufile.so.1 b/vendor/cuobj/lib/libcufile.so.1 new file mode 120000 index 00000000..28fc53d6 --- /dev/null +++ b/vendor/cuobj/lib/libcufile.so.1 @@ -0,0 +1 @@ +libcufile.so.1.17.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcufile.so.1.17.0 b/vendor/cuobj/lib/libcufile.so.1.17.0 new file mode 100755 index 0000000000000000000000000000000000000000..8098e55d5847243a691e17597c8388a81c879f5d GIT binary patch literal 3855224 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

^9*SL@%7_;x_?V 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

{-EzEvT-;(ah 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

!P434sF$^X6-D{j0NJsJ#ePFlT>DYAZ=W1 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%0D#HKIsTh&n7m3+B##7JP+b9D4($FP7e@Zf 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

C%6249QvP>$Q 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

#Pv6;9r+-GAWKhS%J^qDzxmF490HKG}Ts_?|4n zZ7LQ-ZkUsrTu+gPC6S@CwV;M1&neyJiE^TG4UtjXfQ3H#P_VaO?Q}zl7_%wzuE+8e7{-EUwMkuH$a3M6vBe6*6PK z6tb0>k2uSxK7A8}&do=RYy)f&q&Fj`Ra2C{gKZnH)=6OULd4qF? zambAX=P0Y+@VrnD*-MotN0jT5sO%z2W*lFc@y%J}{K}Q_ibwou4L?jT_fQsUd3ks-EO@IUt0&e-= z_f*~PPH^U*`Tpnscr>?bJ*Q5cI(6#QsVZcUuX7tzc)0)5j07<~jQO4ZS`mX%A;tR3 z*70opTgW$8e$zM=R%J$^Ojj+a+&I4Q(u`-3j@u9Q)}=pkoD2w@*5bT4_}JroygBA2 zXkK1cf20QEh+HUH&M{dYg(elxqVJqES&r3N%6ZBiYV&?<=3)%C#HKZLdu#U#o^1S* zRCBCH_H*cCZ%^*+!Ym^lge5hn84@U+Ekeho@C$y)5-M{2f>tn6>YVDoPQOiu{qUbO<}w z{b9_1AE7AaxX}w@th&F&ai9dQ%FiB*jegZLS(v+gAo?QYcH9h6O@18poSBBM1}`S> z6<(Y+gibc3Cg{e^QCz2&rB;POKaZ=}6SZnSqNos?1sFh8O$7V2Tlgy|U8}}G9B^my zN)ZcYcw7}jYsn#?)!GDctzh$ItvUS4ucs#viaou&HNWi53XTORTeHazJ0)H(8#q98 zA{Rdh%r!Y*lrQyVuoC`2nO1vW766fUqUSK?BE$geF2Dq&f}$w+5Q#MuUvBoh+jwyU z><>q4>bfEb2za5pq3@*oW-b1J$HY?P%EA$ zLk;z)R|W$BhFYBfGWQ91OKqQE0g>_61DaEozl6r3!yx7HUgbY^clD>o0>Xb`A_wpq zRsD`8QZFV!!b$CNW19Nr16Hv>yG`*Z*-hf-pfOm|;#z;Tx^^mYg@ujwsuh9yQgF^x zXrrI=sffET1;Sh$;iW&y?^BK7?)kJCC^;A?-|g1=S~rg@Lb6)*k1{rVC#`jE?l$h% z7WPARKz_K(7Vc1m_>vxz*z`Y`VqdX!`bN_052jcb>G?}>SwlngY+Rav{SUNNrV3Qb zLb{3f-K{TwlZ{6-ae?R)(!`%tXNpCd7_xZnf-L+x@t4SKP?Jo-2DvYi(}?|BWDOF9 zCuzxL>~q~_$Xy2bk9r7a3H}S&^D@>+CY&Y5muZ_!nkp6rdoqOS8r5n8T(M)U~>!eXa}g2cGk;E9@!^w}u0^Fe61Gm&a;ejch+Xp4s$i+LS}s!$s@OvAi*Ai&IO#g?Ziyzq(WRXX#I2@NT zkD%mcKNQb%1@lmqV4laB2hy1JOo`{|fjmn(>*y;m?J;YI#BzU1C^tA>?iZ1iM!z%q z9?O2ucraTEiHtT(lo@HY`a5RN3S{6>%q-QK^1-#9pJSxaNJyi>Q7w%wi-|%OXPwuW znHMfj+f{R6SQx3%jt|Ee1C|O6&rMe@;wa_q( zV>wI;>kC9>fWS|UtQXd|WJ;GofKAfcA^TO<2=7DNLB&&nGr>+y%&$Hah0U5FQ0cPe zw7y$@=RwOF3|9A`Yfmg;UECv};$Vr1ntkV9-dL2!9*oYyXcqfLxp6Gx+K1AQoSI+B z8A02P2AGRGz4Zt4Ig+&C0D3imhCn80u=3K`?{{z-k)QkV zlfqvJZ9qYh$1OZ+#_g2;vh}zkSbqmhUY}!DQm2!{D8-9K2Q`xrW$ykiLZ}QjXctUu}Z-QJpFCT z%|ryPDaNEA011iz8p&fsZ)6-6?ku+nztvgjFpsUoPY0I%Q;>ia6fA$cOY-HC_K;mO zz9J}o{&=MzIq1SS1Ft)@#?nBaFPJnPVk-+(Q(YR10NL^bZl2@?oxT}`*j2=S1(y3E zTzb+v_P|jNa^kHMGl7Cp=L57{0iGV{gBJPAkHM&tlYZU=Y`B?|H0Kt%l3kAf1+nua z=Ppl#yGUmDkAvaWDS`UEgjyG}Gd8k&vKq}TO~@3ROT4j;^eTYhKbDJ4WoY93yV&22 zhXDBk7@x~~&)A_?K_!cx&Jg+^_Y?i2wJ)mRCV(|i8~B-2K$u=RTMJWv`JZ?Lo@4ob z5P|BSIfP+vxN`@nRxM>$QN@FPl)LCEsCd`)24+aP6+=3jjuOxs7a#$*bNznyDFUJX zZytn0;+bGQ`MrUl7;X$8ncV-27Yb%w^@dRXlrDh2d->KcQ z%B@vD;v02PIocV7uxC4OiD7Y<#v;wb;<_WT__Q>kohM~=iPfIj%BM}P+UhTz`pZH54~;wxf|6`I6XCW3wwTP>;u zLDM}0Ri0w1d?r@qJYD4_UX@QAS>@4*RYqCmg7Z-&cU4g3p=&gOiegn>sjIBtYOo9* zS>>B02?YA?N>n+9Rqms$11P)z z{%FE0&3BN=ceVM}oA|@#d$)=An{S2r-euCO&3C!^zGc1-n0zzkyC%99@d-CxRNy%C zkNS+dJT*EL8_>OF@o-v*_l?-IMjr-E?MQF=xOw;lsw0!|(IYrAIsUWE{0!y%;xGRz zwi-k3bIe(DLgIRLReBKHL}LQ>w-9TEP-I@J=jyNY$AIIqvViSQ( zouR-7+A4e&dT=srQ;A%T&KzEq9tf{UM_E<@0Hyy3ID%WinL```c0_8;S>-Q3gxLV7 zM)n2_rXMdOuRk3Pcf#un=-B1Sf$Gd}G$oA=CWC zd44Q@B3WLFyxnsThWA1OLP~EhBW_){BU!AvI+EvQhx7Ddt~wp-=Pd$a3rZ10$bDs# zu0WX>6sz-oiY^xs2#!^yOCItPt0O*OEqIE8=QUy-nu{H2T@RAHxfoso4 z>8mxL740@M8a0Z!89r7xk^K;38O_9XFL!R^$yxlJf1pyz1k}6v9^7SUUMpimW{f7Jrfc;_=x`KQ`s90kyc2@uocI$ z6^`zCr;?p)IGqfjT5DchD=<@+N2Lg<2F&X%fBjr6kkjnW$r_87HR^2#j$<<6ilDf(ICv5+4Hcq&I;UxL_>|(Cw3^+ z5B4aCA?V2q$#v-2V)00Dt>g;R!iwz$4yk@d48rNieMV=Ivn%I z=}_IkhniaIOrpTYu(Vy=7=5CM(EELEcH72yt=vnz)`D#|5*^{0EF!!f*0Mmjaua_0 z{E??PZX7*O+-~cKVfeTmho7kxl|eHN<`aPV;jc92BMs)Jp&TlU*gNhV@+V>mMVvik zT&Ty8SZE&-%P^=(HDxlusJ-WM(0`|bP}^8ZKE57nR0^i&A|`q?nh45Vv`yPsYw9$) zdps-T9ug;aOU&ccYaV;ZApHiA9$=7uK7riHKuDAObIj8~r(r12dE*>R*Co_v-0Y9H zYGC&mV2dhYv5lmoUG^$GLW?UvrH?_Wv(JEgzH5Dg8VI|+fsJWLG$U*Emqukc1K|W5 z%5R7f1w_i`@-wb(wZEKO z(rEc59^@AhPJnz2AnVrqbn9~obU`-&<)de4eOm*x%m7^s8?+ty6bt93t?zcaw7!jL zeTNthJv9z%H<{LFG{)h+>l0f4$q>`}&G@0d?hizEV>$yOL$>H{sNbVof6>!TTR*N? zxBj^Yz1H&;L$p5RLH;Mg39WAh$h!4iP!uG;hd>u~1<=VF=;rS<(0dKgB^WLcQGd|- zbJL~uLs0{J;Pe;{=W86+ePLS9#}^ZDm~mY~>r=hfrxTIQ{eVaNx2q3{0&hX+D_!SPzZltmqDkOz4l!U>R%17zL$tHf6#cjaIJU3@lx-lc*5{GSQ!?#>vDl<-7%KoH>UWiw)%_^20`b7!|1p(F@2-&H~)nT*%rr|t9P?tf0(frsECCQ@B ztd&ZrMi!gmYb6(InR5u))GvP~WNW~u)LK$qe4tu;`Z4M%CbLktb}oVaIwH6@);MN| zrig(jC_#%RhF&mHVbVxYT4#}vimMYgU^D}z@;4uCnd9-oGqL-uo7WT8e208@p0 z?6qJMf@U9jDA*An$gYkhXND`&$UR7&k2r(u;`q-h^V1)R(wEY$tU$!u@aw>qOTey7 zLumiY;Ii#P_)5X15y>_%p%HQ3(J^_zT9YABTPD`@l%T#(#6=t3s#VwkfIhzJSbpj9Tg(>@7-Sj68 zwo1|C`c!h5N)u$*QrSOEnoudDxlbiWxo)D2ZlwP%x<#$JUDm>LNM%r9Hb0#=;izbe zzx;6!J+5zFd5O#yKc?yV;@fg9;YvoMGwh9ez8L0dTafXEV<~w4g`$~-#3nK=`%=iX z867EVvKm&?i0>RIR+G~K$In6&)*_&*I~xR}Cf zRoc<#3{CPcx~-LiN4%3Voc_rxwsGY@$;d(fTOS8jY)wbZWW?~_iY-SK!Z|FZ;~`jB zjF@a$2mYN1WLm@BR z^m>9EmPlfQV+rY~k7(d0tm(QAyI+=av2yWrQDl_*)*%hC&Oq!IgV>vyZqmhpyYvh!5M4RZo3*`L$vID)YU#7oFZL0i?WZtan2l$NSL-TcV;0@ zo%>HF>;sV&1YjB<|EcS{aDz_|Vc5|`La`bS?~8ygr}wwm3f&9p*inqzfgKZ-x8SFS z=z5B?*z#xB#T>ug?kS`$ZJm~?hw(`UcYpaT$!#rr-zX{(5r%sF@;HEAA>MIKj3}r& z3$!F5#vpbuRF!pYPtmGMbSN65E$vePR~127E=JA~dN3=W5dS-M2xBjLIv{obco`OT zqQDFzRWVBK2nT!s+MmDtCj!!afys*OugxvU#1REKGanz-atx{A_9m5_g)A>yxLjCM9cn)Ypz*(H= zAU@2@NQBhPTd6Rf2r^kr$(ivA>ysob8kg^c25h*Yqg z9ofW4ZTDD0bRh%5Q_QLsa{?QRwua{dD;3^ zwo4S%7cz~^lAh=@i_lB1bWRBWd`8JYK2=k;Ohi?)6@i?+cl3;WT$=36VmbQ+TcheM zT#R6#&%!De?P4E|{!9wk5*xjMVh*?9Z-6`5Ac`k9w>y6yKbqK8O3NWBgaE&&U6`rl z2`*4vDs@DK;Nu~9QaXG%rKH#Lr-{5_hOW=CcGGN(tla)*f%QE~W?#@zUd?+HGtBhK zNz_E{Nnid&RPSF#Ezq||ym@EcY%Vgo7 zIY~0UBAXD-Le@#)e#{6U>dvXcs)oimk-}oD-OJ%?e+d~YGX-Xit^FWnFF8%ylAp!` zmgOJk*R8CgMTge_RlZ2|b=VasjD5VdSo&b|1533L?{>uFw}o>>$*nG!4XThVEQgGJ zkt)y7R~Nh}DYOPx7tEL6)dh>a+`y7fd00S^oU%46sM3jZ<}=EE!eUb(sMrW-OY6Ml znv<^r%{EaF*umwhV;urvAn!Ly%jng<!L2rV+iWY$PlSu%*ydcq4gHY0Rr7PWsg^={3=?5-U9yA?l z6|F`s2_33yA_J*4pk>WPwEMf(OOuVJgiETeVJJh|wFe0%LTd*XZ@;0V!q- zI4v5A((uxNGmF8+oDu8%EBYnZM2x+EPCDwwNRt6P8+p{+aBJ{)W@IM^foniY7f!Hp;J6Y8=vI z%uT0rHB@3`Fv!;L4wa9XLY`LGilYmEzA(n_sp}va(eGCxN_G9QUKsrcC~>Uj8+=v$ zLA>mSMG4#Xo+N-H=tQe3Mc31W`RF4M#;FtvJg4J@%ZmduH5FymsXA(| zj=F_WEg1!i+^?EZm(L{$V1YAX{46p*)u5}uHrl8G5s1w{1XwQMmPsjXx{`L%J)l9g zhj5i0z;HF3mt=}4{Q;cM%FUD!G6ODLlTIVSJ6wz8)Re;KZXtUHtxORJ0tiKAblR0w z!l{vU(R5o_ffW6wcY_+g+#FlJi{>XRP^Iv9>d6iqn3#lNUSFl= ziXfG}eB_bx9ESbVvAqg<+5Iz}NJxHkh2kwgvYf~;`O#AypY#h@!K-Unye>3Q!}BV_ zBJ$tY6>G$tWNG^1GIWXhh#HQa#!>X>)nvN{^$@-wBWZzXj7!xQgM(yDx{KQchJuE4 z$e`)<#Y0TgB!m?iFa&X(I07Zhs~{YtV|59Cq>PiMv(P|N!)H?>)v65+HfL7xS9mgt z;eZ=oEH@cV9fFyz`!p0YV#gzuSjg1ECv|vXA0@Kk5s$rM~F>dcW2 zwpSF|TX37dGfRl;ipNICbv4BnYUIB|i__6R;9<`c4W|V}2!rFxf8cNPD`dOu^?~HR&9vo1r%O%P-ceb4m)J6Y9KO-HJR> zE~?SK`zCer(30l&=jspdzb`eDR1b#T)P}w?aXi_}Qy3n)916qwx_u2%oFpcvo3Sl| z0bG90TInIsHj;~;j4>_yUAnOKl30dQnZfBlnmrL|BRXJeCrnYK|Mr^={VxPo55J@7 zf1X#Jo87H9Fak4DftGp?;N2}R*+iWIG*SBdWq;fQ?;$>+2cj-@GdJ}IG?^Iu*~4Hd z>hK#3=6fLA>UuoaF^;t#-1Ct_h!SzQHEncmAQV>aXJgrA*o>8g29?lbS2FS4X|ti%c!IAYJtA{L6!|^5apm z;X^}saz@UtZookF^t(cP7Y~Q>R(9Nf^mR#&cka@=e;o^dxMOR#B;%L82}()q9h~>5 zq3C#L{>@@G%5C5rxQi!w_I&B7HD~aX||%g}N{SZb!i7z3&6LnStBh^ZA=zdcORt zSH-ngyibJp!hXeLT+TII(v+MR_&4p|g2h9u-Ji%xLhifAjtKqH6Tm-zsdw$Xz-Mzc za6Bh=jz@akKf}Do%H+}v)fLrZ%D@#?xTxn++(Nb5o}3=wrB^%vP>3rrl50j{-59ht z>iaT^(sB+5{g-h?_Hk*nFlR+c*PO$7{(n^G;n`Y|PV0G7Mn(b0>6Spae`Ygz*39&? zjJ}#Lpfpo+$Gy+?Ivusz_-Wz3uR{BS{NaUoxEHkg3Fv-?x7FT*ZD|HHMm1#+pYlFm z?#*%aRnNloM$CoRaTJv@RtZ_N~E(83TK+adHC|c zWD&z?Pj4waPmUs~G8866W@4d$WNL)^C}u(Zvo85}sNVrKjSZ_p1?pr$WvRY>(Rt~XoJsc)Q>2@hbyFB*`8|U)B6Ha(u}h{j zKOy-;lUyaq5L^0i*hU6f{544jkH?;DnI!RlGv&&VG4}3mg;(lMrcPhY(Uou=O#lyX z4#V_D>U}YoXo31_gZY)NR+(RU>TUB2D)eSG&jgCq)8<#Enr(i;pV<5gsB->7)qQ1! zx~gU_K-IiWps=E>;kAKlYTjd<#XpZS>tGbAc@V+qU68>>o;0#Q+rL0cq>-3ZeC>tF zR3YtIa&MI_*8o6C`R6$32)28O`kaGXDI#)>6(51Ck~Nc+|9VGXpEUo2uQM3V?Y^KR z#ngu-UEqA=qAShln;&v-gbuX_wFc~h3iaMBEs(yym>fG5DrG@c06r5$*UXAl(y1#k3y~dB~<(G_cbVmwJo;t+(=3+kymbD6JGtc1;)L_SY(@P_Uoa1UEK;s zhGDdyx^5mz$jj31Mq*&QS&T97OJ7C`c~N{0T<6CXhkV2ursE=HriIjYdkg3ksB9Lh z_nw;uPEwz2G>V~eX#tx(i^z*PxmGR7M+`3KzWWqVo@7$9k%!-^frdnVDoGwXGJ{qe z2%HZ=yo!)pI+tUCDRU*|K}o43VgNpxA5fLMy7HTauhm%uu|Ab-w%+xXB1jMF^b}o1 zdO{WQn^knuStd!Af-WH7)+WHJ9WK3wa|3c2ddt zg}8tM+l9as3kfLW95d>6S-nlIC?3(6dV?+zy3P+ALGhkUajn8Xc>|%uQt1z%E#cg{ z`4~Vr97Ygs$4i+5NTTU+Jfj5zjsA$|n)C2nb0iPBqi}4z7D-q zJ+cjp%op&>(;wa3n|?|2MNdUJv1hrt(;03R4`0XduV}JKAIk8qc(^aa-yn=NM#=e0*Z?#QLg-lh;as&I1CQ*t0$((*4Vx$L8&4X8_l>7O@u5LyEH`*O`NfV_4@faoe>RSC<#_uTnu6dmG%!*D%Q~2u({`r=FATL+dEKSt#V*7Cr z8;~reRr$k3zPMB8iZ&&hRCw1!NJTPd(18XG2N8Q}nb_0{X2|^N5)^oEzG`m^J2J1Z zOzwyOnIOm)faQZ>p{gGGVVY#DqLkn|9rVpr*z(__F6t!USfxy0c13pw`=hhQy*pR2w(qX4%_xP@5O9K_|k_Fg!I;6_d- zKPynbKj&|xFwPR|Rb{4#fKed#I86AflTCl? zeJFT+1?-%FU6>L=1>qcsj!W%UtFgYSDc9>Pu@ZUfqmVlR=Y22EVoM6`ZP80G(nNl( zsL6$htpwkx85fXT)heYACl;QfK&!b%tG8F}S!i;Jo=3uwB`G81^xY`0=1xOw(CGl&1J0#cHD_>t z5i2cFaALq2gcosWY~_{42ZK2qOQB8f59Dkp{YI{l>@zf_^kV|#S^ba=tmQVRZ_t(y zU|`|70QY|fT=>r+0r!!4Xlv1bcE5tirHI!e zDkcm+j8UW{bBFAnAJI~Qo0bcFH8at@RFA7`+OugKf6%q$fjspbWe<9NGkRYg>J2*r z>4aqEAVn<_akEBUP1PUS79m@F{jJS6GP)c*RGv}CjrI{i=Tt}uTq5!t7$<0dfi547 zEg;?BxQ~0#X!iFv=xluxySPLY`3;@_za9UOL)i9VO{{}0ALrJnu2GycK&YR375 zhw+b*8z29|z8L=^2QdE8)s4r$o(LgGe?eE{&Nz<$z8UI)9%f^N7r)kXY+`2M-A+8* z(T#isu0+3MT<(@}32RwFV|E_^Kc9&lmmgqV5_B-TV6?$q1yK|uYrKI8LFEn11!X*` zR|^q54!qPK^YYL%f184U+~na-N!J6jx}ca zaSNLd4yN8X`VzMl9Bg=ndP$xLZj4?8ZQKprKdo6b2O>3Qj|#ZN6#82atTyq;GNu90 z00gLc!^m%(m9($N|5^lKV$1{MGgH9s`gwq7D(z-9&w+S)Z1xSfQ!`aT4(R4gMYBq? zf;qpMiK2ni5Qgp@dbEnMQSFpS=r1twtK4j3gXAdPh!ph;r&-ALXN<=13;H*4d?dbq zo{a72|BvH03&{P~MAPmM@T1y(wEnuJCd*%9^I~MFbDz3uO)DOc4Y`14Iu$NHTI}NFJ#|Idk@rat1IU z=o-tJ?kHXnlP`bej##36S@Pe=mse!1!@0kc$d_y*NxI<+QK2QtT+VV(IX0n-)c&jl zNpc@j)axR3)~G8*qSUI_k?nstzix+kOPpU%#2oS;@_*)kKfkV{F#X?|Uq@l6sZ4OJ z@IStB{+CG}{4dHr_#c{hQ~rk_IgmKNa;c!Ybp0d#mpgF|s!9%R@IT%ZN$*}oz3Vh+ zN4RNm!v*c0{=3?nW`mp;jRG9P7PL3N#`&Jt zWy$0@HJ42#Q)BJZqYyWjW+u#@{Y2k|s_rxk+37NSifezAL&LK_nfY_Ss9Xv2=W8+k z4%uU&!BXR|;=+>m9BD-(BQ}3NgDEaSx4j(W9GonhVQM|p98QPLz_;qubIcwY8T~b+ zsISBpx<=hgvjMVwg${~OkluQF_)swx>wO06(aW%CwR@sr7~E(8F3@Wm;wnI%XxXIg z!kz!F?ZWG|UAWzou=|AU4YUh)D@6rdXwCs}+Jy^YQiVC}Le^{S!Ve}PyW4H-d$bEr zg+2y&(KzQHoo>e+_hq0u`QN8_+5zz1;fdj|8O5-DRN`2!ev zqX*Jrwqcr(xfwQ>8R_s9;tk(ex~bXcve_kkqXtT8y_$WtScv~Ro)%&fO5Khe{63kL zKp^b51e#Fg9%wKm;1diwq^XMyh%Kgsk`nM(yb42wAfC{>s^_8v z*=E8y32ftSbjF5K5R+SsY0$mq0`EFj&hGDQ(yJJO^xnGrV?EZ=q|Y_!Svq|_gDfAV zx&@{zGwDs)XT7A8eNcH(BHO&i6xUjJi6?bnA^Q8R=$mlv^^ZYX`O90wzziX@mN|6K zqrLIYk5)pQ3SSsIe7Owr=*2L!YraqpC&8QopWnqxHVvxPd$7az!mqd;e*5>Zov#+t zeI8nrdzj$`@$fc=pN)s#WB8GHcmc!Z2&3#8{^ms!P(RyrL+kXku%@Of`{^PKBnp6D z^4+1%H3KVCbu_<<)hUwJpiW>+ICt!9&_S&AD}%7sZ;(1`)j~aK)NCezWB8{B|C~=K zUt)yStmdx|@r&@PWz2!2Ri*h=tlpHg2KBOhcc^FZt$7HQL`Pt9{G;zxI=<#PLVA&Z zUgn?q@ySZ`iJ<)%KRp|9M;P538{yQ4cSy@fk_BXHkmv@?A@K&l-{lIy zKWHDMOUH)%VTJZ;s6}w;n7)g;L%?}L?zL6V@L>_xhOq#&n!bu5Iigi#*ZQ>Vr(s6*5h&Vyv z(Sj`K>g|%s!2`g?tE9|JywVh{USFUN zPvx3l#i|E?0Z5H34*w&E5+91h9ZK~42H9lpXT*8N_!8j=f0B?hH7yYHDY?8q)qmNw zhq@29bndLn+Ce`)YwdnWuN^A&+F|p=fxQ7;zkAv)q~=8@GyJ?d7wPNfb%t^&pf*cz}0%y;DI4nijbzR+;} zZCb|(cO;+3{7bmoOyx4}L-D6Bu@!?_i&~rdmvDDnRaRl$Fav4_j=ZE`KI6)vR=u#S z@yekVD~IHrSULR8S)!3w33tEY9+Jhm(0G-MA&tDKBfLtG(wmuGUB+8EycUhG9N^ed zBy%g;?JgDo5!qS4=1jJE7BPpX1EVOLuI#{AaUsDHq;LdR5!+P{$t$tyiVQ=mK9!_X z0+DjDI0F^oXmTSQO?WG?=V)@Kr2Jb)6Q9l^ZSNy~0F50@wqSh*#7I{(Nt{cJuZsMp zOsUjaCP|j2jwW-F=*^Ih_yc*(G|na$UCSv{d?`T)n93_4K~-nOikHb%B3e?X`x6!o zP4?ZvW4XV5nc!d2u#k)v!s$Pu?pAo29KtW{a$+1!JTH?ia;>m-4M-%NI!lO3FOw$Z z{(vd2wc{dhTtLBHG6CcX=RSZD1_hT&6}(J-WR4@eOujpl+HDyGm#>kZ2~Sszz_cH()0#o~$>`-Gc08NLf;rt!Wea`i?*CaGh`OzNkRn$`p^+ate zugvKvL;h~3>yZ)ATL0#tP|YO0Rvp%CDC2oIe$(4-Rn5auVJiIkn!&igNmX3EgMRAC zOZu9G=w%}QCiytMFm66fU+-aSX)>HmCW1WrZk5t9`diTL!k#)qxGpl8iFCYhHOQ6X zdh+ym7KyMVWJ<_3t|zb_G~0{2B-Fh~2OL~tiyYc_p<$s^;0!PG{7+`6v;T$vNw_1a z+tmN$M#j4B@5?2F8C7_FI&=PC{7+Wndi7WrV9yNi?`Z3adYnTPoiqfp5ARJjSa;k8 zF_VFnI9BUpla_eSTiTun?tbO-G+)fVhw!6K!Y?%mmp2JdX%fDbVbpV{eC0@%wc&w| zKKn56m~tGCqGY?@KzusA;Y#=m6n{0oJ#dwEAlDq9CfG6Q_FZCei+^&k^DaKBkQ@yE z>c68G$b}!xN;~-%75HXg+X*R%gRL*Q-`b?JFh{LUp?bir`vLG}fNAslnhuz!z6-b| zbT&{=arJ5+#p%kS!P16Hx-4GQ7w7@6!kSkwY{qZHWHP-2?bV()PXLP_v`t-qGJ6YV z&@eZZw?ZYrQ;(y%AI!fhS_btDP1yjx+|T1)xR8X@$ayc|ANUE|)l!W@X>4hw2Rhd* z23t)F@DkI8Y191p0jW_&UA)X+xQexp9JPx6{KKUZ2e*slsgUz*3o74iU2%RH*8Z5u zek(a6-@mLR1KZ)X>eseF4~0jenLz2r)69CC12qfGNBi z=h=>ijs9hIHE*j!omfco3)-Xi!nyG%eG9|wMS+~PCF270W}(-6&W9zv12#=Wh_FE# zc_aZB9l^co+<@IDU|$L^nEuIt>Ra1_Jtb|Eev)#DWu${@HhS;_Ih#xR2o%uo1l;b@ ztmIU67J5eF=-z?CYm-jmaH@HHe1(5e|CAY^70^N=-bA46 zfL>|DZwJ2vzqP@jh`%3A?=iIDv_Q_cC3l6KULj{1wuyhruLKdxYEokKaZU;5d{crw z?d!ScloHIr@@r?%Kky4OTq~|hqbCW^eHOyer_Ku3^iF*@@HV*)|3fERch5WE$hX)l zRIw9vY{*|mH+sCg>HCS;&kVT}Qs6v>P5zL57KX0B{6W;ieSaDZ4yfKhKvvD%@ed#J z-*Ex{HY?5WFBMT0Z)n5+w&pAhYEOR2V5Y$Ph>J%1DCo5b z;~84UPQD?R1Y$~b$T<_I_TAjSehU)6dJ5!DoEgOaA;u3JCj$PNT=tS}{pC}sBtlGp z!}Fks4}iRY;#^*8qLV|;WIW=IjDExfooisp$6?oZsnM_}_`G`o0wHG{vf(`B3Q(jF zEEf4r#VMwOQhayG!#K+&x(i9QB=vd_oMHmJwQYB+0!;rU&3FYStW9127CP9Tjga;}uZFyZU|lAamIG9XE^V4yBH zRkY(nBFWLmSxIAC7>z^V#k){vKh!zGs}lhbLh7XaV4W$t&gQ1hMXWO=damf8zWiZJ zPC}PrO5X878ni1BGTqKEhc=3y`<*1D^O>G&GR<7$FFzJMs^=Sj`NJq5pKzSxPz2iL zQEB|vE@`1_e+sp$*HE2$Kr+o(Z4}J)nfi}zG|!T(oR04$@Cl3ukc0_qE{iWmS2wbIKuTCSEvri zgZnB{&qG)QuYLHFEiG5pZ#>iLfT+CkgZ_e*wsiuF$3>Q7HAe)ps_>R(&<~u{yI^Z? zQhoxWyz(RQyHWW|5Rq7Z$&uw>NGSjJrsW@KRGylC1FEY!-MWQ2!yT{1XG^U8;fB_C z;9i#0c`1Lak2=GnB_bL>H{^nS;pRcNLtY!ShzyB@#OS6(>yt5uT9YD~al7U|RRX^z>S$|l+<-f0( z^&6bi>eB@06TJF^E+l2pZi~%!KBm?O+wK1HRFv@I^7sf6a&S(kxTIYr!T)zbR2-%DHQu?XLuVN#<>_ags#L-w9H@rD1W%w z+xF|$4dJ@&2n$m4q+Rgs-GhLa*AbTwO21;YT zB|D@b!=vBm3_bCtlA6{7N6=|Pt5=U4XlP*fKY?k1(=zgcfA}gHF0+Eh0QSi`5iM2M z%Q_a6#1mB3?`=;88L5q@wnYX|cWqL0U-U7J z4^XM}@zDJa!Az|N{OD9kD+3r|vSc6>;l^Ir;|_#R0&jJ%BEv^oB73xbQw15I^9wzi|o_ z2r=l?Ol4g?rpoi27CFhR;k zVAdtaAQH?Pxki7d;v4TmGhg#)O8$!7m<4_vP9Hi<+S4&8TKfF=T@UKyhkqOEzi%dg zP5*5N<_`aTf6;-Iv%r+?4&s7S3rP$Wv}?!@S6d7IbRPs4_8d zQkDCjX~)ms1!;i^6bH4;0j@k*l-U@9(&89B|s+|}|$&+~%$%O(5(bE9u?-3+r~`Mi@l_MA2enjAzL6uIfUWPjT^E&%GmT(~Z<;_yX*`kjFlKc5`v{H{3isd>ku zM$Yb2fHHYt67G9iRt9{a)h${fUCA?aMXFybR~xt@?rhZ@1Oho>h!>h-;WP;#-W%x0>~4^uDZl*&{5*bJ^ebn+TJ`Z!D2E216N}K>!T_-CeS~xCYz^Gw zz!BUo!+e1s<_I>spIbY4d@%&R;da?h@AS30CW-r6!Xfoq#nK!yf$KV|UQIaUG811! zrX9^Cx9DY~g?-Lr;`G(*lcuT})(fJ;5=^2fG||iG6hkP2OCa)(?a3U?JG-Gd~3iKs?Hb;JxWOw*t)L20>H z6;k`edaV_mNG^w9K-s$pLO7oHrs8tde^OYxscn!|RwEoOSpoM}yn{`(5^^S!zp~VH z+~^o^%k_;QS`4MBR=&LrT-#6=^^pwhd357wp#EogT%cq+{}i#6#cU<78O`(gmksZa zZB#PuOEBss9Nx7`r_cbSWtb?mdOissf(khbqm+6w8iK1$oq0*(Jwa<-HB!o^_V$&+ zU8+`D!ifbyr*)Sn_cbgLi@BJ}*OkoB_H(^?{ONeK9HF0$AO1s}YshbLh;Mz?1O1E8 zFkb6{PD^mhkoFTk-3<5)j-mEsvW;_xT+TTeE3Bw~Da~i1#xZIU&0bD7w#R!Id?}WK z?2mC2p7`$G4%Li{t3Rmrbk@OZ)Ko9_9>o3LEA)3wqi=QeR})Sx*6F{PFuzUg+uXw# z$@zeX*f1KWz&g8G0SjO-H4tz{$}Wec77Y7|G3f!=8jXz-KWL-8t0nA=MWj6NzYziG ztfh-E5polxVpS7(3G$|qJ^EOV4KQvB7*`C$G6b=}LM)bRjf~W<7$%P!smCKG=-jOB z()GY4W|wvlh})%Km5{MZHH4p12)Jdvq3Q;}1a&rKyEOf5MIi zewlNiAF42?T(op8Y|dB`UTx^~ATq|zie97hU}+4vLHpa93Xm`>;EXbvukkXIbm!^J z*bTBbNBaU3kx<`YP@kB* z7t)H$y=pygzp3)`!<&%Xho1-fYUxH00qZP#l%ws6T;g~G#R@WIo z@B*c+cc>I%7bcb&CuRC(=pwyL5p?{i8PQ`|qN#OQI3ux!GY!-fUByq-CP4~Zd;?lV zUl(gI=FJ3to4#wduoJdgahw){dM)0L6M;APJ&oDs!~3}Sk; zI(r+iL*b1~frigFq4AUdD8~boQdJBf56!=fEN0{u1lHmZw88@$$=biIjII1REY=nP70G?!910%<+raw-g6Y$%h%2G)duWQ*9u$gU(IqI0ft!AbOs5XLOe)(WMSMEt&GN6sN-NSfd~U z2Vw_7H=n2d9YKh6nU+u?vKnZPwUuoJ&~y(de$%I35Rge-U)lwFEHYW?0w~GI+S~gb z=37#l3dri1ta)BCvIe~0a`Ae(amTbKfy&;rk%lbnx*~q{B%Y^UI1$X{SSdGfy5bc& zsH+$m(traCq6?`qp+I@ewUZHgVn^g?22f}sbK##_Lpd2b=~?0qr$~X&m{_)MRw7Yu*HL*yG==p!R-fyeG#+zxk@l#UCQ!ux z4XQJ;1||{~y@JhTNn)wTxgK?-Z{g< z(=al_{GCEE2u`dbW+36{xQDeYaVM%RkQD*vL6JX;K^ySfyP?iMdr!m!b3XLnf2;H| ze6010Fmeo>kNQAw-hvWp9yFwoQ!aI|t|~>xIynecGuN|U2e6jEo9LIJ zD7r&U0p=kGKHLavUDn`JE+s=?6=vm7O$&8C1lp&R93xM#sFZKuAvJxPepclec~(XJ z`ZeOh)9`}IG4g_ns?ia6JLQb!&!Hmq6(aPTmvfeL$&mZ-igvtXY#)YvVdvlEEC@WE zqB918N$}lgzMU?EdRK`+qQ+FAFB-wo1Ar9o0LF`7mlMc+EFn>c|bS!lajG}Jqt6<}_SBAIz9)7o3Sq@_Y zh~b7JB7Y0N+Z>Uyy|@_p)!%OWMK%LofIUIIJNQ@7-TEsNmJRu}!M2{@&o>$Ec6+}I zjk!0b*wzDxmFrjKyrOH}$`p4Tluq~u;9?XoOma<2T*gY5hmyfiqB7C#+>gh5@}5T& z98?afz=1m2icbr5{)H=)GQ9mcHC1dD(C1!mhQg&ENtRxT#*7+2E0< z-a`)Ep=*#P9ZHFY7UrYS5gnRh_C=bs^AG!V(*FOae%*`S`M3R=qU-;c{mMDZ^eZI~ zN0jN;&u9M(zJC8~P^GaV&HaIwOwS4jbLNJ;z!@mquLBZ_98~xH!iCW4=toeajr?}4 zhdXL|{hM-wOt}%5yJF?O?DT&vccLk0t`gyV;daXhp6J_?`N8_=)*BLf^}yfI@3!>; z#-utth$A<92*3yrY+&R7kCi!~Dru$)Hjt3B9>TjX)At<47}tIC}r*vHd%yB+6&_GfX=nF!n=W ze|qOmJ|}60_E#7Ruip7>*qlDTk^#VPbWn5{42ct@CdhVko-yav@r7@yI5MD#geAwA^cWLW})SvYP8wI`|!e|YqbSF z^3c1?e|Q{V0K$KUj5gtSu0@!BStk4%!vo^s!OY(?9)5)B8S${gu;)(?cx4PH#nbO$ z*z>1HdMU%6KRv?T7^Xix;S2rmC*g$t?L}6kwm}xV=e?l)xkCH3nzGmIX+(RCf9k2o zoJjw%+hAnHn-7R)H(cj8-H;2irjFFz&^@0@$46QTakE1x68-3IpA^XP3a}r37$IzT zWIw#PHQo=~@LQeti0OwrXYQjg()0CeT0iU_XT8^iMsT>2dm}c3?P8|I`)C zAE$q664T@KPyJ;A!g2bi)-fEXf9f8Fbv17q`ET&=f&3c(E^Q6|A_1ilkD^Qx8lmnHDDx52 zO*p^=X@b{(z@NLB$p@{iNYgbQf|&I$$~2}jiD zWS@`tk;@> zhGZ$yNPg?`YtKOWWGUZ*9gFRUE7DR@R3_ zsKzs~zOk|TzBJlk(U}y&ydscM#Lk(^$a(Zcc|y|KLP37C-U1L4Qi|A+o!Z4YFqef!V|K7vH~(>Oym-M?U~)fe~CA9iyG4a~M)KyoPkdC#(^H;tzY%471&}02oUfU;!({G zM5z50g4I-?uk=#tSN`%&Sc5_Ds~?KDW^mU{l7Hs294&5Z`)jn*OgBhBr6gibkfIm)L#HZ!`Lj?q>kA^7}?jN zUJ+sH&~6-3?ID#DxkbpP3(S)Ousnzp2CtX{SC)GxmhBx~?di%a?D zUW1w>=8AeX5nmO)pFRV%Y9s<&J`BY-zd9-7!4uGGZ0iB_Cbl_k7XoRR%|*5n+|g;> zHiS%)H0?c*y&gI~DANN#HD$it1T&rFnXoR88N zdgJ`o7=rKDaGbZdIJEjSp9T}3^%(MEockm5j|I)$ZbOl|B3{+;UR5+tx!L_ynpt)z&qb z`p*IGrKbKf$VwZLCX2V7(iu1x2Yg@Mgi-@9_?4*oAL@oV3J_9;Y6wrVL>$7|gz!LP z2qz>$xap4|j39&`atwr1Aj<(^rfEap#t_zn04lRFgx4?AG?F&7`XdNO6T-b7gq9FX zfY9)TZo^l58ns~pA*@AQ0+lXHgz!)1=Mp!OO3P81O7|etLz4l7#RkIU#tX^s@aF4OTZyy?1Z5zS5ItI(+SDzwd4AyNdI>f;GYF8ZALmsRMnzrod z7_1@|c-VvWB1**DwJ+qg%j8!R6Jd2>(d|%Z*{+)sV4dN?+DcfQYIVC>us}x-R^LXj z?u)@P`PHuhjMp#K1muHPpi!4ZD8pIq#Z*nb ztOO`OppdlaY(Nn&L=EUX7T5tLOj`8&&cqf444|{T{Aw98#<-#ti}p3JR->fXqRAet zi_yd45UF8Baa==9@nHR>5v*@6@wkHXBHJ}25!Nae-Pl&Qt2hBxD-YJ2;M`^CEz?tT zS-|hX>eL9e=${R&UD0^E=AxX?umfRnwV~T}1q(cbDujkhP$JIl zNikR^zq%_CR(BRXbb@YISpuw{9xMmaVi{K=8rE?v(9450s1dB$L63$ezd9}vmcq#v z^`L>(*1+lthFXVmXje(P2SU)K0pt12;>_bkrjpF%b7ed`R zbXe{tPh>S`&Q7AV(s;gINM*%UQ98 z3%(b`@twwsfbUyXz&8l+f^X*-zMs}>d{0Wiw+e9@-$hJyviG4o0Oo->7{T`wYT}x{ zX&T>&$dO3j*O4O;-={=(xANl^3BC_VMMB>Xw`qJ^5Z_(^FZkYhu}9yP2Q|JE&_s{E zuOd$4`z%wP?0y>GuO5k!Mesc{j_*W*ajnJ3k%(`zCiw2vZ1ZruBEk17%>?9!4hG*V zmIL3805ABiAL!xxxS{V`sM*8!z8HP)*7W@gx&zpBiGvY*Zxb-W4~w@7zR6AS9gG}_ z^v&1!ZvAVl;ev0MIKDTtBJjft%Yg519=>gWfQ$fWtIwh^a~#l|vxGthy{vvToOB~g zKJin0eSuZzN9Z4~{GX*f?)#JcwNf59s^@fAbz}Logz}!)Q*TzsL_}Jx77c z1J=o&C{|89U)>&^Z#MHSh24VrJaIoZo^PGWH;MT&O+H%pD2MvQ^UXE+0?hXahBxX% z`}U$gz4n#=h4jIBY3ccR`_|~NDy&5N-o{xoZ~cYxuP2lrV9L)jTVJt|_#w`Tbl za5gNV{4ELPlT7*HP0AOT@*9?-ylPZFyL&?U)er0bO_luhO9-F+Yw56ZS^oNj@}9z{ zPFNf3pUJy5-P6&j(aXU`q&t;R(z9kwEMJkycL@A0fYll4VrJp)+@*Hgr9i|5<4OXF9@d=DA?Jmv7xc)s~2UorFj4E(qdzV;lw z5WdBH?=;`(=4+ep!{+;#`95X7FPZP_=KHq!t}x&A=KGQPerdj2%{OYkd(HQ-`8LC4 zYQ(Rl`L@Bgg7-fr+}}_fZe7#5ldpvuZykg~gJXS*5T;S^dUzdN8t=|H)wbS696UZw zMStOZ<)D@@=&z=;^3NDKuz;O@tUj5mnsar4B0R_oKMNk)#SfHBXGy)u%RNxKNcU!x zD(e!ftRpIeVJE%&?(SdHev=V7I4v`}8MY;32f_Y*Mr6IeJOg|aUeheRs#%|_GSdC- z0%U;$%B(McMgvNe{Vk*s0AvV&%K`>K30BrH8{vH0`<-EaKa}Jz|0@cz8JE(2g-vT5 z)NSA40IY`atQexLC%q)eT9HS!1~xOAy_E!@<6=&KOirz5YJXG%Ik_xZC_-fUVsdIM(;u(x_!R_$5kx1*qv@20g& zeBP524}}c*hEhKDDC9$}ZSg^GuoQ4R4xls)xb?U85k^k)XD8O+OAz=*KHql$|@6kzxt!Bgxi*3r%01&9K|LbiL4P zU2?oHOAw_x4yFC`wuHWnSSS(w2_35Kdi0V4Kiz$n!Q(b06QooO2FOAaKHS%cpH9*^ z+~VQTLgTP^o!~Ga0f#z7si%ejhgJrMEa9imV*CUiml281zVl<@fb}S2%zoowYX@&7 z3!vuynZpq#f8p5LR_S+i`_lw*&q%bX7g9m|at;|^cuRfsC`5Q+w4x7n9 z&(R<+kAu7%TMhs@D_52P{+R<2jMnN9d%O5^mwI{i;3JuAu^?@(YcBBIMk3LI@Xql-T0s^wq8Q(HK-CV~vd zMa0pNeZte)1eH!#?Jb}RgbKr>=|4%wKL+5jRi07C0QzDgzC5}zNgPdQFob{b<7I9X z=iS76--rI?SQqs5e6SajF8D{^)O88JH+sK~pXwIir2Vj~h^k{PzX+s2p-o=Kgo968 zVsY9bb_)UU%mF>5C4hnok^F~K3OHxdpzhl&sQnGS7l3L;Gl{tA zE>cf@Din=(0XYahcj$#DbT2qo_X|)qu`?37TRjVk(CxU4w1@k!xdc|2k8a7sguuM6 z7>VYT)Fg38zJMt>_Xj>`ydh!yRC)4&UGX$frZu7bG2)IXCPhf7mXJ-s-+5>cF3RC0 z74YZXLOkRQSb5S$7C?fQNzGu4;Eb15Hkq}(j70ykqW-KA9)^3=1z60W0&b(e*xVoC z3%M^^{s`RlHB=Rpae?a>c=!x1Mk~}=P!xe<>3yuXcc2f(m;c^>5~^!W+09M@ZY}Q7rdy`6KpN@%Tg^m2a-?jI1&OyER z{k?y@d_J7LpFOO#hqcyTd+kYm!zM&{6T-RSIp6HR&r&VYxICcgrk(IXT=ZYE3Igho zTK&!<=neF(oU1tqU#=M|U6&hN3uaXM=)Zo8#O zWl}lIrw{TSf-u}_aILN&HnX9Ik-j3E^Ks+Hic?T+&VBwN?Z%@lIiMwtn{W)WSltKGT!l5cbTMo!}Bjp#zO z>a~BdF1q)#-;4KtJAM=wF1 z{u=IeWPg^4?$|6}IQasSyBLU!5X-)fNM9X;k^Tq(jqrLA!>7TFX;u!75Bcwuwc2h$ z@H(h?xaFGCp}y-_Z(N($O;$XqB|=U$Ay5_86FUzjBY8DLE`EU_?Ck}gve3&l>G{JP zjL{!QeBY%%4wM4>R%OTgW7Y_0OxLXxZRLT^^jICPLXg@~j5=I!1sWy}`2!BVXadtB zZ<56Ah#JBthEY zO@i|{I2z}%9|Fk;5UKhZIQ3NkZg!3&%ZuD2`}D_ri5Tq5UxQ0;xD|b~xXqCPN9g_f z51H>rj61}H&&4+TeGd0@y%s>})X9Md@vTZ-JY zRvbR4MI-&urW>iUKN{$tC$NF`n$-(E@i`Lc)vxpquv8Az`N;MdLd~Ai*>O~#E!LcZTQ#ox?$X@6IXA6sMXV)Hjw76F5UyGus~!;E``19dAIeQzk8JF>k%$YzfY+wE{5L*=8v^wM=HYX9=NeS2usLwK@5SgsLviz8f!>!3_y{JALg`nECKvGjg>L)2U8^GA9^=qRu;=3Nnn7x%QzB%A>Hpe5Hb?^%; z9!lXK!kXyH)QledA*_|Ig^TTmt8FVdm}TF2ENbldvfyA16{WFIO8)J78kZNh@sFrk za&!F!LcP(M@ccLv$<14w{fUcoJMqoGU^mSEaOpK?hbn|_Dse6i4Ewbh zBR0aH5|th5Lw6EL!g1VyIvZ)dBi$>DnoTLkg0xAM@#Y$8ZB*ftnnj z4W>f(1CWK-bW_x_I8b(WIX?;9gTw&V-C|%VKLB1LZJZg0+NXwrSe>Dt?*w#22_<3J zt@7lV}$qp^BxhH z`i&YaWAVUWn1qaT?G+>~C~MqKsVWf2s;(1y!wvN^5i3hM*wtNlgFE=xeN)`RDOG z7xsTvq3i|K*j?tYkrS&ZRjOeBTN=j{EnPJ>vdG5b!Fq@sxC*`Zq{N_WSsBD&<}TIA zQntj*)$hj8-0>kfC=(Z%t7{M?#rObCX7D#Bw4T<;QS2fljI|$EMcdTz1ncCzJS4t) zG-?K}+<8d!;k<_#exSh0K4Tda?%Nr@ht~dnxvo+|Yk$rl7;sC8KfngfJ`J^k>%yc$ zmAF)e#JJL?Zea*YI9+1$GJsY+^90pl+OW9f>$<116e#+R;6htJsSrJ2=XpI{sD z&`)4i=k?tcoU&D;3c*2Jc;B%Qjk8+I63QMCf1pR)ATbJ48Q6}s*a3yYgC4+{+Q@?d z5Z_N5YXQvqgvH!6g{cYj(LPKT){9)v>5Jtv#2@ zB%~&TlD>piUa@20WO7&51k+qH7+i$;qm~GzDD(YV{<@{p=oc~OmgXaAFElNKL|owx zDf&f#z@lSLnTwF2xo7Gs_LHyAAVP;Rf_F}N>D4qbXK?n8D9n>eaYUXg5Oz)P?Vw&B zdz6qsOsFG9usY)tRrO6V*=b>GoI1?l7s79K`cK<)h+$QR^uMvEq&6jcZxTk2GX zU^^^ildTf&xry6z?>A3w`P#MvgS%W`8~{w|C@cS1FET3xLNk+KxJ~yjO{zYHgDEvC zF!lQ=1!Q2&W|4u}R87?E$7B{)*pML9O1=UB5o%8ovg7;tC?nMFdr79IZ zqDWx~ST0FohW14#V?Q*6+26X%i%@1*>PY@Dltd87QkJ4Xpiuzes}EV~r)4bYBU&tJ zfwhsBmt?99CZ<+$K>lu2s}Yn~)l8P79)UzWYbxodlv{FeRpjpSe2&2DQuQhZb&)V1 z=diun)iL02(q*YSTzq*Sfw0uXN6A=iswcxx9-m2-ss0d3=QRFD<4ad<@I{`(!anae zFnkWH4~J-dw*a}#8~xNEu!Fu^K$sA?%W%N}$M$X(Zx@hk*j-7KIE468U##c|SEasw zEZdgb8)e)zn$-)BV0C>ELKEd3(YX@d8efhaYT8W1*d|{1n)?gsJ zIsw^jyCM6o5y%b$GG6$gs}*@q_EZQyk`UYF6X*u&!H3Z|FP4+XgiNwA|hHwTZWT#>&>zg8d~VuN~_{YhfuUw%0^9@dgR36SWyPV%%xGECSY> zyNr8SYrz)Xl*HQ!+SXI5B)^h1E+~uS0h0tVga>*Kn8R-?~5fo?6yC>KVtKWd?h9~UO&pIH<_WcBVev2<1zx-1# zzrzz`|G{U_z8a^<{Ptjupsuf7>3$4zN&Z*g6-bfl4<8Akg~){;n0$Q4D;JfdsQR*)kCI65z}m7icCQY$G0~MjrFPEufFF&m8k+XUDvDfWB_;< zIZ2Tpd}OL~1hCvBSbVekpdQTxEfg7D2GBNt3I`q`F5N+>5v<*YkZdUKV1ygo9 zBaTFbh5CJkX@Xqp4e(FHYDty|50|D*+qhWJ4n14Yl5@GmB-!BY3%nbULhurJ1yMhL z7FJ5}(Tsgc6n{B#11J}*_^?8C6qM|%+=+BngYt~?H(t$py_siB(kHJ%)m|W#O z2@L9=ZGRx7Lmew~8sBK4{k>)#2MAvQ0yT>x6Cs==5aeQxu`N354p6rG8ik^sxdk7Q z1}FfibUh52A_w*t5>0yu8W!4m=*8>V)~K|S z#Pd zgv)@OyzGe2!t;HT_02m47oOj2Ibjw~ZVf9-w?a*rI-6%67v{6QbDI4%{UNmn8)@^J&%+y(#ZaJf&ft{V6b7tVys63U_ zg77MZHnNBt?wDFp0>s3l|7s^U3_4_oR%zC7te-4X~YM{a-3KT$k1 z%4dg2qxk3Xf<-)`2X*tlGC;s{lGQ<*PvyO=)$Vp)hE#DcX@sE@=iuU(I!oU7Yy;3N z7D*m;tW#rZXl`4vR{@2$%qUUD_dF2*+j3tWZu;Wj6MJ{n-~a z%kj+`e3q!vtXn2UzQM&Wq(jYkPtA%0H9uco^zt9 zbt2W;)D!qDm{jPvBwutOE@K)GQ`J|C;+?n+es$MHNlE8mE^~p($0Uf-YB*g-)1}i$ zW>DD>aA+LO7{Vt0@Q;x4a=i7;R8X6`_XSBJqyr|eS=NhX&5pjS`(O$umv#qCB<1R8 z$bq2qG?NOy7TEtOu={0LQ@-LvWaXCbRx+J#>NLRA8w&{WRp3GX(qea1zGW{AAiHpB zp`Wd!A2fCH^LY`cV+GKk>Gr}NOk}%B;z;Kf=0yE-&qPDM`4PBV<<6rrC1g^IS%|#x zbsUr$_V0&(@8~Rap0v=rptob6!McR&%Y&2HOZxoh!2_|EC$%X2(X3wBqz0-y63L*& zT=hZ+Ks2%s@Tx_4ljUUZ%d~#0_023aTY)<|S@WA3h6x>COk-7hp{iC3;!#X((ao3j z&O&=eYN1`;+iJ;YFw*1)jGIYUEq;kWTC8O#a}xiH?a^5L@y%VH0q;JzAT6cDzE;bw zR#3i^pF(_}Qhjk^#1C26qSpVlqf>~wO4D=|NV)}0=8-gBH4NoV0bhcbE==)|XfREsLpWezd3FcYtf#5f46tfyuGbb7ur*LEgfoy^cF_6ySWZmckRJ zc06jhzkU!jcT`~JDD6c#=7HT%zN;7EkmH%dF>z|mah)wTZFfMyePx!ZqMeYNU242!+2h}b!7_EKcDSGjNT#B6uu~)%*D0StL}EGh#$c57(%wceZ6>9~ zAYEO}j1VQ39-ma7XV4gN(X;A9?p_S&r3?W5aOwzOx3;2 zCT&*>;5sr!*)ldqCPA|@c3UI2A|oXzpSnm>A2e49lz4x*5FCMi?2(LX+EUmSM%`ZBsWw2#~+t1j@+6DEjtLx8%qYdL(z`TzGZKW~Qsl zA(`c3FiFL`H^g(F=ShKQ8TzVoyMN{A9+7XLFcM6UFOsUwG4dF%{c@?K9~WhD zNi#0hE5N3(z^yR)Zo%R=;;J@bESG-B5g7iOuW+n1_YC0p2p(tBsm`c;=L|HOq+0oH z%F5PmkZbqCPUnC1qk+74)>`>ZVBdAtzH9lmC`4Ev8V+HWJ)=JrRJ4mIL6%(*aKa?g zLi_Sl?SkRz?tol`86E}RheEsrV15dprLS z-Go-XEif(--`D+!FNKv&7uBd3D{I&WxAuBGNNjcBo#{1RgSlyk^%Z@hyiSIMtHjBx zfMZWDx9rI?Kz1S{t#RCmds1AS9d!yKN6VIgIVGhKX#Q*6>pJeToOCF@XFk_n*Qj^uvxQsuyQQ z>wH3PSqLt4G9xo#hBW*BbYD8zN1(K#;;ad=0h84@+IpyLoJUf1OH*33P6HhV+75zj zE;p41@GZKGWrwN}tOhOmUGyTTD#Z?79k!dTL3nR@A-Bo)L2jlx)LEkpD152ab@zjLK74dc}TC=ICID+#o{;z7RvJ0pYk)Vg5uw|L*U zo`u?9?wp0a1XJOX=b(Am$gOB( zxeQ3FNSbU(y`&5_#~9~CHPY$6*d7UGN#u%UPY-~BKx)<102g%gp$CT3k(SflpdDs0 z0lezK=t$50Xyiv8Az)}LN7@x{ zl!XCT()nv>Y0{$EkuJlDXHzk?@*%XIBlQI+scR@dGr8C<%Phu`tzhmFY5A}X++ZAj z#ER>ZevAZxxh`dAF?LndvQMu3BPJ%&hNKC{=RYDGe-<3@_`-6wDh~PJ?QExK@BKB8 zA4wiBaC&6mL3+XDW@jROsgzxPc5YHq*|{?H#=wtz0ITY)L4T`G@~UY;(!fqyoSX(Z zPXdL$715DR2n*URD=5s+yR4>aL4>Jtq$dLOc$VX)!0*5Nd}t?;+4zAvnL8$s@4vSt zvI5lw^+ocb8(_F4Jpmp^UN!{1kte_fK`p_GDZwtnz=DL$>| zC-KqlqlYlsU2zyjyH8JpRgbxjVe+F?_5#$*O>05|Z@uSz_??uFFVq)!)?7V>3~`GO zxSx_qJ$imB=b)E0>N)7OPf!KBz@kC_Y`$=TcOuk&kDvdb9P|uwOXI1< z$RZkgo7(v}?<$oR#3-$bFG)?Zn^8%vY^c6ao$N2rgy*5Gi&;o-IpypWP6zZF!E65@ zk!QaPN3Rha{|dV4uT#0fI&Ub;Yf9*^DPuX^yxE_i=yU5pqoWb9#+Qk2?#X-*AYec8 z6?mvtVCJ!PAEHX0^%8Kn!~woeQWrddtEV0V3$TN%77=3zN9)EEE`QBN(yZfqP9R_{ z@k4&QX*bINoE=`^6}T6GsUQj*St2QXO>gMB`fKjhATIMj+^#|Fqd}~E&;#+o+tTsftl|0RUCM7a z?fXZi*vn!tzo|oIy?a8z3pe#r*N`jRya#Rtg^hR)qv}xMN-x108&Ms!mQ(F`KmPZGzvRjT~CFJ9%3b*|O1TqBT6%{&G4=gzECuM8)RYl9X= zjgMay(bn0CTaZaWM`5qa_z5;ZY0XuslxLAP<8uowkrI^oC`PYv1e+t2T>5i$I*Z=+%<8idD zL6SkkN4z?R<~6-Pq|mt}HBb=Rg!66J(x?hRNU zJMqDy@TlC%19%?SXNLA*PCxNp@5+a&jf#(Hr0UGgQ7aoWsT<68K zgcrrV^~M{t8*~BY`owJs;}$h3B%ZcHN4m8vB~G2DKFKnT3|Ow4j}$1C?JhtZkn!8< zW+8RBoFTBI%05df4`m2YpFkBsD9jjRaVY5NTBf(d6_OSNY`fD0kST)Wdk+;y$xBU1 z;4SmKnoy;vc>hMHEB7L?dgXa#BeFCDTJKh!uEL9K3D5AnvI|+)0Q&*a%H&QI&O!oE zL^U0u*%_?J!$Lj2?%k2jX;_CKXbK?w4e+5m;y_~{u&(5W>jX;Jl3IpYeKqc8fiGyB z1_lj#8?$CXwI~LSW^eT?v;<&dC=G&lQjcm8q8D0npH3xsP$TIUfAA(Dgx=R-QvkJX zq5bnhERkSlpw;C0Oo4_cP|V>irxRluhBByMFxExyr@cj&8tN5!GiZOS&V3X^4aZb7fA)Qo#HMUy0~jHc zMKA7|Vnml-T&hFz(L4D%jr40mf8{n>z*Bh`#EEY5`TUmExb-sM(cjqL(V0Q4>{H9u zfpIWuHCxy*^f`Z;6diA>xTIx~xc2>;S)hbS(0npUtXQPzxjq(=92jFTFOP4_UqBw` zGedCoNUtW(Bj!eFmN+5za6(pQp+HPMEnXmOGGp}3zso2 zPBZ9uRvo*OP^(3Zv%{mM1KNmZvVFr*YPXeN@snXJyp;X18 zHF&6GN7dI>sF8q^D*J#Ih?9Ly2NSr{kkAov?v^I&YEe14OiTzeyaflTP~K-)U`Y1g zF%8R9p}hC;(cOQ?WPDh8T=MbXaX$n;HD>>dq@;yX0qE$c5Oqt8hx2D$`w1$3nU76XwPStsTUAefQg;JD6u0Y_V$7aAO~iI8v3Z)H>tBhs-d~Cvq8$ME@yKz zO0UCmriMQ(Bq!*GXg~W&1>k3~)5UF9sX9(zbk}|YS3AL2oD*&rw^J!H8VlN~dZL7M zt7=*NRrJ1t*y7Ni=$1nvnk;vEfT5dQoiHc~VWS{HN+lnX^nW8gu7ZKlBm0Zr$+_e6 z_482N(V6}59Ih{QsJkDKj?`TMW3g1p252-2g^HI2X_0Fxa;eG4g3E7MhAfs__bxxj z{kMEWneRx+$AYSzWI|0S{OlXg2c7Q?5S@n>IQ#sCnZPr!KWHt1>0c8bZk!{XCN!z` zCb_{T#2{z>PB=&i%3i<#?o(LE+Nj5_qb5RaqtI@cfRI9a35Q8+?7**Ptf2igM?^b( z9)2Oxq}Rb1`YTH?RHVR+mFll~LDm$~pg!Vi<=Y|!@$=^#op%SHki-nBQy5nT2t zSejV^dsGItpNJ>Z5uElY> z{v(7KJ3$_a$bZL+5Hl1luPolPXt_g+mXe(iEh)J0XkHa%ifh>ZWlf14%IAQ*-6e+e zAq?6fXobn5caeC)hVvm4s2vO4u9p~>oKG&%(n46`Rf%axWsJxKEia~_iPXc0GjAr< zikF8~JY=^qqtig}XmMfQD+QL8Y+6brNVYQw!ALfzf$%BWhBFJybugh3M2Y>)FfE2E zB*FI}^T{??q!mWmGGsVceMY`?8X2$N(SAX`0)9%4rQ&v~f9W`>$P?Nx6@EbbS#EWg z_Dkd420!`!2D(mzu!l3AdsVzK*ExYZe{R6`NV3{CM=DOrrZmE49a5T5HAmAIpmb}| zv<93I2bh@%5Iq5i83y7bafn7>?FRK6s`4Qbw-92_k;fptAR1DCrD(v|CEL=oKMSGF z-n&OyY7S}&kwWq@)UX4MUNr1i8X<8oAvV87t7b{7|E}&46$=jMHWbsLYmaCmG<%X8kHL1vHI9~A>ZTAVj77Tw(QV$ ztcid=o4HYF90uCcf5{NLSW%JPiVI*s-s^xv%wo9l#d6cmtQK3!$9KTdb2t?`ii3e9 z^n#iO{RF^An$Uude`E6+mjHB*VP65$d^91dkPh%hchsW6cPk^bW^ZQJ7k5Yq)pE{! z)x|Z^(kZO{9im_RE%NG(v)T6j!VcXZ-1faclmam5;;?5LJLGQIi6&-Z zSMGA`TP0*6h$9JEx2!rDJuI_%7qo#^Z%5-ov#du6u>YWm4Pq2bSS(5gaT^3Hf|RQz zWkqVF6iwhvm*=t1c?2}r-cE!1rsyM<>nnREp{(5!%6idlQr6dNys}>7qO8wCkRxm4 zEGexS3uJ1aa8Ja~&`%=cbc%A81#RK4=_>)g$9|Ib@XyUF+6(%Po#}x zVDx**{gnjxF7k4}%WpSrkj`Bb%e{6kaz87PzFYsP>*lXnsB<6b<<@tlq}}2O?oD8R zZ8yG)xv!MOdTt@OFVwj=|7c2nrhreY(z)M?TtxEC7tOyizz++&Q(^fWL2 z$9z9x+!ljxtZ`2^;m3*F68X3Jo@L@M+$H^Fe1nT3HzOV4zaj2wEZ0R=h?iTXA|Dti z_n6!>jr+E7R~q*lq>DsN;{7-2COFZ!>%P(7O~zep+y!twdD|R68YFUHSW}mfq!pa+ zM~<4i-RL3uyHD(UqUBtR1->6D&%kOJo-Ws`VVRsv{RkZcfwIr%FxbqOfzpzyj@{E9 zADl&!1+nuZ%aMuue9t%Unk@rI=#4MY4;fx?cCn3Zl|}ZNf{6taitYDcQ2kUMh2UAJ z6g77ykYaCndLb2&cC3wqI9gB#Y~1O@`x)2(Vd1^j6P*1+za3F|1ouYlV-3QBX>VK) zS=Fu3J_d{TnF$9Ed2lF2`9%8A_b$b>-GcQ(Nv+00TaLG3t-U_9Ejjf2lpDqc9pC77 z93UQ0P2~1F*ywTjM+3sqan{Q32NquW&LxF|))v@r+w1M0lA8)K-^9&|-IGT9m-bFA zoYVVYcT#6)+g@|JA6zi|H~-N|NjEmS1zDlr_Pya?h_P+k@B;YT?zm*8Mz)kWXD83u z2M) zFFBHfksV5B4U3(`P{OsGA`Fe~ou%B_QZ>vel8ssuWusO@EHXX%tf{ZpZ$&B5d)RNW z?;g?j;?0HoMA3(TP8_c$+yQoQ&cktdENqS8+Ms3sM{S!$kvG$l#X(sZT>c5R_~A`c z%Po>+!JfdKC6oNyZL=JRVyY^9a5->kG1d?B@#t&Y`NcRqFKc<+(26xd9I9JRu0;TiT7G=~zq)k!XKgK6DM25m2}3)7O$bTg8% zfIce|r-WxshW=8Ok6j0tOHNI(?DJDWo9PL(iSp_(IEdOn%j}V%hQP+pGo&bKj|>8V zm7@xK2Reh`$P4Gd3ig8VdC-1KwDJ$t80Z01lpc(J%6@(WIu-wBiFqx^6Yae-)Tein zmwRL5KSH=kHn}-+8dB9-Dw_Mm3wN2t^?>D^MS`05n5H2Kmx*g&J1NGx66%G$?7hMs>tQ&70X^7g?70* z+8;kCnQAroQq*Vkp|S2JwIF7V`MwR`aqg7!7O$E9P405@Z)VWBRx^Xr%&@my^EQdw zZ^BLTs&_GOdiVv*uon9klGj@HkKDNs9P}Fo34eH%W*dKaUu1bBA8iX23ae7ZZg-e| zPqADJMMp=Cfhq4p?2l%08@+rpf@k1=KW9t;Uny%wU~$|EIAd_GY(xsc;41^qIU`ky zZDl%RhS(P7`(rTCKWn&UTUprQG(4E|x4-5Nq{V@3Y|9VYO~FA}QD})4*Al4%q&Dz7 zWAO4G_9=(n%E$LwXH2VYwK`)q+14g!jIu4|jM-{iTaj)%;31k*{gBPDdZj&3Z?=D3>79t^2hJZVPAF`5Yw|zlS?vEP%nSYd+6n$ zb8OJLA*B)C>Zo7aQ%am!cqhBFGFa?fi0L%mjh;pGaKgLM+f?9Yc~7}7-i@|$qPsqk z-6&6FzglAd30N2vJF8v^<^XNwX!D5jPYLjP$ffW0={6!cpFL}B0clq=;u&MT)xH^s(hk1IVX3L1w*d$Sb4RN!`sJP2*b>rhh` zlFu+SQx*71ZiXnb zcqlT31E??^ULXf~G)X`va3?V)K#xdO>57Q(@Krc4<6Iqx9<2MJ80WHNrzXTk<+(UH z!Tu<*e=c^eWq$ zem0C7=%9n)AvXV9jsxs^|C~7lz=mPjF;2Fq!`?I6NzSdfR5h-fY{3u+c`Lh>)EE2+ ztr{M*cMkg~L6i$WNwWrXW~5{HFu+qdpEDaH5Z?B6${=;iF$Hfa&cP)TUl#jEeHO_@ z=_oHsc)9rt$RQhXg4pAmifhPG5%2=GeQ#4!rjr-ZUHWMO?yO@WtS+}~Tw1%Mz<({M z!{4hYOD0}G9EVu>uVSYdr>w>WK*^#$u*q&ZkJE1WR;mGZOZ2XUdTE5 z+AaePClX|dGZh3~1e%?hMU8d8$XiHxX)T0F0f=2vr{|yz&tz>MTS+4MuIBBklXJej zbu0w~)TvH&#yjXw^cxI^N$PMQN0T9%fYnRlvbi@_8FIXnP2iL-k$d_l@LhGWWDS_k-AQSO{Ob_ZTrO4m>jqu8fu@iP!Ml{=^Tq8{ zuDBg4Or8c&4p+ArUzWNKJ|z9}Y^q`{>fW1(j8n)t#+RyY6Cc|Yw_Ui|4;+gT?i7r0 z5WYj0=U7^{v09*ahd70)fknywa4jmrE0DRDmJrj`Nd{s-4T(easpHN8>QLV4-?2{z zqQf4&A9OK$6{!SG9+y3l`4D@WZ*^=u%FM&n6pUNNIo&h-ZW`ECZ9-2(_7}!wyP_OJ zF9I4=A~hFhN>T6YZ($#{sOPY~5WxqT;K>LEajWmHMm2}4e&7Y6iZ!ahWVlIZ`2G|P zXRryrn8D65mOC>=opdc=L+E1SDvhU)3Sn~+jM*?(XiHfU3Kdt3yQ}Ls`}qJRT5tnf zb?A$re0h)rrJHAvT}|@=3jYf`&B?xoNho6&HqOL-A#vUG3nb{7ZX*=yc_6@JS?3Rs z*Xutqi<{khD390XWjt_5lKQxckXJ{2{3#{DkGl;ap}fbxVejyMi=_Lom2m$XbqRI= z98(>GRHV2g#qCswirb+MVs4?heT^?mb)tmP#Y6ym((33F{K1jV)zJ_5vywlr#8pq} z?_K1_PARx=(!G=)Ct|vX0b&Bg2&4uE63CB2_%agZ$9MnfB0oNEWo-t7){X}ZR^VJ{ zA(S5|KBWA{#q*Pp1v<~H>FsX;DHeAUj z@q~#4J&g$ukWd&{< zf=Y-EJQCAXjsw5qI(SY=DT4&^0nWS1U=F1?WHaWyGmdSZ98zcRr`BA9aH`O8IaY`TgKiP2<@+Sg<#&>3Db8Ga&{ zqppJ`*cY0|Cc$B$TT)cV6^MfPz%0#orG%3nD?KUV`X(_@TMZ+>ODVfq-O3ae4A5zz z54x*?m>xw}0($UzfO3XT{W>m7Mw$W~4v9&*@hrO#@5V7nst{ni@|if7ajtL6-2=^w zMm#JP6Dea)X#Rz(7`vV?c+) zM4&zg?FMtE1*VsA-)soCDhB;U&6dA#1JrP>5;kdyZ=Mc2_}KwWvn#J;&Y9GEa*^{e z$$1Mp&tJ3wxtowPx(fG^g=S?YRSnZXXjIa0B2UTCnh!C!3ih_`P&i?w(0A4v{Tf)D z5djX#H>}iEZi=VbZGM=jA3C_ll!DgoodIdyL(dBl$aD4-@=%;PslokUb1A~1*?R)} zSkVD}?VoFzKY*X1yp3Oih%f=A*dLlJdD_(!$S;chW3<@sj$jYUyF~8xAC!V1s*HBK z1o&DV25?<$0ZRgL-wF!it13-!)i+Z~+)&(Lcr!ZWzhD(4z25=BOZRWkg(vpEMe;rA zkYDZ#vHvuc3JCOkD4Ep(1VF9((_%hYEGMM?s-sN>1j^%uP2B3%Xwr!x)$UtwGFxFEj z4efFc6Dhn#uj81=-N%E2sKRkP=*ID2{(cw_e#1f^ivAl!JEhHW{0Xr6jwb)1*#?LX zwNV``-<`_OZxkE)zwu?MKQI)bh-0OQ)T*AdA=nzAZBno;8$NbrkKMVO& zOMI^aM)dWVepF(AU~JU|SZ@m2t38pYR@Tw1ao%#q{|j|2&aic+xQ zc%ym{$-L;7baZbMO>{F7qVLnu15I=xy6}tJBsbJ0_H`()LMP#XKm>xs?f>K)@Tzkp zCGZG6#dotu9YGRqQxAeRWQx{eSZAP&MusG~r1GFqC6h7#?Z}2pGhx&qKj=&%T zPemZz6OB8BE@TwK;(Z+HgHUbX0iW+1E15qGn|NpRIj%EM#>c0;F?qF})ro8YP3Zjk z`_-=BI&dGrs@2|4WARw;`r#mavVN+d@d5#&&t?U>+?5zNcSCSN4_#Qm4B zi6B|lsMkz}AID0Di%o_nOz@WoMnm&bffTjmVgQFG0a?7Ki3m>(=z0`8SYW_(B$(W0 zUXJ({A}G2R zd_O)9nHvzL;Sn23!&vA~954^(&q)64$DaZGIXc$&6Y-{G?88d@$W8n>Hu2+de6V~u zko>X!-1Ge6*D%CJ!u$ebOm98Va9WVAM;Uv)9%Z;f0J6X76Yy2gZkAEzQve|A`~|+} zD08$PWgaD5Gr4#Pvd;E(MZmv-evmdVV*2YNk!i0Yh!_jkzaAB5e5gOPy!IAK>F zjjl?nL992uNE9a>mvJzu26ivLtLP|1Uo=kxUFQ@f`Q5%?I#t*m1BxF$lTTmtF%lvJ z<$Lf_iiFkCO#V#a&lvt>^XEMN6!GU+{`BR~rM!_@w?}7Xt{T2{M`!dz62#q*32f#& z#O+kKQAS8JR~lcYxO}*~zJIVq8ezo^nDp-1C<3O8@ZR zkfoxdMK$xB$~3|}^MrYJnVRRF#|G&#HQ(=CGEbZO_7V^++EHi>hP_tyCW;JY+2}G7 z!gbD9A)^dmQTr2KJ4hho{^T_(Jqi5v9Vb7~;J{x-gUeK%fBmRu?^=VKI!H6m@N%+? zp1q$fVWPerPG+<97IxTIE)CNV2P=1Nnn_Qk%L{3^MI%mRMRg;(aStu2WshZB5wUg!l39xLer8{ugcO$~h`F3=LQN zoDZMH8B1Pnc{V*lb8sK^RaNTiOawAl8h7adlhKk!CeRNVuu&`C66N^`Q=3M zkY5JFSBMJkHJeeK=cG$WyV_o@Ljr1Vgdi$Q&7{R2zD%_PO-XJ0T_$pU6J~l{58i6S zHNK$Qj(6GFw4+aAtT*jRLs9hg_|OxZ|6p5FY_HCHSY*eOryw@7U5Bq!reI_hnkFPV!`rGX3)I^^g^gmqQRRLDjQ%Eck`4o zT{@C*<-b(*k?50(ok;=>Cp@o$1V$3>^$FrBoh-HEG!zW94N1W5Lsb2Bk&!}u#z>U< z*#BATR0=|XfVMUPceA_8MS=9}6-39a`Ph)H70cNMV=0rDF*ye|@>!j!XsRSPce0-) z$@S>R%i$MDqAtZe&J^=b@aunX+{;OEjxGcNE!!Q?mONeG)BY!*fB-VZ&gs;BC}k(_ z?qy=@0iI_Lq=%b`i?N%)7-Y1pU`~7DwygI|cxf=FO@~7;ApI*Qyh8Rs39M=l)&j=u zW@qLE<_c`~jP~JA1%G<;XK3_$I{nz6Uvr>ADN@xZ#urfU7+;ENGCoL_|EQPEN2cO< z$;=l~PX@DKpH4Gbsa?%O3^`}C#9;ixcl6~%4#IxI68l5$A}q02)9T3ms=vT~@G-b( z2F8#eI|i}V1OC80i8eF1$?HD{bU{#3HS$;H?*$9w^Vk)~4V zBCX!lMmdWN3{=UI!P@~>gB_$g$9A@>ZK#k4Xm~;rAd%x;huQ zNKYZu1IT6Js0+@%uxw3CgFN*nPc>bg2P(KWVyTOn2aS5gc_ijn%sUkKXUHlifV7(8 zu9FJh3Wn1V0)mwl3<%a&bQ6Hk(w0wVD;iUo(uiE$PcBUB)t#LWd7h-{V{R7*0y)nuzR*%nB)#q!FR zkg;R~rb285*7;JIuh8VHF!^RkKJ=KlxLj58VK?7${SXbR+Dob$k!dq#BpoX2Hx^kZ z2zv618AalZIG=R}12F(;?1+RtzNv(#BVq8r8<9-2Y>Tq)3^q|d5${Z#jiH;StdSR z=g;@zpJx2*Rg{m5*C9rl}>yH$y#X5>zw61LmWaAGZ0ZR;F zn@|+Eizu8bRc^u7IrY^KocAouLI|vIFuHSMN_h~F;4m=HlNON@j zCp>h3xssXq{Coz7>$G;5RL#WaBZ+TQzmL}wpXb=jFns_%^>gfjifJNHQ6#rjkCQ>Qvbe@X`e{4w}+q^tD-{Gk1tI{O4v zh6|mJ>HIHoEFW!gVMk{t#<7j(D)Jv^ca7q9s0MM{)e>>rl<=SHJFUX&P0WhcpGc^A z->e`Bz1GAI(4qMhEk=kffH%!Z~thESjkVk5Bx4u2iE0jkW_`R4r)#p%lH2Zt;Ih ziVpP&!?6A>h3AARbS)-KcaN7$>IPXmY>o~gu7lZYPYH~LWFfZGd;`W6w_SzB#r_kx z(Px|FT)1)ryDjvun_j_MZ0N&`PfN?~Tw5 zIpuY2kT^jzHb}e#7;L34A$`b@lHT>*LePdGztap^_r1rEduygWn`wk0IiBpc z|EA1hD|a#S4IHJJ^DlA_&UZuE6WMt6IdSeBC)v;`Yt*Ez;LgJ-7I(4W<$X^JUL_UK zFXizuFzBOcWY7+EU63rN&3LsEh9e;0r!$H2ce4fOys^TUXWtRy%TpvC_E%jr^`)3o z+SNzeKBC@{?+*1Aza5$amPrWi%aRc6TqpLAAzMIJJs>#9I;+MJs}$fh#8?h&5cLQ% z!s2NOqdDSXNhsS3YehV<-Beh-ZR&kfxFUl*U0q2aC`LdPJV+GnYLF?;;Y@=H_m%Gs z)r;S*@42hI4h2u<;ejELb;%o~0`B5m%-B6y0iP_TrNWC#7*zFom6|>d(8-ru$(O&N z!y?~mzC4El2i$lXe~#nNA^hPflj!lR+>EnHAML6FE(<(OzB^PozomsINeK4WG9;Au zC}>!l1OK`bT$qBQalG8lc^-gbXa^2LJ`CxjAJErZAfP`Cr0#?STz^g??hf@c+~`xx z_yvCS1=(=V7lvFN{WoJiEc`)Oer6h(v#>Dd!AX+WewQB3btS7GM$ z9fsn|HaT!ue5YKQ=G51gYECWIocio*9;c>At~Qkgc}7l^^saCH6<){sYkt$5`s)^t zQ^o%1`j#+_aOxVvsjbjLVy44?6((|O6BU$OMrckQUlQZgI)*nx4twM1Gm;JMxkfEk z;M5x-)yR2?yCv@1qB*tPa4Kws*+2KvoZ4cM31eF(zLQ|#l_g-$IJ3SmTA1~@+hfe? zN_?AY0I#!~hoV#@rGXqJ(7pZTyF;b%8>BQ`#t%y5ZW3ac^(crMT zff!-dZXCe%r7$~3YhWpAn>30r>vsq=Bl`yNwyA(A)B=oXM4qlzAU!-8Dw|eOA?@c8 zL|>MgeIK#5tILs`CA^5)P=|BmyF-oRx9j_Un%B+X-Vg`*I1OlYc)W|7J(Pzwc@O{Rd?eDF46m?=p;nEO@;c4HwCGhpOW@sy19bAR(Q4 zybR@i4a(O1n}^~m3q>RUW{KXL$iEjLpXT2Q0-;?64WvT2Y@Ac&yF;A__x~mT20Z@d zf&kf97`l{9gb!E-G((qMhQ}bdBH#^~!gr4EhnF-j_td=np9YVYPele2?j?{%i`BFftvCA(3 z1GWgncJ%_~HX#3RyZ_r5&$-*F8f5an$3Gb7!3(ge>g|D9z~zm0alLe~9_`+JL37BV znnT_I!^HLo9xNH#)#;FcWD>J`qjiec^!^$-AL{n^VLN%3_2=bGBLm(&!X&%w5p2w3 z%XynOnouEi7p#J8%!@~9as1^OaVA-TX|KaoU)& zf5L*)NGNap`3q<#q-s$;u};>m_JLSngLTTlvr%=>75?}EKDN$g6OyIA zqA!$pjFgfbbJs=SnE6G7iTyL8M*g4n2R;ZGyY3H6u`Ycd7s0!4yR z8kQry2B993OtG~*z4$;>Ns=pWxEIqu1Jz~7f@=y;T%OI>D-X=k$|_*-ql>|wfhwCh zka8VUAY~I>v_!c#Hd+qs&M2Y`9r0H9>j+}f8;WVQUWMtrnn+%9{EZI71lGn zr8V#f^F43!Ny`D>BFVQnBf#`7ma!xsPRqU`L1e`l$O5w*9(b2~aNE^`t;D@t=kbM-~ui7t%sAK%oOvrKrVeB=I8 zeuEH}p>paV`M|=k+SdeEGx$&85MzC7Hy?G3`PO_;BC1d2gOU|%A8XCW47I|fpg$5hPBATT`IPI9fo(TmNemuhIC>5l6tkZA9)e;4?c{+hXivQ87*h`n}mV~7jSQi ztg|DbWgfYqge$67OOPE<>nyjZ7Le-+nKP}DTFWWHEK*;~?hLb>aWV?eM0#)E3RW2^ zSWUO6T4b2Ma-V?13|HeMZEPS7>m>>OEGu!ii@bWc5@pMhjygn&BrhxAV)HC%$S{xC zgQNgj0vvfJCP6#cd?*VtAA$+3a6)XwWPY7jq4}v2h4p+~SE%u-dS-IMZ04Z5gzFJl zSV=-U=wz0?Py*sZ@9j*DMTio6r!2{~<7FLLU2I5OHXL(gB?q7u;Z|p!| zr2+}TN_RYbI+>tRij&*O@=3guoC4<-9WT|)ZDhUmotj?$$vVE2-?@!!LWwW;;&XL; zg^q7xJnwO+7UYLXe9mW<@2TNFo@-qw*gcj~1nE|W~#tDyo4{EPhPxX~< zSAPzV@e$(^_~={AwPJjPyUT@cgbl$*Q;|KUor0CfQlxPqTuJ0sYgDx=2WjO}E8dUe zPDIbR(p$K%Tav)6J6{60d*&<k!-u5FydvQ?v$8J8N|Gf%T5EsuVYeI9%mDVUnl|b;{9>3ygGu**^y9q z@yE^vvI#DBW=)vMX&?$!`#VEr-7L)FpkpEsCU!mh`86RiVDv1>eb|;0DngEN0uK;=#$-L7+sp9M?^m(+g6j)9gz&GQv2DWY8w0; zW6H(tRAoAj9iW2R&kj)e5|8npVPNa+nC^M}T5NyDJ(w8o#^VeO=9jW@#+ivLVWwi7 zX<#j}Twg~xnJ44%E^lX8QN8fCFcUjLGgB#jtYXYMaVtD~g}LrPE(|a1JMy2$dU)qR zGNLH++0T0WC(=*S>GKg5)NA!fQ6_1@4)cX(92uN~_CnU#a*hu=BT|Z!x8vNdI#_2H zQgcoSx`qSilZb-kz}RSpCY!_T!1--&7C>*010QW?us57x;9Qum)0u%yy)4OPe;x+E zbvkt`96k6+0HDrAvY@lDTH@z7G2RvKLLsI}YCOq(LJ8kswME(%C;y0Z&uRklakT6d zv4LB7FlKf(uoq-eqJwu`$vUw&TY*1@+JX~CTe{wscQ!Bm1i>OK;Ti>}uqMD_hK|l&(Set=~6F7v-CBL*`1|lkZF(P&j|hu;tx(Y%2I!G z^c4EAnkl;sI@EKgkbB$J6XN1N9Jpv?Y4E$XzYbW{?GoRqZq{M!7j=#HFQWfq?O#Cu zB>KVO2S7QFkIu9o$N3#+PGih2lS*f1mdEJMRJlY8B*R7m5ev4g6EOBd#Rcy}sjSDi z!6w%FXnnDBCUrL!)k?-SMDM5{dyyD5+k;oxT^OE%V0#FJOfxun5&)#U66xa%BCH>D z&xh`c_a7Ek2wd!rS;*c4INd&yB{twLWY2^7+2KL%%@7&`^T8)k_Cjf%v!!H4g>B4| z)M0ilMro)Y65tf!Ia`r4WZr?y;Yc%pcT)w8JV+0@j2zRDx7Znmo2wv|!i;97?eLgg zszJQ8MEI_}RFC%=(Wb+_DtTL?q>MbVE8+)d0L_v7uQ#%lRy6KnaPKK+gG5;>n3x^n(SCko-NLxiVQ zx6)6}Ez)t@`HeRZyu2~aAE@J5IK;C#1$K<{eL6l%$CrBX`TQpQ%_j)%QXQY~#gh;u zezlIT(D4$zV^%5rUSMPEN_@*6M)o-} zi{*wrLNY9GIp;$M3A6r~jbL`GNec=9LfPJy>#G|Bd%G=4ER=Oveuo><_Xv*r_zvyH zIkIoa0~tw$xvBoS`|~@Lcj!N8wI2#7HwzT(m0P7AgP7v_OdqCkeff+rTZi5d1C4L$ z8m`aa$_D#m9ngLhZnqbo63`)dJG9j5)#RtHMjHnpD)6SDdHc$V7t;AoFfu`D&X z2l3^d0)kJf3}6lSAB=@)K(i)nQ@rmOy`Q41%&1jY4k5^%w>E>&bCUgTI=547X~A;T z0eU;dn88Q@xiOkQB0TolwC5xI_!RSbC$ z>`uIqN+gNvH=kh&(L^05Zi1-ix|x=KXePYFZ8wneg1qk=h9o^*kOeJUhCoqQ1a{E5 znun)69`Ca+3Io+fYeJAdM!SLJ;iQJEa-I=GeUCkzPQ!el^qk*bbfJWB#qvY+pDf@QhOPtYsgBy=Mo#v-u z04W72INO`jh!D~8Lw&ZBrS;UCEDZO=)K$H?9Sn>#>sXszCpMSrIH~lW)SFQ{UfOd{ z>djF)Ui!>TGH8@!cZ&M5w~jC6cf!P}+>75rZp3>-I=+HskE=ItOXQx^n-_G<9@Lxp zjOi+>$ZC6<*pxEjVE)L&Ca&JBA4(a}uHJ@=!jTMAql97qoemSee^&cz8NX2CvHw|z zEn=9h{UV@d(hqTyjhUjHALYefH|G2A$FmahZ8>{e_CEZmfegf5jr$*mDNuY46mcML z6TTtMb4CnIf{pTz(D1z~EAag`T5%Y#_$tn&AeV1^U5_u7mr49B>Qm|unSigJKb9fg zc$3BDYQ;cSHMd|{Qa&}Bp2s3jvAxoA(=Gwf6+ULzZ+uG9WdG8pkV zg3eR>aA}IS^pq7;V=EoTh`%b2DDbbS%z$~RT`fKYCB)r07(-g{DnWnfJ_3iMLMu9* z_sHls!rZi^H=yY_`B`{}ppx%{^UbjB(bv=>G@;kNvHh&(jSQT9lq(`;QeAVn)6L0; zHpxXzXnHkOCKyX7Gk8C?zs8Rc+{uimJ-)&#%_5wy#K#Z*nj(C_`h;Y-9e*WjaRHm>F}fwGU0}2+<^mh-80k_@&YQu=6CWjm%9n~QjbGjKCe8Kr(N@>e&jC z`vBfZtg~-{-ej=jJ|}$e{iJ(J?5&Zt;2^wq5wP5mP}r~Z(BgyBrhj?)$WxEwgLm>+ zmK}}UfP8XKFviAWyoFJMR~}4_O_8tn@{-4=3Qly!1XQ!c{v~n&^7GE~Vs|tq(HDAo zM{B$%#q)NmL4x$c<20P^FX`Q1gwe28Ewxr#_=$%- zaGT0`87Yy62qe_yGI{Qh0xjMQm?Hr5Tn{Eb&=3OiaRW0|!@SqPTuPX!k>dc9``KTA z`Toz2QvV-yZysNDasB@%z}2AOjSGrZG_BZzRU53aq#8|x=#7RpiVLpAoz{(Nuviy@ zNs#OHEoen;l}g=f-4#R>2#W-Fz+J20QkiR%AS&QSzR%a0dEeY1{e0T*_xI25J|4*| z?^({AIdkUBnKLt6?!9$P`S!ku?kJ3pLT#0bbXJ`ASmu3oP-@-Bsd-=jAT{t=nRfSe zwLcW3jD*{vd)ZMpKp?5~ygBAZeTKiTg#zcs3BXS(sMP-@+Kf~xWTZ&UNK-BN|mrlKC#am9YO)W8L-2}fOpjGKN7IFd7J z>v&tHM_tv#Uv;aRct~O6g3_vqyU6|w3A$bvCbt{Ys7-TEk!uyxV$4=D%fJPb$tyn< zqktbKn|0Y=a>n)jg};eMDJN1I_JfOhbSp^Bgc|ibC{<2WvT3QYAIK)Y!7RNsZ_wS- zm*S%nITWJD4Cw936z>CmzScy&pu4Xw+9p-LiWn{$NR`h^PB4*_rqeu@#ZSAw zz*7@JuQloIxYUdJ0k8zl`QmixUc{yNRx5%|F>3SxLb_Ohq%xQj#(+pl$-Cxn{*Oda zm~ZItyv6&mcyEXwnd0O;R?31(yx}_H+xpf3SFyjRzebENzK}m>cef(X?11s{J<{ox zBb|q}&dwxGoycQqBA?`pqeegkJCCTEcub)g-)VeFAMhL6Nk3+PZcL~_SQTl|3v`{H zj9%pKC{32VQiH)ep8feyoI!D7xYLrzkmmhuxpMsiq|gaR$rWcyDItkQT;ZY znLeuT2GvJec$ zhj6y3?rJ`Q^psbp{Pbq_SIUnGPXnN(qOr)vt5S_C*VA`gwx6l(gRi!DeQMzPs8{#Y zz(wij=CyTCzxjFU&MeolbcBrQx6{SkFyHT68t`qlf)6aoRxaP6z+Jl|@|H$!7_@~p zf^+EKXE#0z@Ae)duN!3TJvR=mTs9V5=DFhtZ*qRe>@;!0FR)n845(%rZaz!HDN3v# zjGUDIjvG1=p*TxI^LT>i$Rn`c1)QC=4xBEziNFBV4ep-fiwc@xfhApkfPz}4N&xBogXg;bI$ zWE4)CM?_qUdL}CSB{{+C;BD4-WN+syI0; zV}&QSk6Z9WUfFpqSWa#?P%V(OFZn~nGlHT$`m^JS&XeBr&NoVeM-ooauu(M3DDg_e zX~p7Si4spoR)Tw#f)DOq=BR=^BG3|ub+9TfW^S{a^FER|w9lcQO21Yiw1i~mV4LoV zcvUJhs>m%rwx~cY(fWQss`1m2wdo}_<~gU^f$HVaN3josg=<{m}c1UT;=}6z{v%+XVB5yXMSMB zx8QLjKIC?doSy*yU&q)yEd5_TkZE1ho>^%FJn)G+}{0IxD4_83BBSHKF zKM$092F->nx1ws1C~s?UJ{1NoNm7_n(qUXBg@ap{0*qZVzUT`{mpo z!dBGh651yc*pX)Lx}#Ldc9G~0+>f@WxZF*xYkB(tX=+bcawoG}t|Vvy#O$h0tU5_I z@1Eq>otxs@SN;sBa}4KVYV-`}?Y@2(jNB(CD`W~|;F|%hn9arv`~>pCXkO~g0AP}& z(SzaPZtf6|UG^Q?Q}FOg6V?J}e&0TN^h_Mue^>W=7TU=f_%t{^0UJVMFPfAc&`D43 zggWuB_8PHlcQQ|W@i@9WlSrH4HZZ!~SVCa3k!HX?&zSC6^L2xKYa}xzDlYQ`wsXud z^O)Mnmgs9I~zTD|Mcr5)gl&fiuH_E>yEmPe;F9lOfb;(I> zM8vgtw%n5fz}DY-!IodJqAP7^7@>TlaYw~NsF+5~p%xl3?Xke0i}k>;vFLZLqQr$% zWRuK`dG+MAW)TIr36M$leiCrK?6ZumSvwf9m7VsiRxc~v1UR<8k+#zPDsx|n*GaH& zpGvx_hRZZ1ER;7nqk0HR1?Aah3y2NX%2nHn3$L8Dxi4}6MY{bc&uvWtK4ePWA6S|p zD5rFpeWe?gxg!xPJu1D@qrQTYhxYeHbKi1LU-Zu?8ctWRWQT%T&-mhBeg@VURlK(k zSJzJ7hFYFuf)_Y1BTZQoqTcKOE`>RF!BAZ(3 zPjwX{btbz3kjndgj8w)v0#lDhP1D5i*S!PH{}7t5`J4%cd4(DbT8KBC@%pFmgQcL(tWWry?+Gf`;NCaax$ zp5$$}cj7Nzg;(j7PnO^VU_k)-%JZF`!2koV&bIygzHo7Lp;UyZxrCIS!mK*x$N z6UhmMYCB2*Gyv;9O25&#pa*J!ElGRpgu;S9%t=N5IL*P)zWWE=Lg%@fQXLAZ6K-0l z-A#Z?*LL@x8{2qD?7P!0;*#9nKZfK|b7HN7( z-OBZ9^V)Y^_YNpEj6O-z4WUoriShY9{`AM=zw-!f5q5HjG`zMA2z;L>d|BsE#rUs% zR}445&-kE;BmWMQyl!Y~^jJqz745sL&{ruUV%fndC0C7zhjxd?71nkqp%7RD0{i?y zF9r`4l;ETDz2LLgoIY@MdR6+>^jn23(OBtb_&cDyYT^Mq@P>%tsK*ZDHyDlbr8aTtiD zG*nmn15}_afM*!(L|=K6B|yvGL)j6qVwKpXRZN9b65xyZf_XqHvB0_lvPOoQjh%&> zjUmx-#?G$x=f1jD?y9!T<7ynW+4!i;4~tc2IF*Mk${3v{c2h@n4_^)CXtwODb&-@+ z|4RD24J6N9y*4?{+iG8>8KK&gSALDQQtuD>T9lNJrM}!Han6YERgK>!l2=YwqoY2n zx7xAbu+w_n#`DV^E2KXfzfe<7-lD+IYseIR=Iu~0*?mK+B_e!otw(?5vcXsEZoL!* z1-S3)UJY?2?vi7`Qk2;DCz@q=`SH{G{n;hJU+LK0i3OcxlgwYdu#;?B2?U*6JkJz> z3uwMd0u}e4k6}(rHt`S;2EPo&lcz6qY;VhhkzmXIxIk9 zeM~fBv+VN*UK0SZJRy8R-glwDF6i^zBrWn7>8nZT3BSvbYZiC_FcJXn@BmCQtiVsB z5u0aExB55FZj)brRI%CI9SX8v0IAJaQN@l5f7luBrtmAB;kG%17j}kUQTVYCmS{Q{ zqV%F^pObF=%*&S0M=ASs$)>MKD9KcNb=gk|K#32kgbVQ79F)BPynEjxKq^ZsmLxgf zQThr~D99d`^IfH{@TG$6eu^{SMZ`g6|3K()H)wE16(gTRR^LLbBdRz`{tZ3wvoqWq znWSxqM4P9=P(+pJIjXx?F;e%x<8BQfN4P1$$E#t%SLepd*I2O>^7Mu%rTtl$?_Xru z-EPu9QHx#XvrttXL3;l(-CV&iUjJ@Tl3O~($H|Qyi9cM(xPFX{0FF$b)?=29Y>3U% z3qx_(>>UbN^yb3*Z4|EADBORe@J<_rw^5jKca(c(vb`l0$zWuCa_d8R7xmDRRQg!- zI>(kIx88gK`huuz{T8gG)8Dz0j&{uD#`K!Wa4!h!a4qfabGs|F&-L#SwJb!f+Mpcu zFKQ+XQE&UGCyAOHq89t8d(;b2+5N=2=|r7`5=Q&#o!An8(0+9$F?)3X0#2AleVSE9 zRCd|?Si{t|HS};ycQ)Bg&M*}Ri=6Lxtx9>_H{wqA;auxj_N@U2QXAXyfANbCcouTpe9(NDgC{NYB5pzy9Cu zk6-;wyY##9{`hwgu(dB`{NUPck0*FbZbvEga?d;yZurbwxbr+ zpMfbg8#tVJD}Sk;MT(B6>qs9*)HB27Y9qb=XQ?zVtRBuZj(UUNqRr_7-!_BG^5y5j z6oE_ZmgMNQ{2fgo)WS=|+ol@7F09|#J#Mo*ae7*a%!_)c_x5l5%bAmtGlmpPqVpfy z=%00Mjgvb`Ab#0QcMMD43Xsd{6X@^i$JPvFsd+k&HaC8o{KGFO4^QEkAG5?Sn7Dau zhA+g`rcWz6cu|j^s1?PUeuCYG_Pal5+jTMuz!a(&c6r=9X`ie)T9GnBh9E+|FGc=3 zdL=Hf?S7cegheo$zd>}ozgBfrZFE*Ki^0ZESSj=5464Pe!JOdLTI)+U7UGty$krJT zSFcb0;g{M<9MeBJ}Ze6;-_aG$60)*2Nfw@fELU4So=|ORD@`9&gY5f@jBp_lv68 zqVTrjT>oZvsww|x{RsBBl_X{JJ`(m-yfl-x=F@mG_`i16^&oyX@K2 z6B<1HF(og){7FXC`&G(+(V1o-M?$av(xu|FB3Jcy3L z{^ZP1#Q&51$qz%B!Tw~MP-a*Ald7Xpo-wI;bF0kxdKPXBPbe)MklT@D*jB>Mcf~Lz zRrpS-ye-+ZmLcWm&>-1#u?=}t);5rjhOuo7R0GK+E1Vt* zI>HL7f1IdeLezmi>JFlQ5u$$Tqpl@t-w@T;qLNL2RFzR#{}5eh(N)RopU$4i7vEl( zVNmyb`7PYO$TT3HHFqQ+xesTR%c7)>g_TeQV-J1qJH5H;yK)mTrBp1Tfb%M(tUt_C;&1?r z>QA*+8yx9sG@Iwrt2`wrHVrhrG&6lHy?>e`9|4%=ivUm0qlVY>79clg=Z*kH>DH`W zVv74u3opn%6XG}E8h@@jD&7k?_K_VpZDu0RUU!{^-VV-kp2(teH9J5HEi>=iQY%=q zS4=itOJwJ2_M6W%S+}|iC77k#<86VhDc$W#aqeqN(9X8NNaQZ$`>-w0Wwrbdm1*VI zpVL|Pt)c84RCd(cJ>I!5@Z`g`FYwF{P=<{Cx?M{u*8-h%k^ipE$$!Zv+2-c91#Izk zATi38-YDDO^RtclUN#vnx@rdhWQ}9VTi+r?ehH!fs6#h?wF{?iyU%SDj+`s0(A|JU z!`>^pYpBlTMB#yVhEMEIr|-!|XbWOZb%8rqqK|2MZ16_CpD$9+jN&WTIHh5MupU*@JUEwQLFlL$}%p17~jx&IOwQC;JtH!sywTzTdwo{mkAQmEL>f(*L>n z|BBzER{C~UL5)b4YUd##YHy3mZ|8mAZn~Y%ZwyHz3A>>E>rFsnHcol%{MElH{eg{3 z-+klKPv2DOkDAh=fldbC~NHo>#3An_H2Z=Zbdk!1l4K z=c1~{4eU9krJ-!xz&^*H!hW;kuY^-`6kE0rXH4(WPqEpH|TUWSR*(){iy&p+(829#kJ|%4->=?rclfqkmO$#=@F;pY*CO z{jjR%LUhJpKvziO0|Ph9H~w3Xf!hcSO}|grH{&kC8)Kl$KG8a;DQ^Ea=Jy$s%J}cw zuN~t$nbVFOvNJ3K_i^MKr55t~CPY$wLnIW^ymjDFq|aktXk*u^wy*nK`4=N{b&B;*kmwqqNvF%TuHpR(qxT*tl>k z+r)W`PEUu?=tTAan6TV^L4QmS(df;x+%(uFyqz&?PcPBv&9gnaeBa!3uSQqdkKqp9 zw}L!#=*xnv?l1Pf=M`tV&H0KmpZ3=0^iaA76lXrYoz4pWf*FV)JHyP77qdqmp}p5m zSNG4F9NuX!&Ld5JHaC6H_)kpBoY_hn_K@W!ti_AmF3j>~E$;1su*J?Z6(8_-GZoiB ztaFbkCHCTaJ(g|$u6E#G``Fmjlbr$inzE} zH}S7?x38knd4mD*HQDqXh>1tTfgfspu+AOd1|%AEUW3kXi+8MANUhCyBD^&<606@{ zlWAQkvXYE_NPspB*79+@b>&vJNznQ}b+vz~Mr+Bx3F=xFKGx|Y#?68BJiSiW$MFl* z1@Nwz`p_3jxZjk$bK6o+m#F`}eQ;&=Ajk|dIQuckpbuO?-9P5no(#?i?zy;m3KQ8Y z)?iDTM+%%85Cas9i}=H5y^J}4_!Yp1>ng>+&;%ggjR5EZHzcdJC$1jRpS{*pYg7Nl zFa!PMeaawc2tOT<1hi9b_>GP#hjHZ!`Ij_Iqo)gg{^E>8Rd`ooxl ze?3MEl(DLiLoqH@$on^68AOM9h%zHecdRCP;GCA4SnBTa z8Mn6h-dp(3aGaV_eW#d8im7EU(yGlQrZHIxxXF~KpZqs@FZ!w$G*H?f&m_i%bkpK* zq|@fDexw^Ea|1sJ6T?E%hx}J7a%SvrY^hYz2EvrOkKhZqoTw;zs70=yVfwn?n${+< z?D+niSUSImN*D84zhP*8H_Ew!Xu(^g8kP`1OIKUy>U-MZDA`%bQYTf@_#LMnbdNDU z?DW2*Uzl+=pBRiuGL%r8zOVlqlrRY6bX2SZFsr%G?~!MCX^Rg5lD<|;ySsLs`s;xH z3_7iiG#Kk@;)R4f#pEcMRbu%VpzUrmTgO2qM>-h}CdLfY`J|#6c2F@{8zs7m z4&}3E6?)kw7G{sRSr)#HfLfAY*b_GQb{1CuC|G{#SP@Bh1}?8p?@)Z#zPr{(<@eDs z>dt&j16a7$as{oh+2;{0{xXTvj!{KAu#=bGO}BZ=h);wkC5NX%=susSGh%P)TY5B5 zs>Vo)2&PRNC?_gyqU|WkkB3TJ$7+(hQ$7*^GJ65K!G2;KX`t;O(74#xdOydVs(u51 z!VYT8IVp8_winaTJLp$|1E3Qw|3Z_4zYtEO%s5Qv%RT#?{6U$ef^%c z#o3|Q@n07(87G_8C?It==Kb(g~JK1cf;-kcsDl0vFaB@b$#35x`*GiXddhMv} z)i=G|{>%qf_wLmF+P1s1wN2Xn^3pa?1BNYa5BmMvvin26YkfZ5X|dV%yBEw6JQ#+# znybG8B|~&rVr8FDURm1%e*U2C^&$TeKK~Tb-L+j_{+^xruO!~Xo;{oP&HWXSxQjo; zmy+*%e0j(o1YVRpW-sRzcZXeNerSFKJYr5gw3urrAn_U6to=?%b(JV9{?2hP#|Ev zKpB&PyEzfyE}`O5gS&9tb_Q_SjU+W|b9d`+WdTE})q_6F3Cbmgzy1t9Xl}&NSQ=SC zR~YuQpB`$9I|Tjg8oXUPJk}32elpn2W66jS=VdhQKs9%3L{o%E*oE&z%;VbKEi=?D zD0Wvd-hF=-t3OL>GyUOlQd7nq>jBF!;MHi3y7pkISlLl$`cdpsIP=}^uKva6f_reR zFH*}ogA$280cN>h1ouPSwzV-np;fz_hVzL}Yzd}y2_1Iv;SxGcXH~8I6VU$3!>DYF z*EDXY$cP)pcC&f}w_#4Ut5(`w_C5Hl-k-B4uH0J|Onm-XOyFCu=_K&0+vv!?(N{*d z4U92&bE8D^c6XuHoydQFj3g&@H;58DQz1m3Z2BA&sFqY_y4oP(9!*V==IZq%l%_)y&>t3BfYzoqU@_W4=(hlaSP03_v>QxO{~$F}qH9jlt}2&sb~@KeH^D!`?p#YRd37 z$AJ+f5^7VF_}#~S3+ia%dAM}(1vqYtTQ+oz0At6yN=wKr3Ok18G=9$Qm0BF5U{s94^9L(*mk3}UeUmbViimZHWq*T0*&mDb@=c%(9 zO#)%MrqQUn1?BuqPu9G=>N7^P6OCM5ExD63Jn445&%w_}j0bWFS^rojh`BF_Z4?ctWRq5bZvVLWCTX!q zH}wsrTjzfCZbyfaL-u+;#N)XW(!)sS&i$w7^O0tQ%yd73E@uP+WVPJXU$x)5F@7+z2%nig+yeG6NV}(JDw`j~XT2z}JGg-QeDiBH{Pi<31SR%$p zbW#gFl1iWSkP_`oBJLi7b3;x;Q8&luXr5!Lq4ft4<$iJAT1w(FXY3HQt=(cQ{FIdf z;#%_o)-&(%mM55$)*pqYYJ9So|ObnU-EW`gr13u`NTzJzS-Z@X6_ea+O{$NJ1ldqzvALi zAg;kkVwmn=Ew?6La9C&SK63BBZDQ+gwLi6w|E`4(_!iz>n{K1*;Wr-sok~E1q6{@K#JOSL;K@o}Q#ph7^vCrl+cT zpshfT$1EhU?U$gA9_Ivn{b5pnWoia^JPBj&i#LUTb@L#J#bAx3LvbS24B z8nM3vtJ#I1)bM9psI`Hgk3+()jYgI*Uc|epT=|)KG#XBQOCyJozF}B&Zlx@XqN=)7 zYn3ExI<=}2AkX`vf5D=vI;ebXUw4G*cw|?TYuj_l7qE1{a94$T71YhneFDsS;Q58c2oy^`)`0vM{?d0Qq%AMfw8<)`=_%F^Dt9I!to(FL*;$ z9N8jvx9Rd!+QzNx%SRjX*Uut$o_aE_rMU2-R(oz-(b8TyDF4-e2A|IZX7NN z;e&&_dtTU&gQ{Z(wFH|0nN*tS`a$^5tcMo{dg%MQD?OOiP zjt=+!7wTW7mwAO=Z01yBkrwVHHnFThu$suGVtOkhb67 z6+Xul37UIIs^20WnvtvH57Xq5s6+`CE0&)=wBXicwj!+n;ck>?Dg09N(rO`Mu)1_Y ziB9jNvjSzc($N)_sd?{_BEVL-ScyyHR}O%CfcVi{uc_Z|@#inlV69MQ8F@S`8L04^ zRQWf_rZd1BvmE;1_C{bdUo0( zt*7#&9ULjmpAKWVldbMrsc=xe=~&&Rq>=t@aEhxRN=4aqZX!E&sz6zwslm1JVGAo( zJ2PIM3b3P{8jx((9$qleP`;ro6)&wq7s<6iQR2+6gU~Wl?E+J=DzG29yeiP2hcRtn zcpeE{J@6{**c5`&Ifmv!0X*Re8lxn^`w>!*S~M+u zk6)2dP~R8vy(Y7{Mj^HJDg^jmfy`6ouO=Jo1t#ZtCMyG-TAaPb#H32AEgV!aDo|-- zRa=y})@CrV;$~&bBnDUcb;HG>s$30F)AnH`mDbW3m8oc7Y*W{{cVAXXp0+BG%c6e< zguC`PKkION)SG5$w}TM{)JhZ9bt3_}A0W5%bHwW~F4w}-ofV7U2V=w6eNBqJn&<-Q zN$QvK3HLq(04pZzm=lvT7@4(!^aqjNb6KW=a*E3^&N9Vo=NBf2u4{b1TXN`28V@z) zEn~8kO>4(gH9a$C7iIBO%ecw@kuptmNM&H!*iJKBj8b)ljYZwMCjGTd+5XEKTf?|)+zC~_}r6Q5XJl~7i7mNye z7zuyWLsiDB9swf|`fec0jU#2Z4K(1Q3u5v=%~(L< z(#invF-AFwUNpd#Q-=`#UIQ-ry&nRe^y`*rH1@gnJwYVWpM;j${f@aITVSPutxN$d zv{&Qe!t9?-rqK$&m<)qjTp`k?&FvK(D=cEQ#3j=Ktnv}da}n?Oh!=Aa&-;kk7V&iU z748?*>^(oYj|BJ2;1=%Zzqg0*%HUoX+^cZC{g{7mI{l^DjE?_AZ$I0!V|1JjXSUF< z%zr21NHDBTYizH4UR~I);Q*+C{W=`K#n_k3`q@Qt+Ahf)Zo7m7;&@nfB?bHK#S&s! z20Kl_rEv=UgY*2Av7Z^NMJ1=N?qP2Jq@B6Ui76M=7IwHx>E>Fy&(6=^07i!luE~sZ zI$vrtLLu85Lk5KH#S&LzlraR$`?51D)S}^R*)UrCjt-ZyrP9}1rQGU=-|yz(A0@w< zgTGRKD?F1JB(wnE3gFdGe$CPPF+h>;*npKkY6=rIIxiimC!OXH{p4Toz2?`5&`90l+b^{Au$_HweZoCFxQ9 zPn=VDW>LdX*wg*sN=wu!^h?!j{uQi)IQA_v`gw^$ET&k5ze_Z9=WesOi`X!qi?z%qWJ21(AGT9=;Wo&TWz!QuFN+3QS=niX$+ zT}|)=0-HNgQ)#A-P4Txf2ls7UF}-ndQTpJ%u0?}8N*wp8kixWl7U1*%9Bo*fpzdi9 zJSHDV;RRWx}*TV~KQG0eYsxL<^aIpAUvHa%Dl&FO4>2B9T{frTdd6<4wWj22y({Yb)|v zAqhMZOs9nwuphvCb0nmu@$_tLB(mKE%xb~d8P@5%W@zaj^ZAG$M!d345k?7DJj>$# zK@#Qki=3PLB;b$5T4LcZJpT4{Yo2BYYOwq1GlIL%w|SFEJDLjYW?V5Z?79=q5o-D! z1yGIq_ZW8&WjM-^nDle^fG=a^;`R0hE`&+|32n$@;xT<0k98Wlv=HlK|;$p z&S@gXP{ZuCN&+Phb}y-wBz~O4HbJ`C#I!wUdb5h-G{^1PE-|6sNy-zIec9yEbHg%a zY?Tr#W8UTN=UhwM)~q?cw9caP%$HXG0mi@yj0L_T)){h$XK(gN!7)iwQUu366Z(_u^si(2G-k z=LuYk<9w5{cO-m_Untn~?0RhJ-Xu8b7#Y=63_qmq&}7qZSf(Z?l}i$?ShD4kExDft zF+F+BO0rkYWc>%Az2`hhy%j(1-ne7^k5U!$em3uC$>zh!Ql+(y5{zBiSBEQn`F@3u z#M;;H2XqG@lDeNv-hzbp*#x4?h}NmbsO%*)?ve>pbS-j%R4!9*;EOtbgIgm)=Id3j z;4(C^q~QJFvrr`a4coGtgTlTi*@K4hWS^bFTw|;0bll;}PR=2?LC|EO;}68O!()n= zS$nxL+8W~X3Yw&wO5{=}8VOz`taG)6Yr1fNF?&`8KK>1&glKEGD2xdNIRMpX(TTG51z!;#T6~ z+Q2kX(E^%cT3@m{#_p>@7ACJSD=DLEHExuc{B!@^3O1X^6msp6nrgQ5GfG{FsdTB_ z!{WbrKldb0oSqBhaLx53^?cyb zr~Lxr67VOyU1)eLdn{z?(V6KuWfJ)5RxXsbJ-qWfIMe$uQ-LU6Y_wG+V^7IOMvKPkXmR?kQG2eT1 zmOJ|eU+%A?p$$E=hmo*zy_g%-vy`af;NgdiNH+b%>OJJ>3(pv{P1VdIYNo*H+%lK# zZC{2Ta@6nu5j&m*0ix^FbW8(Cr&eU&V`~HzZrN`YK|dU!9%Y_@ZX|>TBdyf_*Bh18 zS1V1#k|ev7j4^-7v87^Fe+^%P9y12(_2-GdC>O6&pgrA;1-4gkzl!{&U*!}7ot9rX z(kn0g5CWA@!iq9+erdSbY3rdg$oINVbWwiN$EsP7N?QiS@Ht-bovmcWv*M_EB>$dcmJ&KLIYu9mBlNj>$}F zWHGt-CA(&Jvh#k6NF~i+C7?>t#K|xN^gsaRrdjwp(_pGb#(w}+SzA7jXYDv;zf|P1 zi`gkiv7GMJ-(50K#r7g0F<6sKs2w$3ElPO3xFm*bm9F^6a;puhhJgMC;p;s>i9};Y^+bcG^%R@Ac5Mrf)HhLJ_ksP>g zpfF50ZGW!*m|>YSpc(G%<$mhkI7 z#cXgrsBS9K&YUd!?$xPw_yMTq{K!!s=XEoBM~WA3Xh2byG)gm+O5<#TgffMdA9 zk(@YHsA7ITJ1xAV(FD#&cx!S>@cqAGzD38}qB_bQia1dOcV0tDu0d^R>A-`$Y8 zl@WE=Ia;)yBY{VKMgb#Lz_9XF^~X&11M@D#Lx{mItHZ$5(KRmUKe|Y7$obLC(5#&s zhUQ9?>?N+>EC`MvIkJ%A#ypZLr-m`Cz51NPJUSUZ_|)>i2Y&<~JnN@gTy!6|Jydhj zGl-(yfy2GY15j?ekqDqr@O^-7&3D_JKn$lDy6zWIEa?IJbfY2yj+_-q(tjSnlh_SC>t z?q!l>&(ZLVD%MWJa`QGVLg2Y0b`QKaxCi2DU>%RE@uc+tw{KJ(!}eC^iG}f>tf!-g zVXtqC0lQi+eJI4RWYDsjb)VH_a%+Wnbr4ntwVCaf4AWlHJ|M3q)2$}`G8B!K*^5|n zhHLb8;FC6=YSQy{QfILWvxEhv9+%quml6_QP#+E6yZwAGCk$75WNq*+4b zLs~p?4??X5G$hG=@+bBmExI`{C$B&tkTDmCuq<1lMMk>S)~4`0^rX9#xaWwJeD%4J z*wYZ|7+x=i&+@sBIYmqrN`tdD^`8bgh(1%e-eC0wS|WY!WFoYE+w_VeQ089woVD@l z{x|W(Umo6GGjOrn*^8zx>>(Nn8yu0uU)@lhlYPBCd&8b2ie*oeU$MZ~L}S8fEcIGI zM6y(3WhQaOKyo4VK19W}QN`gS;eK&u_kztXi5mv^G%HABqGKkOd~3HGNkoYkdyiu3 zGP$;PJ3O(#D@ZMNsM03B{t0D)lu?wGlXF$D8~ub(%dS9FLyQIXmK^06lVy9!4`BuWX#|orrFQ}b~ zDiOo~MvGsFs{V6Yte$U0ul+H(I%#q4N%^!`r3G&$u|-HDlKFq7#q)NjzD?5Nhcj}t z_zc$LVZF7>m8>$(@3Ov${BEW2GZH$;{u+tj>;PJ_d*O9Ey^C=s7{n^}X;oDU*tF4h zWrLx;7{aN7Fu33TeeV_~z!95yB!cee&B_uKdHq>fG& zwFgXqkDu@6KdumZyDZNCdlq%9%GxAZyzp3#EFO70M;4nm3yY?X+jE9zQD1--(Zna_ zu5)+LgV{PQh|tjOv5VKx9cu1^?7qRR3Gv$m_a`C#z~BxH?vBCzxw%hg4-fACA$~w` zD?)r_a3A5OTGj947i4cF+-12GzyDhsjYH>`itL3kCi$TH<6z>;()=-1#hSk`o7bkt zv5pv566^astK)?@X$n|6q?_&C!t;+ zR!Q`t<}VmNydRL+4BR%aCtwCtLwc%zXDf^xJLgoo+ueP&rFkPxGnX_Cvn_x9X*|wp z21!wKour-C<`fROAi}a_v+g^>TZK{B$gAr}r;g9KKyW3Xl z9+>EsxV4$-R<}_>d9)dc1& zk0@Jasv#z7ZV?8fDbsLToAqBmyV$sSu|BaQlJ<#Oo0kw_9h7cfOqaSMuFwUL=E*V_ z2b+Um=-?njvblk9X1WR!j(&+Jm0Y*{)K01EEOqZaJv1gHbKo~B0$}%wHO87a&?oDoim@H%D_vD! zj*{P_qV6QQtd6a%E8SX|gG7A_$%3&Wk1AO5DDkhS1pJhVWT}n%J+DwyF&&d>1T`z! zJ%w&WD1J;jlFV#_^B%=zrmKbOvp<{qB(cvjn6!y*{ky5d5^wgC=+-ScX*-4CT|!u9 zy5I{4>j1MkgpC#4!_01F5vg00T0^|q8gx4J%=@z?z6_y6ls6|=fZNuZ7)`Tm9>>uV z6}gAyoKm0$zaFH?(bN^HH!8c3 zErwdza!sAALI(RnQZMJLhwNw-2F?=@SLR0a7+ME-X=5E1vA^ z(^v2dg6Dml%?>TzZ?He+{np-lyx$OWi}xEcCwspdf+{wPs%Vve~-&yEFtVlwk+53H=4{KRLlm4zkrG@`Dh4%D?-iKye82v$K zq33rNdVMJL#8Bu_a{a85Dbk!Wgx(vPu}RnJu}KB#kOBN|RpW|6cg0;cqxAH!Yesp< zT5mW>_?pCG_XstuvDMr<_c3lFl=#~Vo*}_P z#4qZ91y8EpQ9P-~xP#q=cWWRe?)=>js4}%8{J|-GL3j}~b|m2XP5Mk05E@Gf2|_xzQXkSU%DS7gYZho8DJN>4>_ZJcWRXZUP!r!QGTl7Whbk>) zG)*B+xcE?s90XJx)wRe#VI|T$Di@>r6f-dwqdEoFLn7MfL7{!B3Q9MxCZ@Lh^JLTO z?2Z9Ji_H)=zY&_|L*kx-&W8%fNa!IS5+^3K#D^yP&`2fuA6sRhWS^%6ykDD{UZf0R z{<-X4`Ezo@i+|8~3lB)6-yDrX{V-OvM;5zn@5$xz4fwnm<9v&F#_Pg>!_?Pva-Qu|L; z2PKmBD2giiW)l#iwK(9X zcUxoCCsoiyV z3SUzMF+J)VYnj|weTjPi{$Udh20ZFD=T|K5!XEvTy$s$TZ5PBgGbxRl3xtWxbb;*U zF^A8+LhsSO6}~pH920A!75ezNK4zvXA<&sDafgr6XW?OrIzJP6`7{e3zU~nN?uCcs zlwC#0#20tze%?%KUr!lU)&TFfs&@8%gQ?j3)BTv4qF&UTc05B6S2SA4qRd^@;#Vu5 zF~Mf0D^(2Rk|DNY*?pp)txmDdvFUV1J-z9N2{>@C-|1U%tCkO;fqyc;m&41AG&o!* z1Vp{B65_+CiV`m=l#V6}6H%Z02{9;hQ%SOEIiy54+`LWbhLq*CO1l z0Wt96PKG=6erx?bpwlh2m4;`yPkX<3j(fuUTjamr`yZ13Z{9ym{-Y@;J6R{(B0u;3 z?-LU8qee5(x(9@Wb#Apa)uhjApatcsQv>b>=u#>6R+UlN{E)%p+cIqDGZ>R3!xDu1j#blhrfndZqd`bVxU$K;n`oazoM!|Nje2ibK#nIT#0`GEWf zeUy4oeK5@j1uorVT@m>x)ee2r|3->`AQnWm7=SFygs6K+GK`0mPvG0o%#_v25%sR= z5CQag15iERX1dvVJEMjdiK{xoD*=vVu2sqK^4o}}qaM@O;Z;W;N$y6=EqIP#-R1_~ z4|*CGR%*b_{)ZYh+n{>b`wi|p@vBKweVkG4weo|Aw2w11UFQ9U-QRovV(M{cc)w8L zj`M!&-eKM^jJYcBH_|Edej(Ql^!}Oh_w)W1`M37|hvZLq|1|lZxCh>J3lkee9?k7v z;DtXeV7$6&HH;K;-($wBg9ytl3vRi&PiIr+wq}1F;`hQ;xrYV!g5X{h+&>2Q z^5Fh5xCaJzm*CzU-0cEfzuU;YI($Dq#HT~}un@i`gl`OPT;H`Jd|q(R4DLS@9_~v* z_|g!L-H{=@Hn=B+bg_F%2%iz$xctpRcvNs>e4iS^u^Yp&dx$?hxQjx2;__#N@UMeA zJh(S(BP)p(w!Mn(6 zR?OI3OoM#H+?0z^9SluD7xIh!$y=MAt+f}9Eqq&>xi-kBNjH~}%iY6dpSGH%GrB@@ z{r7gVjxy=69Biz>B(OSu#jYI+6Z;y%0bmiK?!c5D=;aK%tu~qY>`Z9?rbD@8L;HTU={vP2=pF(#+NAZhX^&c= zZ?~mZWzk-HB4}{g2mAT9`bj+YM9`O&!ODM=5GyYnhgxpBRnM&S@?8LyeoF;K6+`ZV zmp^=p8pHe5kPlrykbA}TPE}Ab{%NYsd}=l4W0Or^0lfRwCu=&g?f5$NQ<-Kd9s^Bf z?*=77|5)}z1L;8Ouq7#{>`j~5XI>AW`z0rPbnl{TyH0a`qTeyG9`d@{SP%K^ZLyB; z%qLJE9#PKn^t9<3VHDZdJ8B*;=A;i$&?_*wvPBnw@orJ#7*&P3Q#Z0*a4+SWrgJjB zcvgGwb}(`5EzD|b27iWO_lJRqVq%Ls+xPCAKdUR&xw~xjGF$Ay{l!*CvqcQ<8jIgp z!)fRL8!ss>s6PeVA32R0cUMB`N$g-lZ$FDZf(p53e+H^c_*S*Jeg?+N`2s zGde0=snos5WJ@~@Dj|ck8fcE9xf+%r`s5!b{H*!FV z>M{vUDJ{~%`0!fM2~$LZpD@IG?}nH`Zyj(+=%e9CbTtqH(#QqRbJ{2>8$!svavVeR zH<0fLw@=6{^W_0+31?HHX4{ zey@3HwbV*BsKecN122ihb5D8~TPgLKd$;xBh!=QJ658lH9oh(6v|N$G+wUhQ{ecKnFB;?Cl)r(|LN#Yhmukw-&YNJxex0hFh#HC;X~i|J?=g;-#EcCG zKA0QS%iTg-(MS)!#XYu$tk5pc11EYt{32VH_)d6sim+rHy9NW`RM(ym4v7)Agpr#4 zvAV2Jh>+_17DI;YAXt5_h*WN;AxC1JRHuswwyD8#Z-g!)n8%>@WgKcCtYkRPvAOYX zzJ#`94@M66L|#Sg|NV?xBx#D!fHgT%PeutC_YR^w%^7t)w&ap8B45J%JpN|ic}+&& zGgFMpgBX&ItfKUkFrmr#1~q|dFx|vjx9iCwSG)huJ^Cj_f27%9{b^d)PnYZgq51S$ z%i5IiHuD>K6zk6SbE;3V)=i$QPnH1&RH+oR|6+B@57DH|vAh(gg<}{zZg)zu_oEO? z1(L}gC4f|u*-YD|-{Tgv)n?4du15;Q^L>%BLq@W`v}M;B3?&}<|0(n7tK=Iop8*yZ zGoMl)%40r*eHE(7_kYZMLSa6Cvt?v{49VaMKQj)>Re zqadhGdG-HOddktqO1JEUPGUOqTI!CPSJU63sUYZ@a>thZH%L_TdqHrlw(+p41sS6& zeXc?+vK@oJ8bPReOp%E3{$dzXXHlAUk5m~^;x{*o-SsZRL4Is^Z~ujIqD1|Je*UKK z3V@>iRQPD$Z+0^=@|ZA%8@ac;o)nZD7wGiXxz@;JxE_?Ljqj+>>wjVPhB7r>zlz@_ z%5^2^I(II$sn#=8E2|U{xWu4GFr7kH)({#N)hDp_{jz>1JFlF(Z|D)`aNRc~L*OiU z)aVNR6?fr5f+IHq-DD19Q)v}9cYgWjTz%CO&*}ejDy<)~afLt7`K(-h2Y0Q{1U#CP zYM?oXTxE-*>su&7qq&M3Rrc+Q?nambqgo=OcDi1<#y9*N010>;e=2R33CB7&!+%Bo zS8480LEC5>*~nt!Wo8y7u4%N6d;iaV!$iF#{Z0LO^wfD@?Z&hz^SE)p>6EvGAt8If z)oOfTBdgqw7PS53YVKZ_^u3Rj-Dd)2)5L3W-0;6rYv5at-{gUR5SKV(M48Py>IQ&X zOfev*>u>7IdQcpuYVFfRBrYc+m8@P2F%&X|Yl|lbaX%n_YQ3ket*LKs>N9F_8+xtP z?VnaoeH7boU(jch%Tl0T|@ETEBExgayv-m%e{+ofuI=p)cu2oCT9$& zZu*pyl5C`UGlJVM-XJ5srXs(OJC>vc$>!O%joDlhk0vk5wl?<-^F71Gk2GGQ^#)$) z=2E^9QoKG>5Fte_vU0TS9~`nT^82s|UaC&xCG0IX|0aih*|3}my@eucGp1bEI?neF zI(w^;g>|Scn9MEp%TiI4?;6*BgYUxl(E9*yjC~GS5qlA9t>y0E;q+Wn6kVrtxl0-{CsOmj>zBZ8MY%rN}JG>@)Vy^ zRk&AKfFNjFU-fC7Vk7NIIqBEgqi zp?|!>U&5q2a-z}1Xpvb!woMosJg&@ttmC7^0sA1K%I&NVndy@)*OZ&g3FZR6I||o8 zM#8h3H_=M=6-*gxMYV%!O*tGU5w$7VUwkrEg^)2q4l|jB@)tHf#|q-zDCOXuNATNW z+bLXNJE#Nm?y_@lFschMo6>u8(RC))c&)@ zXpATf3U&2GCTW@I!*?~nzUN5c82{bKYk%W!U5RQx|J^Wn@1KN0zpMXO@3;QA&ih66 zZi4q~?7KhWXPQvA1jfIZwJW251{6%zc(8A7O=GTH%~(UoR;_Eg|AeMK3?uTpOSaqG z=68*Rcn_=HRZpubTwZC6?fMM+7u+p(a@kJ*&bfOWU~r_?Wu$XD_P!(#l| zovGICf|x1G<~Aw&F)mWCdhKC$AOJ|x|2elOWxrf+b!}owzOOk4m|NXB>Ls#h{8cyc z+VL}De5^q|q+v2&R8Z(%S_tgXUemBy)jD#?U0q}p4ti?CHIo><#^#dbqU}ihM=DD8=Nj#k?$z*|$$x5US?#*>bjrMFRS$P(6g zL1{UqPR;F{*bbD&)i3bk3ZH8x1>LMZO@EZfN!J_$0Y!W5#}GyeF^eU4%_OKjO8n%G zjR!9)7R!wFNrkHo+&zJ$kV_jc#~5K-0O&+V8OGfb?%cGL24;+5%AdwAnKcnI>L?l~`9*@L-3`C_-$W_wJ3`bG#@VNC++0g{U(VjQm(u+|E zo&XZ6PId{v%6=kH{C>N-E;sfxl?7qTI9k}+XKP245+<*7Fq()(2+ehTD>h<^r8>)y zQ|PI%MYg?fTRWkaMP_)X80pef?;@{fBc?Bf`WQ_`N~7`(wmccL)ys`UcM%lTUG4x# z2e4Fipkq&>_VG7YbTZ%1CG`jRJtmBtH_;Ne*q3RI^Hk}}v}tb3yfSaKl|(peWCZG- z8mB7lOp`6_lD6+O#b(w*My9W?d_E?_>8VCx>6ha>h?g+S>JH-lrxw$+FL6#f*OHh{U?;jsOkt78oubL;-{)8GsT+I@k_B5>&WAebMv(5;AV0)^j|-a{?!C1 z_jez^LU@|${YDwrdcRR#Gyd#mHmi1#8s0X;aZf6zD1Da^)y5MDw!#wQ@=6fNCO5&A zhYrV^d2P9U8Mf>KsYz>JyZWh%|9R= z6V^_0NIeplS!$Gm{1(}Hg95i1inolF34c{u%*&LM$=LnzU2Uwj+H5e#8~#^{14m`U zo5kbAw{4_;_D9B&U&+=)hjNvh#tk3Ekfj9qOpB`W1<9sjN+CkK-@^{mh@W1f0%c*o z&h39OslwRr(BdN)e#EQb^*5 zh*AAeaAyX$#oV;n>LY~vZHC7Zm4HD-&_vvh?iV|zB<|Lti)csug@e2>g@(z{b~MYgE8n|j7}%2 zA?3DIPTaO~H~NMRpmxl7D5)=KRK7*wOa==iV(IIL#4%+j13VDenz(+{j3wLdS1JJ9;npCQWl4&>;C5@n_s9jRx%+{C4Xp=bSp zpBM_=jQd!i7uzue8j+q+Qu_Ls8jgA&0P<+jgWW1Y5&<8Qr3i0h1Ge#Fy{a-t7tH&h z`@9uJ<3CuBUOxGF3y(dP^n9-8f>h6!-B!LRaR+yWic0@x6f(qbE=Pvg$HEJZ4}OH~ znu)}NYopyiOMCUkXH#+_ipE%d3H>|eJ&7pY^faHIMp=9X>m4NO0#_eNBJEf4A>a4! zHVzeNVkv1GP#ZSuH4CrQe(_YV)IO8?sumquTIegKq^l`OqNHlFZG-`o@RLy6&eh2o zzb>swucp@csKYsAa2p1E#YM9mX`U?-%_L3^Roc6VXqm`&eyJ<^v+jsZltVMMQN_}| z_3Sg3;$XhC$en}q9%c%JqmxYptmx2&*0P(vh9}$IHiwdk^kDo;_svAlsz10uG-3BF zRC85nbblq-bNw2)pSH&CrwuB0b$jQOV5}9oiFs=FJ+wC3SL!Sy6zY~i=@R9h6~%K( zacFvV-YLa+zKy37Uq7^}X`;%%0?*q-Y*NfPv@|;fAiUj8Rl~SSx+E!L^RtrL7@(h9 zEi6ve>=&W{Kqp!6suu#5hb5Bx1t7U@H|chHE~4VSlAfBWGE-B^m^Lk|X4uSh;UuR? zGfu8kfqtQdRhj5AmHr&4)$MIb;2oCPZ&>-dWYhH+-VMu~$yqm>jB7F%71x%pU?a39 zd8ofBPILJ#7ijG@hGmkangbOy)DB#cDqnrsjMOZau;ch+l3sH8-6Xp`&{u6H)NGkj zQDXByc}nMH%1q*scSYho#+AmH@FqbQ{$41MfyNK7L`>jG%yAG&@BO`j#_l%I5(gT= zVoEj(lBcW}DN943>0S$a%=+?nv+{IH{?Z8)^hEyaoW5G$k$yt_Qc$HuLw0>!s!H?6vmR?eF0`zJQmT<;TDW%YX^RuYW$ilfkT(n zl)sR?a@=-;aki3I&19uj@Pu|qrRZo)Lwcaph$OPYBjf3s=9+H%m znJp@YZT|T(y0M=)1-p$+o`pUz*%MZ>=`jj|Addd0h^u>Y(j68yp-zHdpYv5zpbxte zr8_YwnD(V4o_7%AV?;oAWrwPs>L2(wOzuZ;bc>5+Yql=cxplO27|FkMAXaOh`JMlVeCBtGRMWuHljde?L;g@`c7EVfxglhuJd7lyWSd>R;0%i? zh2)Qi^VgJZXKJ0M`F6i*SoG(9iQW@q2cZ|EgGW8nwI0zvHFEmo>W3ejDb|s ze5ggkerkSo;fqck>Z2I>JLhexy0h}Ci>8OtJ#+R4VD`ICyxwoLGilxkg-G$yOoBPj{JbSsWB~eo$GCXElj`Y43#aYQ5%GNueIC!m4p*GvCgZ8FDg7wF^ zY~ZU1(Z%n2(xtW5^8~GXBsO4d1Bo_{MeHRh^Z)NZ>u{+p)yzbdr+kD_ktOmk8Ex{v-@^T# zc*FSb5&gw~m%BA40JKuvJu>0>z=F$Nh8-_`UU06#?8P~;em8FneEnl~YQ)#wwn&=V z3PrYsND~VY>9r?$Kn(g(K(O*vf!=LgDv;EJqf}=8EHhOxJTl3lGYW`h>pgWxz?wb1 zXmc3V3R?%`BH^DvD@^3R5lCt?6>Zc})o>6De}XoV{P?3jFN@f)8>~vgk;I${1*B$z z%1(T=@~)$ezMzTt7)bi8ioZI`D*of^Ccba8+YbIU43puPyA!n9ipmx;D++D5j8> z{WaHvFnaGHI~Z`#HQgt#f!$s0sI@RPZt_W+MY!q!0 znpG!##n|7vJV^g=9eXRwJI#N;Zp^P~8 zr9tgiml{LvC;Z5 z0AUl9?>AS}6|S$&5SRh3KKIoNE@{F~5nSmv-HvEF1km3k@&eGG<^E@r!(Y2~GN@Bc zV)hK`81J{q;V|zv26Z6*|HIvzfJa$m@8TUuLsYP%vIJ#`5}2T(K|zzj42cl%z;Pctftqt2kBGUJ8{hzv_01Q1*p#s%C!TvAN~i6{h7?EAi_ z>g(K@}f1lrTZ=NUp)pn{*Rh>F@>eQ(!^7a;8Nujd%(`zl2ftYaNei;E=@)>0r zs9c2EgcaYUpCND0oR&;c!}H*mm_k=S2dCOKj?^aAl;MN>M_F;41R(pMa4&J{+&d+m zgc?E*J+DZ=^T|SZwcHS)o9235%ULzJBU+RO8;4l_SpM!%RoPODZNm7!RBPDm2p+*~ z%t4MqxOuFi9Pfmo=C$hcWjJv&fp!JDh4l&<)l8(X7}3e__vWw|-G7dtxI=Xv&&p|e z&7RA#!d~T$vB*%|GY`tCTI4O+JRD*(?9elhp)Bf8cSL9-^e@Rmu0ui=!{$8 zlI3bEXQLlayKAYz*+AWF$bs{eiSw+=Rx^cBh-JX+BrC8678cq}AZL5&Hl))W(h)$& z5YgIyyB!GLJVq#zL71%Hh73#YxKFQrHJe>Y4lZ?amJW#oX-H@cC{Yuv>MdJ~+9uGp zDYeUCv<7t+3_3tj`Y@rI_A5?*8n$#7+@LY$%ZWEfn7w=R9}|S%$?t1ADl+>9PHQ@3 zpEycTh(p@#Z(x6r*VbU>MYnu@Cu;rrxg@Rz^^Qma?p=mP`7kBR`43#xQ+^g0je|#= z%fB?1Ws!f5;4FV%3CXNMjb|bMuJ7MNYn!&4cd=%;^RL$}ak`e8*38r`fm%@z^xq9> zVZwWq7LsS&gc)UJIrfC?wwFELK6cv8Vm+Vu>OfQ_3nvypQUCQJR1+0UJ;@+Q6-;Nq zp$5GO{y+~cr#y=l1e)d_ALuUNxx=ebI+}^sfhF?Qg^~|dFCX854DPv8R4?iVS%Nee z70h7x!UsrV!5vV}sY$;GB?v3JREpA5#d+FYg&M0a+AUMX8HAq$cs%u$(#7+j3o_j5 z1!VL;jph+0AvwEkeA`bL7Btro zwJx7TpI9$a4D3_ZxG!d)HMVbN%eZDta{Ad&r6zAPW)Y|78_jg5U0;Vw2+T^sZas-* z;*A-6w522#C>(g`lIBFf&duU@9dwpVEQ~20sZNrGjGf7Jc-fwxpw`V(b@(Lb%-FSG zGMM$&O{Ak0kQGWgpq8O|A?Po{$5TF$AR$L>e~fYdVn8^*0D<$XF{D%fBEXO^g}%5{ z-MA?>T7`YY+eJe*9<9VudjFQu&Qx$UWD(T)3N(jm{u@0NoFxk;cW)9t=YW?;LU?Bl zW&Oty>*FMAx+AoNNRV6qbe+Skcc6{crrQof(vZ>EpkCq1#&!>!ZkP}inBTvntA(d> z&0bGb(7%DulnWMfs{FeEi{jT%y1i-EY2cn(!YDo_p}+MF;Ol{QB_sCceXaI{X~-y#Qaf-!Sbrf=Kw+O*+}VCfP2X z%ozj65+}l4B<+SUvt-j>q+!Cf@8}}N7{BvfCF$0O|7pTkn{*!;|912JvdQ-^z>O$7 z-)D{gfJv9}zApb`li$ted#m~W)1=Qwy7*B$IR{?d#NVr`Q3#BO8~Ypi2Dn`R)BdLT z{ZIQ>K@;Z+zW@P7%ct7^SQG!OCjQAy{5Li64{PEd*u;NH6My$6{&sOcx52|Ln)nYw z2r~Fe{C7?KA2;!@Z{lCt#Q#DQ|6@)3vzquPH}T)p#6PTwe_#{;B~AR@oA}!`@waH= zKL`oPSx;cE76({=V})8mI9o}zNC*ee@x)w5-Itq~_5x@BquS`_qC1ZXpL;a?11AE% zSA>K{cy##>oCy3ElusJB{}m?!ZyybR@`=Fb z9u2<<;?D8w|3A$So0gwH+#7_EHm%LP!4HS>A=YK!0KQNQD>MxEIo!tMde`B}wxqQ_ zxdN2Wu4btTLqtlOUTwsm3D^pSD0S)@tlV+_Jqx0nr(C~lIRp<)*?0kquT~ZDrL=T8 zN`(7*`TR(cI#aUhxp^(sm3_vY8dFz7yMgzv&>LK)!ukCu%yP)Qh|l5_GrN-5t9SAM z8_zV!Gje#oNL3FehJL;vG=#4ft&lg8_yqZU)Q@;%0uMgoTnWE=6v@rQOj2%dlxyKN z`FTtnS}ci(L`MlXndLonnEMz5@CDak!~Z1Sm)P?eX=J>B7JKO@Pm*54q%+sC`v4Jt7A(AQ81tx! zxcP(k7EyJzKMGK1A48b?=77h0m;kIi2l`rqRdxJ+by;#8m@^-Iu zKkRU?0m<;`7<71v51qkR03p~)zwq&(Jh~8l9XkH(YuQ71I}LBBL2f5ujou5|Ubab>F4j4Mk$Z(M2WNxG0< z|EsWzzW~#bGf(rx%T&CnUKg5@9(X@VHG_6J+z<1$z8@*nG=3KpwBe~@B>}nDIx2oG zt!bJj|by`BTZCxkTbIz(qpTKkD)AJj^YFJ6q_b zmlbT2;S6w$xa;&&iWsy-9M~`ky-g3_E6|V$!`nycMQ=7nk(#fCfB2L|;xhR<9l$Tb?&%dbhCe@XCU@bPh-sLzx4HPpTP5r@(Tp@nxL5@S$Y>rLV5rtlQC z|H^o7txay%Gq=EHxB{;H9|CY$hWZrgtWfU^Gm`pBf%4*Et$H;fk9S(=);RMx7&S8( zT|tb{VJRxlxYE=m#+9zlH?B-|j&Y@`G`diysw*%A4`B$3ol(>A^+&8p!jB$*{N2cS z-l0XR9zdF(NLOdNe01FsbDd7t1q?f#Z8%SAM2sIat~6C{TxicP)D+{%RJR*fsu~9u zwN0bs+n@$B29-EP_6llMfA}MB;(bdkT>0#qQy^Uh_N4jn+Nm!%9*?l{S~lKl?+abv z3r$X031?Zvqxnyvd1uw<4UNf!uG=e5t^Sbk&gwo@bcI;+b@2800k3#Ae($w<`pV!o zy!ZN6!uzU=`Mzq3e~=fCe=<+pL}7GhxRRoiXDKIEdbT zUHFQu&toAYoYn@}?u-i>SnHrJh>3iIN|Yl#cBqH*u>5jl!oM!MF`S0D8SmisLl(Xs zhpaV+n#o0J?MUbqRWc5|+~GO`MeY_D(j{#H%6XoL*ZX=Lws=#@Gsqq(Jrx__5QFN% z;LcD|q3vs%T-c)?R|>XuU2SJ1!5U-+?mDZQF^Z4O=J|rRgBwgpv4W#vaKA3C3I4QT zg}LwmzD3_EL%mE1E<_*RBxWYk4>}T#7g0VYxfX-zn{i@VhU? zU|E#~81)3Q9tA2G-D|6URfKd@m@^^Ge+EbAxooPw#p#oKqa6P`a$K}9=eyFLu<;|2 z!v1o2f8<~Vl{Zk3nKW8R$K*tOB6E>nuc){0bs6cPpAC`q%pW!DTbfq-wB#3gGfuCD zM1w~t*ro{EEjO|hndA`mAf6ZDd#oa9p-<5Y`dX8HH)nvhSo07BA|IAI9OK2@`3kv% zZ+3O{&GgLi(i_OVXDK$t{pZ3Ga+^TaDi`=5=~>d_{TBo~FV-F=9(JeoG~*BSb$Nmv z^={fUrokqKr+foaa7NjQCZ)Jo#ipH}PbLL*HoCoB2Yoi2YGm9ea0QJZYn=s=dgR)= z=<4MF>Q$wt2pHJedUfBo^|;T5ybUvc9(Ke@#dtedjr+PDGZ@YC|Qt&z~-l)@l zyZ~kb_EQ;U$PP-9Hzk;x)oPl>QnA4fgQ7Y$V*t~&{lkn703()aw8Yn{3a?O^-3D8Ja<;In%{$N~Lszh?DQ`rW^ zEW)7@nc{Cy>Ga#~wKqnP$l$Bqu(SUQFT2-0=ch(vU&BWo!c7Nsx)B6sn8{&wOMy!La9|3AbsS0x-ujO ztfx&*ZI~0vY9;;#m5gs>0a4nHpYZMAiu{h&-^k~T`G7xf#C0u{U-f;#g*beGTdzv1 z@`w8D+ZPEV!(qD3n16AzEAF(t9D{h;LR8WhESzs8)%${_i?~3u(fqzp;rwW6Dr|Sa z>X9Z4M$;>re@$WVC-nvPh^^4HMa3h1ISukac9lq@A5ngzQz=Yvwbu7q{%qei!zQy88W=)1GG)9lA<>CLvMt-jeCvqaobk-@KjfM#x_s{ z|GZogS@z|4i`)msgBWFEIOe(7!~ME&?Su=f5}YI}&!~4&zYTm^RR;$1;pHFQ3$+vM<#H^d^%@=S ziB6s2&ZC>Mzhw_Z11;79I+YRSxMH1^FdR~lbQ_}5@Ne1qC~8iIh~o%Xgu!3DO!iT5j6i=D6ENeujBE zr`kWt3QV(He%!Y<6f+i{At&oAcBFc}D1!K*3Z#Ug7SiOAYWvV1f0|cy6MvnW7R$Qy zdCmwWxIv}_c;1G2025*rk;Y^&HvZZzZ-;9@rT9uY8yYf{r~FF>@Rjn9q`GsY+4)L2 z(B~`VlQ9`V)phi1*0+;)+3s0mooVkmmKbvPe3`3Cx96cp=*QabSkI?dG0wR=8p4RD ze0o#FCOC*)*90*%3K9E4SU0r}>fzt9iMSto^Dvl#x{f@CU!n+!a2Krgurh%*#2oeVoOX5>ugqsf&f7TjeBDc8Z7 z$NroF>Ynm&x@5N<>K@OnzioEp+8I%iUD&Jww~Ova%5nuU;?(>!zTqBoG6588&@Y~fxh zfv-~=p*Nx2Ea`3cEeuAE6utF@#+@FdDY?ka1DJ{JE?^pwnTXHe?bp6^0 zNY~3H`#SZk2$pr~Q%=bc!6eJ~WPaYEYValZSSjBIwM4#k>J`RI13d><5&ztxWWj4QZrx?D)MhLgeSKmG+yZ{vq!_JzWMqV%wnTPY?kLkalNubC} z3B1@F%93@oH&le1+o2xjIx^1+UWVm0uC=0q9~xzD6Z*g|veY5cqUc~KuX9#I284xH z`E!Zuo#73JA+T#Z%S+nvrUCdKsS z9)CM^2dAx2^MnJJNu?erjfxZKLEY1j7i6r9;MVYU5%fZx8U%d=d%GXL?C1u}FUAf) zZ?yi1WeW5QfjyaKHR26^OK}R@Wmt-!38`pVtD={1tf^-)H#P)E3}le`2}$k z^Zrm$V_;pT#tXM@VD6|>t1s7hOi3u;=p!8!+!V~3!k2qPyM?>__K;9R$xuu|Q8_Us zl4kJ6^q4BvX%QX#4f&|dK;OR zQOTFHaoQP2oim>L95PRX><9JG3x&b@yz+ykw=uK+lG&FeiePevx&aybfEp0!(QB({ zA@}<{-nCi}Sq~M`+R@Ilv``^w{bON|I`2#nB6OJJ;UFUSjT;a=6j`aqvCp28qG>Cq zB+cK8%7eEl*oC0&!}4eR3GJNLDRG0{^gC2z>v3Nw(D8+S58dKqh#f!pLcjHe2BJj|P~qzt z_z^Uh{`Ru%4l+OsjOp#PKxsQPtFK4Bl`B;nVdYBAk}In2Da1J7%WFBK)BM-5Bf?-9 zLPdx1AS$XemDN$rFUG?gcy8u10O}Sb=Z({K`0mT7Ul64xmZKoT!|H>Jq+%!ln&kow zg)v$chpM&$GcsNNSAEzt!_%v1G2Dkg8H6%DUHwU*tAOG|ky!r#&2(5kYpqg>>ICsd z<`wjS1zd~LEmnLOK!I!!oAe+7FdJ%Py*yTi_Am4ltikFDr)@k1+fj3Acc=f+A6_2S z@_7oX@&7}3AhLk`#c(9WjF4cgA?tIj7EOQYF=B=8fZU4_kyC?1g_IV8Ka*-A_fX%k zdMw&c%@RH_G!siHpFI_PCJ(nS6rcr4A=B`(Rn;5K?X?SvAZl4&ds-f%^SIbzTpHp$ zOYh5Q1$8D!9`#oh7jQiH&xFlC=7UQ)jIo|e&TuZz8j5^HpS1#93v@+F!B3TE?%Kkf zA3cv&rL3JjB%>AX8<7^fJ+lx@KNDjW-RMx3yi@=jr=_bF7s*)dTG-twF);!80GiI8gwiNTP1~SAqP`PbVGuO;Pf}{v*nlq zEw=7e7hT0BBYT<;aaC;=9#x|ziC|KvHbabzt8`-X2cChyGetP2FLbl;Ed0m@I%YmF z3s3o0=E|Lv=_%aXDx(@a4|gJr&qyOPxwa634us3Ye3AiU>{m3y$80vV`ab0bUSK~R z*#kX(vU0XJ-c4CE{Vnc$Onu!K{FXVUBFEBKtsIoio7P7&U+L_epPd~QWLu|R&C)y& zsw1CWkmv2O-D@^f+Q309@9R1sxRG(l9qapb$SH9+VG)cngvhL5M0FOq2sBnAG-e5n zLEQ|tl`to6%tG^n*47skxkOx((@+I@EC!qfR|r`s8eITLbuW5`LyAu-pwGO)kNme< zInZ+Zdy^qwh*6AjI4#|%wXY>nXR4YD^gv7_Ibg>D%vAGReVZdRQJ4sKV)kkWg&>@qdWtPc-_`g4`SkIhqZaja8%1_hPM<%KMsAU0zH^ z*e>(3c#dNxZ!Gt1pppOsVg}^TI4|{dpFep}E6qPpS@@u`U zcSj)6xj-uK(UtGwQf*~9sVna@mA?x+pU0_ucaXy|D*q7Vo5q!|JfV7jAQL6@AL!sl z^7c`^$__=PQm0J0WxVNAsZp}7Q5%=)&&8MN&TCDL{tE5?acVT=ykpjA<;6{F+vyI(4OpaJY$^}o zSTNPS(o}a54$T~=x)aVlW_90(9MQM~PpJPqrk)$X*iAcG%L)gK@f8d!@EwOiRkwU?5{_FbPJtYf+#%!Fy2#vd3)Rit0B`Or4{8C-)Dc<*nW9S!;8X*+Q@-d5e$f?GalDHN z%y9K%hOTrG6QR^%0m6=(e9_MQ0(fB@*dj2))msKw5&?LbByQAik1`2r*DCYh_1iwk zRIGbFGeAa%_(kjGnYw533+kR~S}&a_Fi`b2C~Ps1+YDs7flM`!6AdJIdU*x|)#0ve z_gZz1P!wo}DN%N|K%(2_yCS26U$nsdcnjn)6NalL$V6y{i2$s(-B)B3!B4IKSOYv; z1N(vtBuY&)a7-u7F6kPz+(;%t%Wduc?^ZReDJE7L zC#P1&N((V|_qn72)85#E%+v9@8xX(A#HTVlInE$sKi$dw?y9qn?mKhH!LkpKa1c2LI(Jp%j`6JKKD zGc|mf6CaVKiD6NI&(iVpo%qcrUKlIlvkiJAEH>XuCY}t4nrUeqmji8^*i-~iKdqb2 ziM`XrW-$PHn`0z-PW;u3pSf-u>YAvMgX(@Yi`N>NYVJtXspn)UYl2gc84t-{1&wDu zJ@<*{zKn_LZsVG&CYl7~HENXcRMB&lNmHx_7*~nrE(QzSB)M%{GG}UIm1NKjZ7$qrdM5zd6gNdvT^Zgtq#@boFRA&&eD+#m+*=acg z;sI{;_Tp@}oUtklzAL*RGxtno4?~sW3*C-6W^NTAd^pyRkIK#fC$Vk5xd4d)Cyb%b zLEd(yAc>tin*rX?Rlru?&YuJ`$W3ZXXC$+2K1JcBWPrQ*HQ@XhAOpOiLIRdCPy;@$ z0bLRaBS+^64V(3ly+OMkE}HQWa$+2Ew1(WtkkG{d+(K8-=7q`{Py#|%5^gF3b&1_N zv%0wdyDO_Yx(YWMNhR%qMYy+Tp#wd7krjHHI$A()6zCtY8LDbKA;ca%A5g52&z?{T zsM$z>i2`=L(3(A+MyMo7zKqF3OIQV5@p*{J>{m({Z;vj+lnz+&Y1AIjsWsmAHc7pt zNQzm>9WQ7eaAzw6OkG9*Ai9L;`9cM$g~6|&Ew@7Qa&MISU)%wzU*xRPuf`CR_G9`Q zV`eFg;o)xNt1AT)2u!W5P(hhQ+#?awDsee7t0*z^C1#9{S%jE{PE3`=6zI&P5`9;) zH{{M_=_hibZaQ9?r0>c_PCO|<;N3btmHxhRm8rm|JMrIU2(no^zS4oubK+|lf0R93 z4a=}=`;*N*S-ZSIXS}-j0)p-Ph}!8W_SYu zD%h5qunCJ``3Uu@HvTQBRJ)*|UJD?B&USB~{ zW9h@ z=Xo$J*$OYn7w_NbVJvO=uy#vZ&XV{BHJxFB-1kAb+5({`uv6JUh9fThLY@Cg<`2GI z9r+i3Fg&Uwr{ITeahb`fw|wi=`SOMRFTS+ztq$KNqpdp3ohlr10PH7m4T9|d6b9eV zA6gi!p^}R`sLpzu%NTVE$i!J!L!PGWz-4fi$OUpPZE?nYdMH%uc=aM1Jz?!kX@tub zE(0ivb+o07Aq~*hob&6eu06O6!n^(C>JHJm+Fy7Z34Z@`qV&*bOp$r zl7qA2=lR*#d1gjJr&!C50~In$^#PRy3pqiP zvwT03V-Yg(#TIfzim_*#*i;5!HDMNF=}vr-iO-UFXCbAD0N}gGU4X81c6>3iQ~Dh7 zYfZdR5#m#uEOnlhcn&N?npIet16*N%D-jS|2hDe4Z#J=uB-X5T;m~_g1{ao=>S^Q3R*x9hSQRv`Of|!}@>HpD6{%Z|t61G&ToWymb!v2 z6w-_fNpQ2r`12%x+{RU>x+6{GPmN>e(<^3`;(DHW{0eH0{3*^3Z>l_o{4$UI1IaVE zvXXOCaLH`WW}#_dPFhqKiDhn?M9Or2zm?W!dj0khqkFN){1QVTit zV%UsBOhMX(1Nud#5rO6b68W-L6hkQE7gS=Oa*>!mQrK7s#%QdC3@>gu)>86ci7 zVT>c;ybU^bEHs~HR$9V&b`d0;+s|Rv@@AQ~(VX*Yf`mik?)vSNa9)|ucA%A{T-~ph z@CteRl_Jhvp(XRAk=kySqMn#Tk`cv!QQBCgQVGOE5p2yU}l zL}YPWFh7{YHzPD8l%vMBmO83sXhx)9Hsp$bBV0&OKoRQC+N&GnOBK>y(wv$hfKpWm zo~lHmq;*)O8?={z#Qa)#qf1C%zL30u;N!~aATH0Fh_L7qO@wnx#G`3+Wtn)!;#Ym$ z0AxkrYEYk?r5o)7e4R$E)^3)j-qLP%lX^+gLjS=q)c;BGN7W-bO&-(SPq*z(&vHl= zf?C&8Szc~6sNUs28;38>VXO#h4GDr;$2Jty@+2l6%uQTvAE6>hVA-vIp@n`Ug}>Pl1_=cP57s{7B>?Kwlfb!rN}h62>B+AZxmM&cXPaE1kP zU!2Ca;W4ll7eY)t?F?3Ahx!Sko|AJ=q>OyX?(a%i{g5??1IIDdY0O1qP>7fOnrW{T zbg+X&NeAwRn`F6*VYvS`_=EaHf}-jJolN?$8tyPIq;9kw6}#Vn_m{xD3wt)gJhiHs zMyU|s2f$1S^I95tk!*+9?sgYsxCX#3y|=TZn?Rn2dr9sg55$?yq4WoGpT7?+fXyJh z+9DR}zxD);0N3u|<6PB^VKUpjfx%{R=#rqGduY%fn1(BkgN9K)%S6Hi-xaQiZ5QB5 z8Kx3n^;}CfgJYsDL9Wgmzjew2bKnK8&2-$#@VdF_X^%A(?&7A3R zYAF>lJmLu^f~FMJf7HlQuwno^{OUup!%uuP+gGpQB6lAQ;ft6f%&XGC;MPk5 zbW6t!_0XwgB(Npo{Q_hG51xzwyKS%_X1{(LlK|I8$tCe^1)PQd$-)eWm40r|u7`x6 zzBjH^Rcl-+>I=H;A-rq`Cgz{82Q6>#6LsKZ9bP16auS}Wb|P>9%9xs>`P>#^;%HZl z23d|mA|PcgLppBHQTSlB@<^}GF-P(X0n!4vtgfSKwiNc1NJ7ReuarT+8ust(4B}7T zdA$ivg+-RSMm&CQUqfF{5599udn8L0*`y&fLU#j~sX9t_(9t2w6m=@X;pnX@&Soh% zAi}mgbdoMSTkS)unu7vgGY|!wX9{?(oo?tS@zt6ANn9vxwh2mA(~T=l`RPLSZ^M_9 z$$0rTsO#j5^9PIvDtTBhYnP?+=(640&vmFBZ1i)seIWNf3>>U?VT1n}W1+JaqD-_u z-Fhmvl6k(BQ3-;a)~l-LIGf}YxIFs7*9_2ccs(pmuJD7l zxTmJ;??6e9W0B|%Z*Y&gBnE%JxX{R5O;9RK3ROGfNmH%pLOUnp%Xa<+(*?=zNBP#N zJ)AzIop%|RrMAH(td5n25ue=lQWIImnhvCdf^Tp0#rBZ+PcvW9;GvmPyuo#1(Tr-a zS<0E`879#s=1YrbrW>HYk<;nX3UHhs3pbNw;6H?=s!;4{Me!Zuw<*FZoCEbBSPof? z05IK9dF()a8vMOMI)BO3=jqeIEy;iNxu6pAL%dJsH_Ue|{ej%fDeMy-47wj+?2gyK zM96mU6b9-pVz6Pmtt6;Z=>q3q(8W5<`Aj2RcRMk~&fHGW3b}3-zN%+4c89}tCFlWY znpxOZ@;07d(E0{-Ii^2{`*s&FQLLT!0vPT=VOxz4)Ste9+?I>uAP!?(hZU;bXVM4c zws`Nd1@Z=?EdvhVpEpV{7~T$b{z)Qhn!_{~xS6hPkGvRvZH0JZ*IQ$!UWRl*9ZOw3_C(S;;s{BdR}u@e}f8eE+7-e zd2vK(mU0JQ`p}Puj5C3$YJ{Z3F(I61LZIPK{TUBLLk8jI2BCD-1L=WTmU79?JM<2! zoet`)_F_|*8GUq`9wzVMOB8CvkMl3|+wNiAot_5^8j%c)1Gzted|dwDfLw|htIyE` zgE*@RUk&!^*y$Yaoc&p+pahO=$`Z4N3OE_VRRD?L za(OA~P06QLy=3xxj`^Xbo)kaiUwk8fA#QTuo{|%+*~7S;56NoGfqR5RUW+eBWqcps z9wxgvMh-M1v+-5q*sr!$#83(ui{a(y?Tpa_hmNQhKx9<0P&-7?LN$QK5=>&UI5Ok5 z4%FB&NNpi0CaCpN5lCI2Xf%*s=5wtEWR#jO>0>4_E@q45^&DhS5j8SmV4%8F0GcYs zUY5;y4$pK{RNDS29R$_SWds3PFXjk_RLOn(m_3Z7rz++#5)oReh$ujZR4k}8weHXg zO7coDOk>*dIhgLz`mUobX?C(wY*MYRtCad1ST+VrO*5sI$rn5P{G#2qIIsh7?IJBI z5U$1nn8H#>-YkNml8KSYG69CpPxvV+%r7!o6wf42)P4w8oec(+26&zU*1Ppu6-Hpu zVQO_HloH0C=Bp%KbwLv)Pc^_hT zSZ=V$A{Go+pJV5qiB<1vP5T($u$r&o=QTCf>P} zlwQIonfOW*Z*;Wto%pX>Xxy?)yfMVdbK=*S_#zWORx5zVI`Pk#co~Ag&sf^%;fwNT zns^x;h&PrrE(iVw6Q64GH-<>*PJF(JFX5m9e6cQHb2rxC#8*nZqu-t{LlDu;O!OiH zZuHkxPW&zrXv}nh?2Y=|<;1Tw@u>)i8TzC(>d`s zF&>v6g4W{V3Qv88zav>fp7-#l3x8Vk=NyvSA{l7LP>VSxL9^%?F7k^p2{InpY9z#80qI;B7{(5ifQ#V> zAb)~Nj76b+bPbX!cD5CObe7|6AcyxgNhq;+Io%IA$($HMFnLLjgXw0Y}0JWN?oWS zwrGfL0&zUkqWvlfsj*QLmCX!oRzw4%XekzBd{=lL;EP~k1oTBode@I^B5id+#duQ# zqh3j@yf!fEyOO9S7#X#Z$YU899d;3{X-j@1p}OnvXgf1YwL+#x!9CaMc&TdNl~bMg zop4A`EYR`NczsuvIPse50AH@-r6c;T9P7kuN=E#69WOnJcki9}JfT{|4`BS!21vs( zn5j;AzByM_b?RyP)~dPq8ZuBp?aoG?YMOQz(S4V8TXav*?mW6jXm>H)g>++8* z5~>icpH$CV7lKlpSQpkaGaI{(!KWuWg^6|HA@Lb@AV!9RHB=c2*}|Od=SxV7!Kbt7 zBlFNkhM}jo5ms9!b|#R+-0Wonr#BVtr^fEZ{di9mrOA4HiR8rv8I(`xT2~4HRiN8?CZ_)9^_z3(?C*Gsu>vg>4#Jijd z)%`4$P1P03a^lmS_zxI=G}9Slm`+x7AA3|~$`|*);ET4KjeJxa35%*$IxLN0F6~aC z`^R4;Z6@7HyVL3ZT)R{0-aRSnYZwnyD%{RlLf$(~D&V$tV%IM;ue7n!Ax2fzk+vQPp zZ9U^fJb+5~PKkucWP{52fyM8};3aeGTSq}>B{4y=3(wW&1#OYWgsL2%>$qP5g%j#| z`8KGhYn5ASF3awU0n zy}R%&O;9#%GBJ)?emo;9!s6 zNJRyK?TC?`&MgQNG@`0T!nmdU4@oGt*^3Zpka}L6wQ8?HZh|R1O@)viSY)WRHHVP8 zPF-QJxtvLW?{CGA_pj-P{Z}ieKQa8?-z~%Mj!`6n3=qM4jGeiTWQDrNbsOPz_4~A4 zjgE}RIQJbt@;$QWKFl5tz_vC9;4VD??;#(;#>MaWb0L4uGgfby(I_OKbxE~ zm=ntCDEc4c4WM22tc+7q<7YS#d7}u`L2C^M;Z$R`F5`5M@aPCyqS4GqlBzRa0$ri)U4R zGATdyJj6q#qYJyX6vlg!9K|&8g@WuhI zpTR@in?&}&MYnuHr+{NQG=aDGc*@tXR-xN?mk*-$iLVqMTv;{(>3D+}3h?745nQ8# zO%64VEDV+L;$iGi91Q@pFgsYk=;LU(N5`^ZX~~Q8 z2`+*Wb**z9aQ4w`c-Vu3U>XpH!i0JwxwXiPOCz$_3Ics9Z*A434|BlTja~uY>;Drj zDhq3Y>|PYx9|HcZPO!mD5*j=D{ zQ{y`I5j@fv+%GH)9td9#crV_p@Y;j2(7g`qAPxIM95$++;P9#V%nuWU9pUdWW-U2q zh7QAR%0POA0OKU2?l0+?353DWOc4y!Fq1_GZk(sc%nKqnx1!`^M!Pk2xn$@4UmXR6M#naOi0^Gpq22*kMGIi#T1HxQbS$f&d3x20s@;^Ai4N5+ML zt<~NREivNi)LhaOhS>l-Ymk3k!lP?U_8p!_9+1}3)v&Fg!#4@3XgA11NhW)s>Ta#G z_mnRt9pP$3%=Z{#;L2)ikCv|d;JWgv(p#~I?Qh8`5cXr}zL2}~VExF>WpWiFhH^nt znhR6Y_4ugZUJmPNcsnENKTCynvn2~K$D($BNaR_6lb89yw#tez|1n$FX50AX&b+AEgtFA1 zDHdXee1j)=?AC){Xy;n~j)v$?2s^j;NgeRMJfs2izlDeKf-U3roZ+(|cij}<5)VI# z+!OrhLvM==7xX$mlT1qBe+NUP7m9SJr=!obAHH+oQ-xSK5Sec&hhzc^^$!sro3ov7 zQtyWm9qOCE%$3I~wf?e81}sC@po7OF(^YN)oQXCbz!U( zf6t5WR=IG^&1(MmLMiHS+m^18Bdow7jDqH)I#g8$HbzIq`&%X#cPOyQ&C zeU2Z9kjn&7PRdj!!=zKKiOVlVnA04Spn2)M3IVH|VJEtFeKAMdtcjhBm z&+0c!%&q@{Z+4;)@+`YkRWinE-)8Vf_iuiO%m8go)4ZlT8-?Tl0G_lc$;A&oOy6 zo!_0Qq~)L6VYg1$U(aDzW5tPP=p36YMb^$VvbLxE6iiH7-u9IL34=c_aKE%2H33KO z`Zd3G&SbRaiFPja0h(C-T@ut`CQ79$0rz}{F!&{ZcP#&xn5W3|{@dbtUv2Wv?~TPhGbne@tEXG{e-DiD(i|35rYPr2kBjX(mBHo>onkHjtoPDS{`lotSnOs^-YQ#~N7hV=KnHW*;#6%<@>< z^F2!s7U16s{CtvU);gvN{5;MxtFPb%v(4o_i5Wz+lEC`rvax`R-_`k~GTh(Z+@CSl zdb|2S=5-IPJ&Yc(aB+wB1xbKrIJU9^Kc{#CPa*BW>SRyFdvIV8)+I(8sRyf@`BQ_R<$K;5(&^Wm zf=JvBM8itU!C@`GOEVd+}ia zcGnY-agWtq71tm=;EM>4)mr!}!ozy145(T5R1o(*D^Pm~eHZ)`cagM(%a?k{>T$?! z)!gc_KDc>JqH-&Y8YX7)UPB3H$X#_OT#k2kxN5(BQUoN z7?z&A`uF&#b7(GLPc4g79Y@|nC1&oS84t><(B+x?;qBatGoY*muPfrcgJY3K9@d#i zhtD1lzSkR*2BO+X2sbNWGrvP!buxurJj=lmjFD613zejJ?K{dixl&$cvu&Y=TSU+i zVW2`@f}73ddFW$g2aN)RuR}+sEF^6W;N*c8STF2PtvnM_Jd~>l1jqSO9XUx$(!yJc zh{Ab5K{pcyM{z!8=C`qCFDQ?CDi$I4)s;X^wfMogzel~)j_ZO28D)qBJSw783bTNj zB!ldU3pobMf8dM&WPiq}(8wk+B&47FV99p@EI(Mo!~+qv`bL)Y)PBAGU|XRBqu~!w zS&lP1_iSuWsdqoy7ezz00smlEBrp%X-tx};m1ua%CxKNTlq!J9cgNa})-pt}VymZo znDFt6D*7@0aV-guxKI-H*$-m0Y;bA5sW}8;fxMI?E7T0y0JJ{%1TM7olrLkCk#$4{ z$h^)MF2Ps(EG9G|zeW-HATqlsnjajV!nvkg@7DncjF(&olS&qzLo}VA&i?gXeiuNZ4mBL1Nhi_!YnjdLpnJ>}1G7}$oo5Ske| z9rWN0tWWXf;5--}|3U)TZ5*6MdQI_v%SkFz4Zh&VC`|X!&g@5@g*!bPL}65{ zWrydqjmag#07(|-B zY244=NPLDUe65TT2FFSMav@N>zl+i%4*^*7W7JA&*R*QqAUXOYp=zFrYf!4w3Tff~ z#G$fY2q#&7hQU8Uh_27w(U0l39ajGihy|W?B*w0;O9v=QiN0iwq8D zV|pq+LJqnu!<*nd9A`Rx<!=|udeAWEKGQ?qdJ zKD_y7$2*1I*U-rE)UCqXNtg1Z14LJx0K#J)o{BJFJ>?@oQ3cqXs7S)7@!5TD#MThS3p@nSpt{Kl zO;k6(sceJw zT1@rYM&QDOcQ_1D2Ga9l407`E1|Jn8e6>Lm>)LQS=d&v6?$bH-HmEaMuHCj{M0(^! zzmb2?V0w#oqL738-pg3oB+o;|@QYQ_SNiP$yN?T?syU{}@MVb8d_Y?EMV51>hvn23 zV%bxy?1N-3wVX-ROt`^+@FEC`|BxOC7c@3lmPE!>qg;UW=IkpShxlo`1-%r5UY{6x z?+BT@KksYMdmH}7=#2uX8jns6KaDtZK1@wI4SZ`l0yMt56TBal$r|lk>{X=;}(YZ9zq( zCROP&G~}o)xi(BU)P$`(vP*Z-{~IzJ0GAsQyQ>8Cap)lp9SH*Za{sN*Yn#i~WL1w}1&Dgr?{rO&GjxX|q{De3mp z?$%WKyM2a9bVYN8bEL~>v~S$qj{roKg7S#UEA7zj+~ackQ@A_!bCOXX;IZ@X$Nbys{0n;R#rbIzfnEEkD%s2TgS2gEzGzMKWpzHgX9Y73(pnq) zIF7|dIxQ}sGv*Vc+*-|U!71N;8p<8eH{CNQlYYE^hLMNec5E7rkz8#xarI)BVHrH&3nl8F1{o2*dlRp=sXm7^UJxhe=f zm{Ag8>GX+K64gOTgvAY%M2x1MXf2*S$GjBWF#uMY_7DotL?Y_uF9XspC{gUz-~Oo` z-d^xKeODtw*(M39@SZFjs})FYY%IgPOk*v?oX!&D2$v~YSP~jb7}}f+(O5SwTy5W! zz}IkC%ba72F|)TnV3{j)C7m;Ty7pjoPny{Itgdqnpzcn@PBXD(h>aa0t7KBL$uSa3 z4VIh{6Xhia5Ml}pToscd(wzO<;y`voe16~;x95H?jxlk)`&E0_72}ehwUV|(cT)dw zoOdrV55H2@4zEEt_ZfvYv-Y^q;*a8>3E5P*yrJ8n7uf5MHU9&E;_C3TExHHN>FK2ABmvpH@*%&pCzk_cex1o1eYEI-T47=yG-+>1o>oHL8CfVFBN81q{cm73PT}gZG zp=7qHU?`dSvxg^z-^H><^rP)#CB3Ze(Z#sYx_8i7Fw z5x#5}w+wfb@>_;CpKe+quGvQ3ILx?A%-Erx~sBUrRsNgvQ^O{_?m#gMO}f z8BZZ?_WPtNZ0p)>U%9?s?`j!4Hc$DFNQgvY%NDMM2N*=BA%~0LhJH2F^A_~q@(%24 zyU!URO|{*SWdgCqH~#WLst&Q;-iX-VSP2ji+qn>voL#>!AJEx-{2n&`UPppZw%QG% z#G2KjN^UfAAk4tElyWieV^?RbT8PxgES#*(DSQGAC{k{>vD@Je8lmx zD~V<2x8hmtUZLx8BjvErXtc_`DXL->0*P@uz!;Iy-$GOwDc%hQC=k@0kIrX*9D>Yl z`lHk6#{J=c+UbkPBTV{UJn8=H8YlIXcf|zhB$wlwgm^LzQFRoAA7XS2;%0bsGfq`j zQXO8X47{JD&ie!liN7F95`sxS)e>F1weW4 z&DNyy5?CZz<#V6Il8IYoh&kcqn=ab%;bh#Glm^UEO=Zctatcx}Dqoc6Be z`!(p`dy%c3d&4&{1WP3nSF&h3w=IfOtJjG8B)Z?E8#doKK3o&&Px<{Ww6x5qWC8P$ zof^Xs(kSk~G?B&X3ggOFdB#}J=os1`^c z!3JziWHoV^$)CsQeJT)jPnm>)?cdSf6^vTrl9$Vj6`PN+hHU+ZcCNVn5{%RDY3x6# zN&GiW;y-KR-%3C7-7a5k57qMmV-NN6r?RBpI|I!s_E4iRv#RwN)0!V!!9$|2YWU7m zxz@9Es}+bQ;m}dw*ChYRT=#hJ5G-63TjgEhl0!`s%Cbngds({TbK?`s|xi z_1mPrAnXod0y_sux#`4J*8!En!3l90Tb(tKBRx}oi{GTu4A0V`uGxbj_ViE5U!RZXxba&rq=wY))PUEi+`X{t$g@^)rv^!)in_*ca*= zc^U*Yt^!0f9egYSd(4l}f9UI*gCFC`0%@9@&CZ*dC#h-RTiEWx{(OWo-3)6cW=Oo< z>wyDxEaQ$wnWqrD+UrtA!RD&+MD5KwE(4wbcI=-)Ta!X+4Q9P-j!=7i^A!ozVWfpu2E&?KX8WdMNm zM5q_`ddgozU+_38EVBLM3$>xPe?}qp7!dT1r=0sS-p~jn{>(d27|_!R5j1UpR6s7ColyR zw+UL?xP7Uk50dep$>s6?b@uju1GSR$j<&adNMazk{bzgo@kko8$0Plpm_1%M2b`po z2G5Dv<9&yrWlFDA+u`9D_%H13Uv=PwpTctj_IP(Yurzm?AZ3E{|9AHGm&9SCs)v+& zV)ph2xN?%gBlFXD^n%|1x9strF?kw$yoXJmjqUO9?sIM}1bp?T43aAU_27T<5WTuV z1k)Oh%6te#pCA>5o=xE53?t+ngX^QwE$~>_>ghGIKFS+`T=iA}do%aDUD!Hy>~>}E zA@UjIfA>4@VIc^ZJ;ovdq?cky!aDs+;Lkr#k3v<1gJ5L7(b;v6{Ei|KJMf9H2fW_!=FOY3zXhudwbZVXYhRbS(o`q1%v&eu* z5i6Xr0q@qw3NQ=wbNO2zynhkmu+l!lB!QKjR$cx{zR>ek4A@X10outB{&9p{V}&}c z?Z)PT>i#PP=5xxI?cpIAvY~t-1$~O#P_Ho29+OCKwBku}N+Ku65~blF0{Cjwe`d^f z;aNbap~gDGx#=SVPuJO~e`!!qqXXAyd@!w}rMn*-bxh}`vJHCb=0 zCbd!IR&5mdvEq2bb`M4LN!*P>QCSei-~2mvRd^h^PCd00G8656Q^7BLd0b|!MHMBdEEnd{hK2?llO(mZG&F@NXd z?N|LyvKRaFDI}4|2b{Pc%fw?T_)bswHtHZ({xECY`uJ0SPs?~7ei|ws%A!hd4>J3&|!EI2~r~8tsJP)t+=G5H1g|hzU zQAx^}0UCKvy-C5;9+hNyUaLl@qMXd&wq9Eswl(~aAN(lipOZSoQP-yz>8 zhlC1MXRFsn>z1ks!IrlrZLxyM*o#=3WX(KW0$y7B$$;Q4*brZ5z91B#p5W;yXKc>-lQYG;4boQT30=IJz%XhyOO!q zOFA66ko62qO@>Xt3jhdAO@ZrWakYYrZ!}?INENfHB@Big-xiRDzt#Ex-|0&tKkP;c z5VCz-2n^o^)L@^m7lui&6RJ2_@@XU{QvXQF{3KKhGf|e$o`G9C24(w!+8{JpK@lz< z@SRs`dCI?O(gf>0_fJQL9NBM^yh5cGSC0UJ1`3l@p*_AW^wY3UssXis30!fzXEj=c8PZf%}SgVgwUT2dU}wScWPW#rfcd@CbxD^v{au z8sP09X}4#P4O+1LPsNe)jDz%nT)P?Zv<#>g2DfvQ&F;c-9CR(gA^ z6JiMb(#)TQwOw=n*<9gyDlS7Z?&4R_9@m$nJQZEx2zS%L{=F;<@qV0_t4fZ1go*W@ zlhq?&*f?P^^`IJoQQ0fXt>6nG^Mo4!2Fi*&4*f^?+pcxd%7h_R$=zXZ5Kj?9MvyhA zRv;W$3Ni-mqRnY)n?-AhbT2lF)2&dEY-Z?J=ySgZTLX{GlRA@W!y0^tT2B!X8?M2R zxSYM%XHQBIfrnyIp^sNM(4tfA_#4%fJFP(f%p`|U4L>6x<)KO#Qz9ty7VJepY828t zoR979gBHL@jV~5!?s#GV=YdI5@bQLxT3VwUF?l9k|nij3NW9sPYB98P8_c*v|DjQi>c2Ly%hLT9 zV*lNKw$p#ZS5a50jT*3sow;WtyksF+Sj)n6AD5#Z1N$*uf^Wsb-;A`$#F0~3n z0}*YYkeK~1JL8hL_)Y#W%mL-5Hft)lR5(L1;QeFXP=Ya*M)pVnM z_dM2f-1b8?(RgYyHE1%;qZ6?wi)^7ngDn8}w3ov;02ue_@D=4P+#P{T)rV+L=j!hP zyat==TeRI}7A2rZ_2w#eN#_$5LQk4{mOTJG6N-U}cHmHR&#Y3GBD!3=&+?sE{7jbI zS7ej{8pDH%J@U;RgLLMzCDX+cP1Zb!$q~OA1CB_%g)a*oyF3aFGBrj8=t2x;&qFjC z1DW^1d?~}j4+7uWP7jZX>QuCg)DQaR}oDawE9a}nvQk#`E-+55@fSl-SUCq(i*S!q&6`LLO*yTwe z;81dr#TG>4tEi8ncZB>zj+6e?vACmS(#veN<-S=cP^c{6=(VU&T2@T244Yz$p3CCv z$|p!OX_*KcDHIAu<1E0EuGIE%> z$L_JFf3p?bTd3c4vkZTVQx0_*Cy$W8d{x-KUWjq#%77RvX~c;;dSWbblkTM+bqK^b z7s3?5g*)3WShEwNiT)}%YAMhjdgnL1cVw(bEy9n7HKQXYCf{_keVw*=grH=`fqZ8C z+c1lA^Mvnod6xVS%g{I0?GJG{`;r2{iipIDVT zx3D_#(fF+c>OkVcD37le+GNCUci+McsR;${WmZg$(8lkO9D+=2ch5cYIlHBes5H1; z+Zv#%AE+wY!K11mb!-8B_`-^S@xaOn&x4h$#f(jVmCQ)C`w`JyL~&+44fQ3gCR6S7 zd)FJOmC3KoxIO99ky3P1gL7iZY4dI6^mfrW=7JW!tk;vh)PIWssx`4P3~WuT3ccy^ zxo-chq|h`ql0hn_jLVuwagSC7T~L+$m#G?3=%zmYc}LSm78NE=-c0no8_*6o{_k7Eq9i2LnZ_A!{Z7A%(`KK-5e9A&_ ze)7=urqO*=xri3>T<4GV{pjhMWC!-9L9z4@CIfaG2p$QL8^t6|OF4Pg*6^-46_p3s z`Y(5}B5V`p`fi&rjlQkqwhw^wyycs;R<`#@9}nupJwVRyfD7<0!SNc;_(y>8scMZS z3G3I?Q;oEUi(8V38Q`mL7BlVgtkK#maRkE>%S`U;#kyB0F`ej`PtILsYx&Z6bM93N zU8qlP@zQIgvGg<@Fdgs$q@!MjJYqQ1lC>hCm@N0f$I9HU6FI$RODb(}9rS-S0zL5t z17dVuQwzyCE8mAk&UtGeLb96H_n6$Yj9_Zdg119h$h`Lzsy31$A&tJ;8r^5rp0u6k zi_+y2kZNF|n1Dvzl4C7p$I^GrsyRW;U_;d6MQVaNI8w1Zs(s&kRwv$>cm?so4u$XG z3%^{2cOs(&a44D5DD@TEt;B8$OBKPi=6K{8PoF86D;YVpG=Q--a`zqv*Di}8p2v$M zblcqq=0}36UGt=rN4nVNWT>6}7Oc5hheh{KH3KFg+5&RN3d71 z|FWUPP~nafpk;Gac73lEO$#ZmM=TxO>{l{z5oLH#QG9f1-$7QIh94dgRxT@aB?BAe zW8WnD4x%4cwm}7Iw{Q=-TDS$M3M+6yBcVdi+7ANUcDMvZ5Hu`(CBn+X_9Vpwur=(` zxL_%nvKn$57l?YY>bDKY-CzoyE*Yi5F`s#WU6U0KoSz$vg;oJu9fimbsmU)5g>R^gTV0*ZdrfNk_Isx=A1o zU9yRYh{m_T7=oDi*EWGb{F2;WAdVrY7l>cnk3f8j2+5nq1?pUmYi$qnHZD-3kq&w= zD5G2Zm>k3v1h9cfsVMSq5w#lmDk}3LWzm@hoAT`^2U%~@z2m3D19#kMJt?uUp25n* z!LK0AO~t_juWu?2LNi7t_vgYIk<}Am&nqv+c<#Hq z0L1f1pxUh?1aPYWx5J7Xz>$W`@eo7{w;fnh^X`MeY4OtpxSbDR3N;e`sXWC^c-S}V za&tS}1-Joox-;-+E}$2?^qW>AXmv06d|E>6#p%*J8R=aXT?x9np++Z?AiGPp3drs= zzAG{HyVviKn!`mbUmERs)$X5y?X*8Yh096j=btN@#K=7|Cj@j!XP&ocGve-R_t-{y zTP+ONdHPQ09S?)6kDm$0!EwC6l=*6-2%Lx}$ZPR+f}gp z;ZY4@IKhx+0~wKSr#7|ARGjF%isH#$0yRIS9oH=&W_cnX{FKk9Y5=~;oIcIwbE7vA3=-(2m>TJp88eMOo<}Hv#oL~illK4) z8UmfZaI$bd$|g{}e`oFnSBtv|iPu6;G;c~TnpcW0Gj$LF;kX*Y*5Q^NNS$F*ebMjl zFEH#G)|%v(oq)eto1A6>rw7e325)y;{zzh%^0N!jt+i<9@6)5-6kq*`k#w8Odzlc{;KLYh*0BP$O(CId?6Tiw^8BX!e&f zPfo~OT$Nl|mD5tiUFsyPN~XDNR|H#R!ph1;|1RbWrpcOYmlCrs!JrD&ANV(!*T?4C zV$2wrnXoHgQdqG+E11y5y991QLJZi_uktCX4GpSFJBa*-pp)2$Q^esgyFak(pEc2; z|By9+!;s&)>9^Y^uf1ya|EJ8jjV!=iyOY_$CQ=a7qh;64XO5d_8UF;bRfSWk0BU%c zdT#<4=uyF{z9#uM9WRK#NlCF(4R+)a1;LYZ&2M#>q9v^nnfHLO0X!9zO<&s@%btE8 z!6~aL35D!dkBE8ZRQ_sNb)0)AXQ^1;zn&j-xF%CAJ^egelc}$fRP^_ybHYL7z&|sY z8dEC4Rh`Re($=h}SP0Wd{lyG%RDxQecuVHUPqAZ5Szm|IwilC~z0 z_r|dubwz-bc!D<6$Z)PFTd;!~(rX3{=b@yCmU?(f=1~<@JLpkilZV^M0JyyYw>CXn zR?aqT)ZDLuh9;sLWB{;5p86`Ii>vo$yLVC3#)((HO|I7-RU;eMstnKZ+*Z&~(6-3a z9a2A^O57;Q>WZ(Q0c|NfRd+-xR+_4)Sn@$mY{~ltyhlOklC?dfPrurCW3Q~N-m7B0 zSF)zwFfYi_IKE$2{a>^gR9eGfqKatzI=UxSQJ^)&5_Stu)Ad=d zd93b{um@P&*>CuH6tnL+g;HKB;@l8$GjEPh-fCX%-;19PK4J4oy+ zHTwVc8a8o6t5?>h^QKUj;%#DEYhjTv%(#d!hf(vcAe}J|Ve4ztdrTt?0N8>=Ve4aD z&c*q4!JfQJ{lqcQ6kq6Uf!HkriMIhXC-0v6iMDg``P3WqEtuXguwD@?YFL)w(?@58 z`sjivX|I%Q0=Yg~l(n*hhuC}(t4{2gYs`-=@)ceMsXXaq6LXa#q{3zao-6K8WlhT} zz**`s!`b`Wc%0buw1$IijVi3Gm5CSXa~iKI7KrNS5kA)=K`xUbwaJ%;9pQo^_0IN%aFq2EdD$>BfC7lULVF5sIAYE-bGRvGj&c}%*(_&9lu;!-> z$9IWg?0)n3a+|s2{pLq-d^k9s%eQK_5&^3=`PX5oI|~~FI3PO38VuC8x)aD6T{g}( zYae9o;$zh?w(#|?Y@AT6R#+byq9BNwThm0ez{uc7@zeqFVsL|660KV8@qVJv{uO~t z8eToVmN~;fwA{pJQ}qmPtJy79W|Z2n*od19a)`BOj1E1#! zUb?Jfmb#4lm>&1yAjr>-;#B01-%Bd=n7E(H*u5Gd&55LvH_2gyTaBzJs5`zY`HDOG z;q@IOPwfOE(@WD}8}*Y*k}I0t?^V(AdC%i3qVrfDT@jtP zEVkrxmeIarN}RO8BczZG$-fS0@sDdHzgSd3r@6VP%(6&)TX~8`tZ!dd^?6UjKIlU2 z?hW6SmuMiicL1g_0i+9d`nS5EXLM?U@8hey__7iqi4#)+M)tsl@*m9jy})lk=O zsp<@sJcXK|KuvP)p{d?hauoG0MpT3KlK0vB=Dw}-t7FFjhdb{e;k4aV@{!p_fTSa@ zYxFe8K4#w>kX`egAj25(y1vtSM^X%>)!}%f{D-$-jCe|sOmr67vr4#%Ne8Ydi@^^CGbM z3UVCCKkN@ByOM)RQq7}MmWLE+ek5&^t8gQ4V4&0pUyNO>ek)ZLO>D<_%oUiqSqixJC$|=PgT-O5n*G-V^OohC&Rdpi-s1ecr);;#^c zlzBTPn9kc5T0ttNi zF$E3Vv+1aD!a$5V?jt5E%$b~2OXh9al}&%!!ad&WJ5Ac-PXi#0DjonjDx%X`-MqH% zpu^|QtdP2#O}!JC`niq@*gDIbRt{>)5qd7fTPxsdHx?yp2YS;+iCzJ=Cgf zsavTXq`6kW5MKq7^^S*wX7z=RhJNdtwM$KkTr+UBZCIg zD0f|Z56Bc=u@+X~eJ9ne~MO6@%S7|b?b!RjYe!Kh@87FQ z)TX@u5m2ffH(FHCj#=QpvmH;i`gYt-U^jSRHMikSPlh_76phDeRAa1c3z%rd112K= zfg=S-li?oCG$Orll_qBJ!E%FOTOittm+Qd!j)CvOVntUaW4^&O#XhStd7fb zZOntCq-o|VeLC-6%&*#16a#{nU=p|89$8suRE~7L_cNUZb;TX@dxqEptqI6jPlGa^ z41E?TtOt=gP}YC2%W|e)^lV0KV)D5w?^gd^-eiz>1Ox>=VcYOF9_s!4fe^2!d6u8{ zh49KSuLA<2a2l4u!WwE~m#JYRul=&a9kMUueP5+w{?}Q|j=q@V!eX+!iutlzF-IGI zRLrM+Ddt_#KRcRu>nw4j{9=mWVym8EQNL3}I&aOhrpR71p$n+v?*phqB5a}gGo|^0 z)ThzJ;pEBe&ksZpmsk+@ydMwyHy!!xeszDY-37ZTYF<-}X+VA@E^_ty05!z|#G~fr z2fLss6BOmw(58H~X)6OaGNrSafnLQsBrK-TG_Aag?-liwG~#$g>Q6k;!{jo1OE=Sb8xpSzw!czB@l{6-!-~6Pxrtjca7SUAZOACR^0o(IPSK7 zCH6`tc1TXs2NV?>@Leo9*^*0&maS-5Qj=;NkJeqoS?<1;6U|?MtkNj^$|p64G^@6m zJ?eAjTT2E!Uz2RM9IcJoh_6384-re3K zz8V|AZ9=O!uF$J*<4OJQiVd*ZmV6Ku^efuKXtzBv6yB&x+&kB3PS&K7+8)q;*I`NC zHs<>5$`Ql3TWGkyIPY~CvBy%qJMBhDDt%|+3^MC>RDbEpd#0tiBPVIj7cXoi5{=7N zE!d}}MVWmpN}D)&{8r1OFudEAKuuS+v_j*-RaEZ=@%gC6uC0+I={bdKeUT{gx>q#j zUbAp-XR!M#ZBa)<;4{Q%tJM=X2-0}rXo)e@H(x2k-%@v*k`N_hYZp8fTBV&3L={+6 z*n}cAVYEffDy#qx*1C2#EU0T*oVuv9PudqeW0N`=-kQygs$bWbS>x7N&1_=5@G zX$2wV@3~v72(ZF?ML}t+ntUT-l%lM&mGuH;WlQ-XR&<9u(A*7fA9LH?Zsx9YJK#!C zm%848ugGo;z5@5Se3O=m4!iBj z)Hv`bs6!+*(%NGgF4V_+XasIN-$Kbab2qrL=C-@h=5n7Rt_S_Nz*pp|0$+tLM>s6_ z$aVb#U$NUK@WtFNfiK@h17D7d1im`=y^I{-rNDh5AL#zeG`Y(&ztvd4#Rxa+=N9QH zcj#w^ejd=z!}@t#KXXWusqyJIciZxmpV!cqW_Auzc(>h6q{fVY)x6zZrjH*b`#TR8 zX}zj4$y0W=WEHMe<%W90?Ui2C=zQ`K;#J@6O{7dNU4Fo9`tfDm1e!I1Lc zpPA4l)AlZ8@b;gdFGZ?8*_+Gka-&oBp%b}M;*ihw7BeliCj_Tjwsr35n{9_pqDX1d zk&y(4PYAv)en|Jdc30+?_JT*!4iKdyhbWPaPxp|-RgD+_oHM&NeGwK0ID&oQEVz`T zrit@DZZsW)HD;M%+)2riwElJ7)HHji zD_wGZwf2;A|IamIINKS=7=4+AdRbymY`c<)#D@=Y@h_L z*@e+`FCpMly2$R*M?Tk?99!CUxENx8{cx;lox2JU)Z$A8N`SX>EUd$w?!ydk$6MG2 zSEI0|@;^eU{<4#ecW~KBPm}cTxi(Z*6+Kr!GxY=4Qj>n7ZC}fIUWn*vrE#D54XS;e z`wG{mf4_?X!}BGTx=YkfQ#S3LN&;^mf<&ZXWj2Di#P(6fztSgRbJ&O=~s8b;v z5o7t!LS!@~q(ULhma9s8w&R798ayHS;Y4V7ig)2nfZ{OVi zZ0-hktHKSDH_6vj{x;<5*|!WBU6s^a(Ay7bu5!_ym$%K+&ud~?uI^agb~lTtZBt35 zF@Fffv_1V_>ccTe)*Wk-o+C+Ugt{&owtLU+0dWJa5XgEpqc%xD?ropz+^&|v>&RVd zDRzpbuA{+|=xCJ%jkfbGpw~fFqSY4Da##xLaQ{$LpoW`L_?}y0L9+@A#7WY3d9N=h z;9EWUqod^an;z}PTrbe5W1UNpMAEUz>fo6s*=_r3If>7jxh#+)se-ST!}tbJ(5{D|v(s+J&?v2U2lK9uTU zOQrh~(;N)zJXAi;Hr;O@6ww$I(JVJC!ah{Qry@J(q(DV*0y#LBUTj7DJ&3GOWL;-u zokc#W$Vto8>D{PVbW<)#o8J}_qP9_U^~}V_u7^!-I^1`r~Gn=U)AIjgkE#b{r&h6|=ni zc=La+@1-LvZ-watl@DuMpyz4Z#7>g@smK{?10`=ueK(aK_aVF(DtQl+TZH#20#Bob zS^mgS5&`avi^VVhq2!H3zfcWXh-bOu(F^P@ z;sGsg6j^MDu-zCoCp4wiowz+?#GVqzX?%yC{ z_4smgS>H2vgPUu_ZFRc8c)!YZcbPv>>ejhMmjZuku2<^X-Q#?QO5OXW)Mea+Cjr!y z!c7%AughuV>CIMLmg?G1bw^q4>)c_gB^_Dyhp>wn3Wm(Fq2TiO>Du~V(Oa)7_CJ)k zmymik4s5E&b=sfY9ao0>oc1!g-FILh*d8B%G@8&^+BQHExRmFPy+k!`6!nuw;HZ)?|oAgbFR!F)Y}s6%|S=L%v`X zKoQ|2sm?c+=1N)-RpkC{Dk%#C5Did{iCz-faErIlQPS|jy6AQ=iYa^c9Mpwg8;t1z zFgHwdOf66SgYs%qmum$p8egZvQyQZXKQY}AvFUmlbgh?>hn4-c1rjFJuG5zHc^W#Chb9OsXO?2=~l}#iS^MOyq`;KW2*F_KDYB=^*vMAcr zvGtYD#9CWen&!fSj)sfq72ee7TXIys+~fdCWz= zBMUl@<@&+&dU4r*tkp?`0{sXw0exK1+e!P-9<2>=KYRZRCJ^he9QT*2C>Yi}6Jf3U z@sb_gPNNsuK(R;Pn7Xwu zDwIOHj*^$+m#Txe%9eOXYm`ex&U;IvUTJhnoxYpONB&b%XCJiWr_(?K#P1eu~O* za|2(ld&GS9?#f}bYH44N1fP4ks$>GAOs9_1N6*c!u-5)IU19wjb%Du=-%(H%juCBfr zAsNWEU%1cPohImiTtd&J| zwjb#NCMtatz6Ycguu6DQ?)^bo*V|mb!+k=>h8N{tH`doPCWw2PIQnYydvf=a;fI4V zzvcbZ;GWzA3$-j(UY6#bTz8>bytFNX2x&V48r1ymER>73!-9{KY^Jl$9Vd;$Xt65r zjdX`w+y?h+bKBhkifJmpdbN6wcc9DPN}^MIBq>NozZBS@9#mbc^=Efyy}uL;JaH6_-)(W; zG^6DT&CA?7zY`mK1FJW?xYekbD!&n-A$KF}7K)*NlHBy~U?%8IG~BtGOTETy!^mMF(CqHTA`9lnV-y#@ z-9Ymh!ygL7wZB5_tY^qZ>Og_5?ju`v+g$4C;tNTg{=zwx=DSZNc<~ju4+3A2TOIg{ z-F3RH>EtJuwq-n#$jQUH!Ztomg?Bi51ZlE$o`KW)8cc^Bz6Kj^eu_L;Flmn8w># zJ0w@)y^t&4bjcO&S?}?N$(7mtHBO*E+02Uj(gjAk9;l&{M0|g^f9yU%iOl~Gq-u5!(l=IX>{V${4p-ia@$~s8G5!i0C zvPuqC60d0kZxDC2#r=m&dF^Vlru#exO@%V$&Am*fd^{PMa;u~xJZ&8w*2${P_Qx{rG{n1QTg++7NXY{t4<@X3CB$GvJ_ zt9$BP)rF1eVe?2Sni2SN-ED!7_qhXKfxABN6}j<&uh?B2_)6W`fv>`y8u((aF7Va4 zp@DCtJ0kFncH3)PXgYGo^&ur-G}!ijfNLs0@)dQx?8kR0_UG)!w~qO5?8nk)yX?mw z(?g;CxaJ)7;%4^adZdaFd7(*{_uSd`&3PAdH@M*nH$>Werm6f-kgMn8?=*}$WY z`BXY8h5xtqY)mMiY@6DAHDUw54^pRIFM({KbUN59MN;4{QvG?C>`~ ziod4Mrt+Q!)&WTO-%*BIbQ5w%Tx01u|EHn@&XbW0uBqerf#;eBEg;fMX^d-*BS2PR zk-LU;(X7ikO}Gk&bPI~0c&V~S&+?;XUq*+JYkHGB;F@MN&vQ+Y>(SBP;a-w_gKLWY zG~=@$+WBOJ_bhW_k!P8G&k(JQ!ls+ftF|!Xm#8?&PvbFqGr!?A5K?UQ$IemwGdM_a zbw%T;$HeN5Tv5_UsZrTUEg>6U-xaxis+Qy8U|T z7^sHh(}S=AcgVwnCGypYgItr!Rf9NU@Wasn>zBYmm*%Wf=7P@O*4n zR5<=Np@kcL*UBswLE2;n`|<8PQ=yi(^%or$sP(s>?^`_;SFOI$zB}ARb2qpv6>hD* zNWP}>g%Fh|?%jdV?FTd>?x=>^&53(?usEWKKd83-DWmP#a9^rUBBvs2UfMg0o0QXe zqbAw*t-JPQsI>PKwni?wE6xb#F|w4^{&(*moGvh!is(?=|AX%zAi!h4`2K;ADho{K z`v*)Q+;wLHcXx%|u3@$&bM=(HThwbkovXW*NBWmsV#y!t_wIUq<-(IGx2f~Jf;DJC z*6%{(3`CeVLWl1av~1usz|Xu_Fcuvmw2%D1_+G)K(szIMy@H28OKs|Gv#Qv81&8hf zvW};1vd5S;l*R0(Pnnee|L}hM7sL&+Al9a~DGY9j$I6ji=pMHicCKT(dXSf&b7fFd zOig;IttIs#&|AOaB<;N4{z~Pu-70aNWv)#PEDWAAxV9k1qjh>1L90!D*mmQySBKff zmZg0B@9wwXGR!VA`wr6PP{se`e*2e6YEVmxED=kP4=YJq<_ctw=Bsud9FS$YG?2NX z)PwwoFt5p9tMh++zx_#Fc{xvF_5Sbfx6e}^BwUU`@3stz_`kZ}ehE~rGK2f=pVTM& z-&r&sRhXMOn7L4M=l%_C-q?iRS8l;b2oYh6uE3y+V6na3EkQ71X1sr?<9I@9QfILB z`<-aKr$t}D2bZBZMl>yG(>`lT) zR3^u*IL&rpSJ_j8vU{m)&e7yyD|o>}|47tq1<#DfRxoy?)U$O)Ki$XsRqdVQJ(m~I z|E36#(m!r@Bq7Rn6}{U%+aJ4UYxs|BVtiMEuxhq-SDv&l+t`rXwr{vTW}71NV@*KT z@C6hRoz}9ns}BaWEbV@SO7rI5^Fef0xAc|62fS*sk3m43hZ0|)Wv`rFg$GQn=>AM^ zkeKdQrh7Bn(URt}$>@pC^uM&=%rh@LYpg^OOEVnzfA-LUEOc#`H6~eSD|m$R>M25r zLXb>aIyB^S!8P4&O^`Mq_oJ#3RMZziSN4ZU2`t;c9z4Qr~oDM4HpTg=1vOwXmr88O6IEEknx6uN z7b#p|6-c)Pv~O7N@^gsHsc4*C{i%2#u@oja=%mf{*>3My1h1O=^-kN2XtUMSwlOAb zp#NuIw3tPSHnOE43_pcSE?LwFcuWT7Z6nj*d!mdwHyF5TQp1cWI$yKU<-`S=AJWgA z<#WFOfBCM(ZR>T8_Ptu3fy#9+)BzHh;%H*4rVr5@4-;%WToO&>;p1)3!f}(KHI}Nn zh>C4@_IFgQ3`|Gky3@no>ya+G#Ayz@xCY2T#wIs0JqS1VFBM zD)4ZSn)3*-u&v~CvxHs>rq0$1j^IKu6}egNh~H@5NwQ7?rf>+jDkSe(UYxbNi3=>e zUl3jwOINWE3W45V+%eiBqeQmtVe^Y$T1V}ijjruB<<$8;(e$f81yVBqVmJ%ucbdBo zcvY=GQx+Fwe{mPLRyK9yTwYuGZEJSJcy9Kq|CPsWE+Jdg?^vDe7#w|i_@JN03{DO& z{mI}Gupo&MB-2PO&0Ka_!DW{$v1VS>x1z>zZ2(&+)@=k|Rje1MYInd}o4YZ#KmRYS zOmEYRHRL6ko?pctXnRZhHjW0B_uLr?|0uLjn{=5I>08Nw2`kJR zooNc(%W=DnKx3Mrd$w@E`|h&)gOhQSzzPcgIWnO%oQKhBX`h?xdrxHIPy|w`43w$JF7$~+Ypg59#TvFcafsXijj71$`6SesYS`@7Kkm3= zNY4rm@Kz<)cjIUVdw;%9jJq1ii}3$Kg(usaHeMCIHS+0X#^;I-!pw%{I}2M3gjv~gm1iZcRhkmfcDN%<-bRK&A=-(tO36aHr8Iq}A_prrpj|=Z z-Z)VhkpT*!Hk!Wkqbb0tAY=&Ir$#=I8^*j-UUv##vSaJhG`AxOy zHt~m4P%2ngwe4B9TURC6IP;JRuxkK?$Xvgbw=s;o$s!}WiD>@=QxS!B!xYH-#0Qzs z5qez)C^RH;p2}wRk@fS0{O1aD1Xj@Lmhvd;9EqH;BVn1KFH@0w=8~;@mv*BUx8u=N zGHID8vOC)_{)D}%8Ni(E+0<#X?CrMF4B$GB3*!wkoJY1GS=O%_EO?1byJcH!Ajn~K*VS(T*dBzqh-zZ zua0YHOfdu4GE4BDOCF=Rcww;tqwQNkwipVQn=sVJ)>-UNDoxpYp8u8Cgu_iJ$%1MN zgEO)lT&S`2VBmQicyu8Qn^3}oH=O4E$@Kyrq3Pg+XnBM4@-Z?~3>=KSnG5ZL;BXu& zK_kelwiDxb27PUk(X&uM^`paTJWEbm_lrz5hA1V@HAKuQ+=QuWf_%k9`W@i2#&%M; z@xZxNoAbaz?hxtD1J%Y~h-xcia~?Qs$R<3nS4UpR1AWNXDIk(>8xL?^*wTB>fZ@iV z>Dqc7=ZVA}kg#=4(4(D_oSv4ZU~jTqC|L^mTeo@gzsG{+6ngRxhLxWq|7InG{H>DY z9A5_Hufp{Q`KuRunC{)~zQal)wdV_2OJIvqw=VG2xix{0^W1^2!o3jqM!Lm;Z?v0> zPb5C>&HELUESH&lF6RVeYZb6Sk-Py?10yu$RFaG08ivS&JBtDwQc?@ zB7Xq2T138wK^QsIGg@@&P&2+oRsa=*9*rN$_hyiZ;yq-!Kqf?$Ue5-(Y*K0-=E2|4 znaM_zD~4(Ayd^fKJJ+;#Jj+l-+x4*Z%4qyb85z>Gh2sM25iMgkm`q5kGN%z2icpF5 zg0NUs`}<0&4+bCK`cKZ$Jh$E5Ug?GCdSeH#-gl=WlNS=A^OOK8lKyY|xTEn8MdAMw zA^NKFLPe@XLe$EDid4A%jEdUb0-7#ppTZRd9Q(VF0s}A@|Tn zVgG-5c4z-@^r&kU+G zne+=)O2lMl7?RZ8%J>U{DIBvxp~rJfW0h~7*8%iY(5BeTJSuyG;zfBr-UvGY#m>qr zS|ZX%cZW1{yyi^Ct-)aCnRHJ1n&NU8|Dk${z152B2;@e1n!!^ z-8qQgC2%hY!e5x{)BiPaAIEL(vPb&)U`^+KHE&|%;WQZnWn06Z5X^M-?i+gOIPN!K z$L{Wh9HPiYQk+e?&;&{lugXo9!LQ4HcOdprtbIF1Z>UB$4z~mzdZtF?cGq^eMCphe z9tpMYclhp>8RK73G@hl5P&;f>vf(lrG27jfB$T8exqj(}2PxxOCL^lxp3&aiSRv4;ahx|dUWk=1FgMz{I*KO1 zn;V&h#Fz`#>S%JV_OWbIXUa^4E*gJVl7Ksz#(Fbb*?ZCW1PiLy+>-e}B~Z+8zNF_~ zq&SxFM{5uAIAMLPcra9NW1(ph05Mtqz6x*|-zz#zmY|C8tAcQzLt5AUnYA+s=MjZx z&hQqQ%SMHQJ;y+b>@rj8-@w8qz3`+vjRiCp|1p3H`6#FD?@HPV&BVllcLG5Z^KM12 zBAUDN(AmP9u*OoC>)jz^oLaRh{I4)6`#JcZvG9QywLY+NbaB-=Hi2u{9?XvK>z`Mu z(4>%s2q7P(*lf1BhJf)Z!0+=3)*~uUul#NJp4=u_r)8skmnYjZDFl=?DswHe#;@OW z+Dq#)x1%x0ej3Am%J850PT#`BSPdpSOW4*IVTEuTk5a=FF4(l+EPS$UbY?&5&^nRc zQyb^sQ?q1kZ(>4i>46FL{6XYSm(P*^x86Tf{uAWq(vcgUlDj;UGM7gHHu+wjnGl34 zelvSzk>;*wAYNNVP^*)nx7^Mllj+}V0#QmNT_H_BgO!mp7b>Ymf6(kqu8n@^4>S1I zpQiq+y;tUswer?7O3n{lm8&!@xcYOyI#g(ioc{m@s8Sr!sN07Ob(d_&oGItF*L-SKU%8evh%;+J=W9HL!SOMz? zVtQI5eTMODGBvny13%ZTqWSTbhN8vO07~l9DqOea+aWy$cEJb8*S13AJgT2HB}nR5 zQfFmrjI}lQy(qb|@mgkq1F@lu7=k7sGucNd(qt_rS#k*%bWKKwtslHto$IE*B^veP zztq#Q=*@Z=7j-!O>Za;&{p>&sZZ`$E?Vg!j;r;}L*uBK=&uTe$5>qLA%R~+9)hzI~ zQ58*u0?hc(?h1dcl#!vQfwCq~Bt4o5crRvKel`HR)+Sg;^08^u_B-^KWn3eMh zqI^r`PnU0xWB&&M8B1aPstP1q+hpM4IvH#7)qoYkK}0~rly;lYS}Em4dkhLSo| z5_~m2OvuI;eK&^R_$P;cvKgT!xin4VBR!$C&7JW-$CHDNC&$+ISj+6*?PViFWHQz2 z6)*0#Pt}nCmC+cKiUn;da<1U&@d+vDtT$uHEtF<5ac+(EXk@4or1~6%BT_0-c3yLc zrH(HaaN`U(1o!w@@>VY?Qjr(IivTVrvHs*Q4gIz%5t3Ns?jUJJ7){bx=x=Hn8zK}? z>w~0qVKhlchJKSZLF-bHQv|g2TiioTzm6tpVD}j5nzdX?|H37hC#+{FZ7fOh1ut1; zs#f6wz#2^v3Q(i#6gW;FWE!tj{JB}0w5Dbm3vgbUjZqO&Kq_EX2b@t4W5bfXF3@g* zIE94dfsy2EZ9Dk!lb1-cc=a6nANgv^PS0=nOl+fN`>5=q442P9e607qUYq>!**&Op z7}^BfQUN>Pda_AS?R|{7SIRw+QZtolyTZ6!_nZQ0MHT?lIyu&*Ud~j>BI_@*5w8fz zYMq3S{%jFzhrkM1LF6zNXX5_`(%Q0?=#5`kQ>R$hX@r8IYxZC1dNYq=+-D}OBCzEY zc#E9sHVLrN^vK9|Cx!}^WH22w|IZR%+^(&40O2qv947_TY6FP~0A8h%Lx2U-oq~yg zP9QG}fjnq+?R>BQm8&mNKScJhFoF?7!Ah&Yh+5@Yt7QA~_*$z*N?~1DW^{Yzi~v1% zdUSnpS1_rcVu!vy@K$}|OK7P&Y4v*a}IpSMpJ^LXDq^A!JL4VD@J^DTFF-G;^ zU>*8ZaKX}_d{N&+9N`q`=1=md)ok_^?rmWkP&Nt_+11QN?RPB}^UM7-u2eada^9-~ z_m_KMXlKe<8v00SXr-@WzOPzTsrqVnOBq>61C`9=#iqjVUPWyxOYfdyWChdL+~Fe`*z(4izt4H*NSdEOD5Ff5 z3_s4Ij%Ofd?C1o>C-Hz)Lb%5x!$Mi!J-fz7D6CUsBvCW4^8Ok7#nI>UQQivF%al+5 z$sNRi%yJZ42iVM3kk#;O%*VH!;3r^T92clIS`xqWPiE1wCGn{w@Jr&`mdG%8XP|(5 zU;k@%IqC5RNzhR7U}r;tb~%n;#x0PVi=hOjjui?B863J4iP z&d>Jg%Zl2xPZ#*0?tR+myBWnI7+rp*PyZ=7k&2{g?tk{_dq*hJ#$S!Su%`xX8^|{8 z$arC+McCC~Ax){PreynWl!EcU>cjd2Sm4l2yF8tk>17KYbAshS?EeR8VV*!mPE}+o za;(}c$}TbZlZ_q^yw7De_MQy6f#)%6-> zvrq6{6u8F(?wNsmg}KW!Ee|MPm-}Jx?cJrBr|f%aW@8)Ty4#{EchN2e4ihD z--O%Eel&vDX}Bvdmi&gDI^QpzDdyC6ou#HDb6M4U6sFlhO`0uURjHy%j70siVn%RG zqp2%iSVgXyv{zU3Z3D4MYNe=V7G9vIJBlnlEH+Zq%AYRb9xcCi;uY7Bq*O_iw!%Er zRh6aJtb~01$v?iEU&15|pB(rrNh8LU=BXNPRk#~`F)d>^Dsy=bNgkWyZ5YhcIP?84 zSGX_OZW>a=v%kx*i3Gd3mNqk8u&so;D=JGU*(93#P0C)ZUp%0rYS8%w7129e+n(ya z+mrbl_u0Hq$?J7j=2U{|@K(aZN>i?l*~bVv#FFV)lNJ zS|i(0u5yb+^UVO}1ro?FCIKC0hQ9(~QL6$)1lA_+x56dlDpU%8phuOP+7$MR;;mPL z@UcN!g@^rsSKS~KQ^Yk&!K4Jeuccwf%qTv?{cg$inhT@MvBNJlF25{RaE&g+k8!aw zXLPj?85@)$qa{^|nZU6~*q(=vshXuMj_v%ndK>mw8I1BVF#jcasf!&B19S zPF?BxgxLZXiz%ZKB?JcJei%ck50J9lMSI)Ei^<>c!Anbp0<__D&PaZJvkMrh3RIfqS4B*Bdgw;4M3zlVyTG)HF`^&C%$bnjY`gl)YQOOF$okcuBs88;I^P zc?d)3SE7&8S;TE?*t+eiW_voRt$v(cz|MV7+Nz1YNCQ{X#*X^6mCvb(Z6}8I6LjL< z)>I5IgJ|lUKlr8|>^>-v9R7%#Kk^I7ozCm6VP7mydpnNN#Ak{7v5b?@vDS7yHY96e zr>WOlI&WrRf(FzL-7K9;-M*`Q@7;FKCcS6!hMEq}**VJ|d+0nnmi(UHjA1ND9lebN zPKESV#C%;9Pju?3pQE!=QMGgwn0q!$%5%EpMt~%2|L5JI`+v@ZOgj0^Y`Pd|%mk*X z^-Mmbj|^v?CWFY7Uui2;!)WmGMRlP62rqa3KE%t5d)dVWJ@-+D_XC9F-L&P-^k@sU z?nbR{+L=G_e(#F*4pEvUfB{WinFv3$lV`qdH?a6p0Ga-fif0!fk&GQ|esGGuAo`rf z@mf7@R^E9PL!ygT+T*+?2{;dCswU#;1eap(Xw%w=_$ivWi{unvMNmNy&x%T*YB+KNH2(u@GiS0 zxUd#SJ|+ge*rO&;t1HOl{t5QgPuZr5MLupO9b=B97jnu}J4-jv<_VDoI9Kt$*gAA> zEI?to;0q;eN00u<^;1d8upj|vjSPxYR`(5%s~;d{QDL_&V$%L{+{dU*)=@}^-ivgM zgMO|g5*pAgasR%mfgj0ud(Ia zO+6HDdwZ#lOv3`eDWtx*XMofxKrM1ZdE;ddt1qOj@h;Y*JuuB~#SAH8HqbTP<#+t*&_~rJVI`EWP`NSkr{utokiZTk00je4d^8 zCe}K{D;TXqMyfkcTWaTDDo+Nn*(0?TyU&uLdIC=;JnVGCOgg%;{73uC_%RW4-()VvP zzCb0UA}6MW;4Pw4b%aQZRWOklkpXI)hK5FhZU3HD*jTjMP4^p<42iBe2O_Ik8Pnmm zv|u5`n@kktGD1r-qva`DMADKC>>zi0f8?zumc7f$F~gEDoBaUR7ln?iE!z-Gbi=4t zi;9dk@&xpQ#ciqn>!)AXZP4Add1G}s-)H#pci zEJ(K!`V#b>tH*)g?3ZmR%M*}eXm!YcJ1@&!Xc|xXMTAT3eRMw+xH)#j9y0{Iwzu8y z5vKJ&UH6wNAJDDLWp7btzLgp5lfZ&u7)q7*CY}3%kwa>a!aCI+D_hov$EaRgnfA58 zzWh!4)_uYaeQN9W7AE14gRil?@-*ls8uu!b??qmYKbz6Q4@UkahnF-j2K=0WyMNf# zZ_PDz?>D<>=n-NQy8~7_Z^tZ8WkZh&q{v}l_luiEVLc}vSeZJ?jUpirGnwIx3?Fvv z6bw^e4uK{X)qmIFl8Ys;B3IL!5|zGj;Yw26W+DOIN^%-<0@0|X?ie7H9J&n1l`iFr zSxsChkuBZ5CL$vrf+JOdx9t)v-3%xwu+j zn&@uQrzR~EGjFbT+W9xAbTphg+D6$r2_dTu9yc+eakw`1T(*>CZbOX5pT|?#I1%-z zAL~;m4>58!!ur-7g|UE5y|YQuqrQ6a6(}X{`$e|D#RgUg-~AO5so~IFy3ZF+Z?-ly zCs>>6@M}{K2)+TYKEp#WV5nsDV881BZ>@bucN>K`nH%#RKB7G6@WVlQ7I@OK(?Q)C zXes#dyAvmohc%}|D9;W1SZhw)e*s5}NH4<8=t3vzWn5Fe-&Fc~uMg^Nm`uHnK#8+8 zM|7)q^5mbX_t?&Q=a7ebU&L{*f8^`^5p1~CtsUrC(ZmE(56ZU-+B7LFyMQ+Jv$D6C zxT9~wtrX%-PIv4rlT+j$M&!t%Lv1LDoK5;h=}7yk(Bw}(@lR8}?#SrPCF?bJu;dt% zhEs3v?k>$-W8X_N7Y6R6z}+u!Cz!iD^XuSyc<|lN+}6yv;QP0@o6VoQ>UH;qQ4cEj)X_ EKeRhrhL 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

_2+XH=d!}M;RK|$t4$7eH$vYkE?GNy`Kk2 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ǔDp8-VAhXDx5}RQKT*1k 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�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

Yq_!*J}Q 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 z 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

g&r7Qwi+P*2;jMoi2l;2!GLDn^C$J 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� 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 literal 0 HcmV?d00001 diff --git a/vendor/cuobj/lib/libcuobjserver.so b/vendor/cuobj/lib/libcuobjserver.so new file mode 120000 index 00000000..7e5db08c --- /dev/null +++ b/vendor/cuobj/lib/libcuobjserver.so @@ -0,0 +1 @@ +libcuobjserver.so.1 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcuobjserver.so.1 b/vendor/cuobj/lib/libcuobjserver.so.1 new file mode 120000 index 00000000..dda798ad --- /dev/null +++ b/vendor/cuobj/lib/libcuobjserver.so.1 @@ -0,0 +1 @@ +libcuobjserver.so.1.0.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcuobjserver.so.1.0.0 b/vendor/cuobj/lib/libcuobjserver.so.1.0.0 new file mode 100755 index 0000000000000000000000000000000000000000..020962b3fc4b1a2492ad8dba09fbcfff026f37c3 GIT binary patch literal 723472 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

1*6 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

4k%f&1l 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 literal 0 HcmV?d00001 From 3398399f621206e862870eac1ce922c32f22f0aa Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Tue, 31 Mar 2026 17:58:18 -0700 Subject: [PATCH 08/25] fix: Append buffer address and size to RDMA token for server parsing The server expects the x-amz-rdma-token to be in the format: <81-char descriptor>::; cuMemObjGetRDMAToken returns only the 81-char descriptor. rdmaPut and rdmaGet now accept the buffer pointer and append addr:size to form the complete token the server can parse. --- include/miniocpp/rdma.h | 18 ++++++++++++++---- src/baseclient.cc | 4 ++-- src/client.cc | 4 ++-- 3 files changed, 18 insertions(+), 8 deletions(-) diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h index ff15e3d6..7642c14a 100644 --- a/include/miniocpp/rdma.h +++ b/include/miniocpp/rdma.h @@ -47,7 +47,12 @@ inline constexpr int kRDMAReplyNotImplemented = 501; inline constexpr ssize_t kRDMANotSupported = -2; inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, - size_t size) { + const void* buf, size_t size) { + // Build full RDMA token: descriptor:buf_addr_hex:size_hex; + char rdma_token[256]; + snprintf(rdma_token, sizeof(rdma_token), "%s:%016lx:%016lx;", token, + (uint64_t)buf, (uint64_t)size); + minio::utils::UtcTime date = minio::utils::UtcTime::Now(); minio::creds::Credentials creds = sctx->provider->Fetch(); minio::utils::Multimap query_params; @@ -80,7 +85,7 @@ inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, sign_headers.Add("Host", host); sign_headers.Add("x-amz-date", date.ToAmzDate()); sign_headers.Add("x-amz-content-sha256", kUnsignedPayload); - sign_headers.Add(kAmzRDMAToken, token); + sign_headers.Add(kAmzRDMAToken, rdma_token); sign_headers.Add("Content-Type", "application/octet-stream"); sign_headers.Add("Content-Length", "0"); @@ -155,7 +160,12 @@ inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, } inline static ssize_t rdmaGet(s3_rdma_client_ctx_t* sctx, const char* token, - size_t size) { + const void* buf, size_t size) { + // Build full RDMA token: descriptor:buf_addr_hex:size_hex; + char rdma_token[256]; + snprintf(rdma_token, sizeof(rdma_token), "%s:%016lx:%016lx;", token, + (uint64_t)buf, (uint64_t)size); + minio::utils::UtcTime date = minio::utils::UtcTime::Now(); minio::creds::Credentials creds = sctx->provider->Fetch(); minio::utils::Multimap query_params; @@ -175,7 +185,7 @@ inline static ssize_t rdmaGet(s3_rdma_client_ctx_t* sctx, const char* token, sign_headers.Add("Host", host); sign_headers.Add("x-amz-date", date.ToAmzDate()); sign_headers.Add("x-amz-content-sha256", kUnsignedPayload); - sign_headers.Add(kAmzRDMAToken, token); + sign_headers.Add(kAmzRDMAToken, rdma_token); if (!creds.session_token.empty()) { sign_headers.Add("X-Amz-Security-Token", creds.session_token); diff --git a/src/baseclient.cc b/src/baseclient.cc index 3696d90f..7ff78725 100644 --- a/src/baseclient.cc +++ b/src/baseclient.cc @@ -1385,7 +1385,7 @@ PutObjectResponse BaseClient::PutObject(PutObjectApiArgs args) { .op = CUOBJ_PUT, }; - ssize_t ret = rdmaPut(&putCtx, token, args.size); + ssize_t ret = rdmaPut(&putCtx, token, args.buf, args.size); args.rdmaclient->cuMemObjPutRDMAToken(token); if (ret < 0) { @@ -1975,7 +1975,7 @@ UploadPartResponse BaseClient::UploadPart(UploadPartArgs args) { .checksum = args.checksum_crc64nvme, }; - ssize_t ret = rdmaPut(&putCtx, token, args.part_size); + ssize_t ret = rdmaPut(&putCtx, token, args.buf, args.part_size); args.rdmaclient->cuMemObjPutRDMAToken(token); if (ret < 0) { diff --git a/src/client.cc b/src/client.cc index 2e16ec00..e1d025e7 100644 --- a/src/client.cc +++ b/src/client.cc @@ -421,7 +421,7 @@ GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { .op = CUOBJ_GET, }; - ssize_t ret = rdmaGet(&getCtx, token, size); + ssize_t ret = rdmaGet(&getCtx, token, args.buf, size); rdmaclient.cuMemObjPutRDMAToken(token); rdmaclient.cuMemObjPutDescriptor(args.buf); @@ -495,7 +495,7 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { .op = CUOBJ_PUT, }; - ssize_t ret = rdmaPut(&putCtx, token, size); + ssize_t ret = rdmaPut(&putCtx, token, args.buf, size); rdmaclient.cuMemObjPutRDMAToken(token); rdmaclient.cuMemObjPutDescriptor(args.buf); From 2129843d93ca23ba26513ae1e18f841900c07428 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Tue, 31 Mar 2026 18:11:02 -0700 Subject: [PATCH 09/25] fix: Remove trailing semicolon from RDMA token format --- include/miniocpp/rdma.h | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h index 7642c14a..35e5c4ea 100644 --- a/include/miniocpp/rdma.h +++ b/include/miniocpp/rdma.h @@ -50,7 +50,7 @@ inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, const void* buf, size_t size) { // Build full RDMA token: descriptor:buf_addr_hex:size_hex; char rdma_token[256]; - snprintf(rdma_token, sizeof(rdma_token), "%s:%016lx:%016lx;", token, + snprintf(rdma_token, sizeof(rdma_token), "%s:%016lx:%016lx", token, (uint64_t)buf, (uint64_t)size); minio::utils::UtcTime date = minio::utils::UtcTime::Now(); @@ -163,7 +163,7 @@ inline static ssize_t rdmaGet(s3_rdma_client_ctx_t* sctx, const char* token, const void* buf, size_t size) { // Build full RDMA token: descriptor:buf_addr_hex:size_hex; char rdma_token[256]; - snprintf(rdma_token, sizeof(rdma_token), "%s:%016lx:%016lx;", token, + snprintf(rdma_token, sizeof(rdma_token), "%s:%016lx:%016lx", token, (uint64_t)buf, (uint64_t)size); minio::utils::UtcTime date = minio::utils::UtcTime::Now(); From b506d437b93af5af8b9b224535f22cda7014250a Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Wed, 1 Apr 2026 11:53:47 -0700 Subject: [PATCH 10/25] fix: Add httplib connection/read timeouts for RDMA GET/PUT The httplib client used for RDMA S3 requests had no timeouts, causing hangs when the server response was delayed. Add 5s connection timeout and 10s read timeout to both rdmaPut and rdmaGet httplib clients. --- include/miniocpp/rdma.h | 37 +++++++------------------------------ src/client.cc | 18 ++++++------------ 2 files changed, 13 insertions(+), 42 deletions(-) diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h index 35e5c4ea..201a9f63 100644 --- a/include/miniocpp/rdma.h +++ b/include/miniocpp/rdma.h @@ -48,7 +48,6 @@ inline constexpr ssize_t kRDMANotSupported = -2; inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, const void* buf, size_t size) { - // Build full RDMA token: descriptor:buf_addr_hex:size_hex; char rdma_token[256]; snprintf(rdma_token, sizeof(rdma_token), "%s:%016lx:%016lx", token, (uint64_t)buf, (uint64_t)size); @@ -61,12 +60,7 @@ inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, if (!sctx->uploadId.empty()) { query_params.Add("uploadId", sctx->uploadId); - if (sctx->partNumber == 0) { - std::cerr << "partNumber cannot be zero" << std::endl; - return -1; - } - if (sctx->partNumber > 10000) { - std::cerr << "partNumber cannot be > 10000" << std::endl; + if (sctx->partNumber == 0 || sctx->partNumber > 10000) { return -1; } query_params.Add("partNumber", std::to_string(sctx->partNumber)); @@ -75,7 +69,6 @@ inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, if (minio::error::Error err = sctx->url.BuildUrl(url, minio::http::Method::kPut, region, query_params, sctx->bucket, sctx->object)) { - std::cerr << "failed to build url. error=" << err << std::endl; return -1; } @@ -118,10 +111,11 @@ inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, url.path = ""; url.query_string = ""; httplib::Client cli(url.String()); + cli.set_connection_timeout(5); + cli.set_read_timeout(10); auto res = cli.Put(full_path, headers, "", ""); if (res.error() != httplib::Error::Success) { - std::cerr << "Upload failed with error " << res.error() << std::endl; return -1; } @@ -133,22 +127,18 @@ inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, std::string rdma_reply = res->get_header_value(kAmzRDMAReply); if (rdma_reply.empty() || rdma_reply == "501") { - std::cerr << "RDMA declined by server, fallback needed" << std::endl; return kRDMANotSupported; } try { int reply_code = std::stoi(rdma_reply); if (reply_code != kRDMAReplySuccess && reply_code != kRDMAReplyNoContent) { - std::cerr << "Unexpected RDMA reply: " << reply_code << std::endl; return -1; } - } catch (const std::exception& e) { - std::cerr << "Invalid RDMA reply format: " << rdma_reply << std::endl; + } catch (const std::exception&) { return -1; } - // Extract checksum from response if present std::string resp_checksum = res->get_header_value("x-amz-checksum-crc64nvme"); if (!resp_checksum.empty()) { @@ -161,7 +151,6 @@ inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, inline static ssize_t rdmaGet(s3_rdma_client_ctx_t* sctx, const char* token, const void* buf, size_t size) { - // Build full RDMA token: descriptor:buf_addr_hex:size_hex; char rdma_token[256]; snprintf(rdma_token, sizeof(rdma_token), "%s:%016lx:%016lx", token, (uint64_t)buf, (uint64_t)size); @@ -175,7 +164,6 @@ inline static ssize_t rdmaGet(s3_rdma_client_ctx_t* sctx, const char* token, if (minio::error::Error err = sctx->url.BuildUrl(url, minio::http::Method::kGet, region, query_params, sctx->bucket, sctx->object)) { - std::cerr << "failed to build url. error=" << err << std::endl; return -1; } @@ -208,16 +196,16 @@ inline static ssize_t rdmaGet(s3_rdma_client_ctx_t* sctx, const char* token, url.path = ""; url.query_string = ""; httplib::Client cli(url.String()); + cli.set_connection_timeout(5); + cli.set_read_timeout(10); auto res = cli.Get(path, headers); if (res.error() != httplib::Error::Success) { - std::cerr << "Download failed with error " << res.error() << std::endl; return -1; } std::string rdma_reply = res->get_header_value(kAmzRDMAReply); if (rdma_reply.empty() || rdma_reply == "501") { - std::cerr << "RDMA declined by server" << std::endl; return kRDMANotSupported; } @@ -225,20 +213,9 @@ inline static ssize_t rdmaGet(s3_rdma_client_ctx_t* sctx, const char* token, int reply_code = std::stoi(rdma_reply); if (reply_code != kRDMAReplySuccess && reply_code != kRDMAReplyPartialContent) { - std::cerr << "Unexpected RDMA reply: " << reply_code << std::endl; return -1; } - - std::string bytes_str = res->get_header_value(kAmzRDMABytesTransferred); - if (!bytes_str.empty()) { - ssize_t bytes_transferred = std::stoll(bytes_str); - if (bytes_transferred != static_cast(size)) { - std::cerr << "RDMA bytes mismatch: expected " << size << ", got " - << bytes_transferred << std::endl; - } - } - } catch (const std::exception& e) { - std::cerr << "Invalid RDMA reply format: " << rdma_reply << std::endl; + } catch (const std::exception&) { return -1; } diff --git a/src/client.cc b/src/client.cc index e1d025e7..63261df4 100644 --- a/src/client.cc +++ b/src/client.cc @@ -396,8 +396,7 @@ GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { if (rdmaclient.isConnected()) { int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); if (res) { - std::cerr << "[RDMA_DEBUG] GetObject: buffer registration failed for " - << args.object << ", falling back to HTTP" << std::endl; + } else { use_rdma = true; } @@ -409,8 +408,7 @@ GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { rdmaclient.cuMemObjGetRDMAToken(args.buf, size, 0, CUOBJ_GET, &token); if (err != CU_OBJ_SUCCESS || token == nullptr) { rdmaclient.cuMemObjPutDescriptor(args.buf); - std::cerr << "[RDMA_DEBUG] GetObject: token acquisition failed for " - << args.object << ", falling back to HTTP" << std::endl; + } else { s3_rdma_client_ctx getCtx = { .provider = provider_, @@ -430,8 +428,7 @@ GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { resp.etag = getCtx.etag; return resp; } - std::cerr << "[RDMA_DEBUG] GetObject: RDMA transfer failed for " - << args.object << ", falling back to HTTP" << std::endl; + } } @@ -470,8 +467,7 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { if (rdmaclient.isConnected()) { int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); if (res) { - std::cerr << "[RDMA_DEBUG] PutObject: buffer registration failed for " - << args.object << ", falling back to HTTP" << std::endl; + } else { use_rdma = true; } @@ -483,8 +479,7 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { rdmaclient.cuMemObjGetRDMAToken(args.buf, size, 0, CUOBJ_PUT, &token); if (err != CU_OBJ_SUCCESS || token == nullptr) { rdmaclient.cuMemObjPutDescriptor(args.buf); - std::cerr << "[RDMA_DEBUG] PutObject: token acquisition failed for " - << args.object << ", falling back to HTTP" << std::endl; + } else { s3_rdma_client_ctx putCtx = { .provider = provider_, @@ -504,8 +499,7 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { resp.etag = putCtx.etag; return resp; } - std::cerr << "[RDMA_DEBUG] PutObject: RDMA transfer failed for " - << args.object << ", falling back to HTTP" << std::endl; + } } From d98948678ab532fbf0c9ddf3e2ff3f7fe259a7a5 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Wed, 22 Apr 2026 11:39:14 -0700 Subject: [PATCH 11/25] feat: Vendor cuObj resiliency_v3 (1.2.0) libs Update vendor/cuobj/lib/ from NVIDIA cuObject 1.0.0 to 1.2.0 client and server libraries. libcufile / libcufile_rdma bumped from 1.17.0 to 1.18.0. libcuobjclient now NEEDs libcufile.so.0 (vs libcufile.so.1 in 1.17) so a new .so.0 symlink is added. The 1.2 client library ships the cross-NIC failover machinery (rdma_multipath_enabled, rdma_async_event_monitoring, health-check thread). Header API surface is unchanged for the symbols baseclient.cc and client.cc already use (cuMemObjGetDescriptor, cuMemObjPutDescriptor, cuMemObjGetRDMAToken, cuMemObjPutRDMAToken, getMemoryType); no source changes needed. --- vendor/cuobj/lib/libcufile.so | 2 +- vendor/cuobj/lib/libcufile.so.0 | 1 + vendor/cuobj/lib/libcufile.so.1 | 2 +- vendor/cuobj/lib/libcufile.so.1.17.0 | Bin 3855224 -> 0 bytes vendor/cuobj/lib/libcufile.so.1.18.0 | Bin 0 -> 3834200 bytes vendor/cuobj/lib/libcufile_rdma.so | 2 +- vendor/cuobj/lib/libcufile_rdma.so.1 | 2 +- vendor/cuobj/lib/libcufile_rdma.so.1.17.0 | Bin 82024 -> 0 bytes vendor/cuobj/lib/libcufile_rdma.so.1.18.0 | Bin 0 -> 86664 bytes vendor/cuobj/lib/libcuobjclient.so | 2 +- vendor/cuobj/lib/libcuobjclient.so.1 | 2 +- ...lient.so.1.0.0 => libcuobjclient.so.1.2.0} | Bin 408728 -> 408784 bytes vendor/cuobj/lib/libcuobjserver.so | 2 +- vendor/cuobj/lib/libcuobjserver.so.1 | 2 +- vendor/cuobj/lib/libcuobjserver.so.1.0.0 | Bin 723472 -> 0 bytes vendor/cuobj/lib/libcuobjserver.so.1.2.0 | Bin 0 -> 738304 bytes 16 files changed, 9 insertions(+), 8 deletions(-) create mode 120000 vendor/cuobj/lib/libcufile.so.0 delete mode 100755 vendor/cuobj/lib/libcufile.so.1.17.0 create mode 100644 vendor/cuobj/lib/libcufile.so.1.18.0 delete mode 100755 vendor/cuobj/lib/libcufile_rdma.so.1.17.0 create mode 100644 vendor/cuobj/lib/libcufile_rdma.so.1.18.0 rename vendor/cuobj/lib/{libcuobjclient.so.1.0.0 => libcuobjclient.so.1.2.0} (70%) delete mode 100755 vendor/cuobj/lib/libcuobjserver.so.1.0.0 create mode 100755 vendor/cuobj/lib/libcuobjserver.so.1.2.0 diff --git a/vendor/cuobj/lib/libcufile.so b/vendor/cuobj/lib/libcufile.so index f5a4af07..27b289ee 120000 --- a/vendor/cuobj/lib/libcufile.so +++ b/vendor/cuobj/lib/libcufile.so @@ -1 +1 @@ -libcufile.so.1 \ No newline at end of file +libcufile.so.1.18.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcufile.so.0 b/vendor/cuobj/lib/libcufile.so.0 new file mode 120000 index 00000000..27b289ee --- /dev/null +++ b/vendor/cuobj/lib/libcufile.so.0 @@ -0,0 +1 @@ +libcufile.so.1.18.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcufile.so.1 b/vendor/cuobj/lib/libcufile.so.1 index 28fc53d6..27b289ee 120000 --- a/vendor/cuobj/lib/libcufile.so.1 +++ b/vendor/cuobj/lib/libcufile.so.1 @@ -1 +1 @@ -libcufile.so.1.17.0 \ No newline at end of file +libcufile.so.1.18.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcufile.so.1.17.0 b/vendor/cuobj/lib/libcufile.so.1.17.0 deleted file mode 100755 index 8098e55d5847243a691e17597c8388a81c879f5d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3855224 zcmeF434Bvk*1#VHu`Fr?go;~G)FJ}uLJ6*cQfy@l6tu2Mnx<_aO=6OkR7Z__alyD@ z-J^n5+%hvRb&uOv_qx|T?se3esN-05biQ-%IWJ94--EU=j^po(KAQJ`C+D7f?tb5W z_nlg{aDL8^A&UALsvM$-vt)FrL>9Wx^UMMCO;Ie0Ss4lc?x{?Yvcu9>`hM}(p&s?G zVn7)Y#x~-sAFuPje|%(LDX9L<{GANXG*w<#*x$1c94)!}H}iMH#TEZ7{9PpbZ)z0! zpzBle1=*Pc(&BfC7g0X(e)eCB5P*;RHy2M8VWT+wbe;d5Omga9AuB%H!Xdxw*eQj? zKSugSc3M9P)rjAHd5lS3;D19KQC|J4hPM=cC;dX|Hur~uQ28LS7qGB z!6lLEhb>;AoS1Al*7C%z^#?A!;QZ5P7u|C8_S?KEez`6D;4Cij@?`&0eT2){iHa>UTPfwdO{51nHfHcVN+V>Gsp zAxHWG+@PEdJ`tZ5`n!hyo)3R7g5zR1E+Ho5E`{&w;AqWYSHbtI;kXu#7#ugku^x`h zPaB+XgyUA?x53{#;E2QVXE^SH<8C$#OEjY`!6_tq4OLllf&Q`4#x;8pQGUKcJv*8r6}9O`3`V^`;{Hx7z4*x zIK*c>{hdI6cc#C)z~9~JJ4!0b9&~Pmzmqbq?Fru}XPoa1-}ixIUpV%IV=5fe;FtkN z0USke%!EUHX2IVB;W!A6Lx~AK2fojPV}1q`yd2IChhqU8i{MxS$5J>}z@dJQfbU1a zaWt`G;qUQqIN)%?Q42@r#|`Hz;b?%v3x^L5QO}(KM-Yw>9O|cuzORPAVK|yIuAL0u zPo?t+{XHH2o&m?%bT0I?WPD!(-_L{N0yv^@Tmr{BIMh#T#`i1W`&DpU4ac=`TnC5v zTu*<+_x1370~|MJFu}#A4cJCFZiVAEcKvobzXSf>3CCSf91pC_ZpET9+&*wXKIM2RA>w3rZ)_=TrZE94-ao(pFtXcla=Lh9n z_~FwZwHYN_jq<19kv+j-x%IA_VQT8@cLnG7rys*x9C)2eX-Lbht4twCb zvD=g!zumFF{QKuO@5}jqfA^WguRrUa_cvI-z5Rx_A3fevR^BnC@SYnzYyS~h`{@s# z?4A1Ru1R}ckeAxoyzA8Syss_XXTyrFqbHnRHe}+&SMPpwzZs7g-M05LruRygweRlU zD`flf`5#8Fd-|lGz0X9awcK*(OMm#HVbsrG9Mx7)e4P26*H2k=){|E)YpSX^{F4h; z-TYI*F@Kvk(rHom(BQL@fnA>uh{t2&ogf>IoGnwaZ}!2 zkUKVX!NZBAR}UF?#A%kP`FYU=r`4V9c09Fizx(bzt-Ru$JCFwj!>{@r<)ps8_{)d?pF5Id1Uw=OLySH9D z; zzcds!O?m%~FE9Ra@=SNJvdtZz+;P)uGeT>|xV9TIckF$aw3eM+cuDo$J8tvWiU)o? z_QLv&Ic4sd(+>N?V~OM$Qx9D7@R$F*_ni}OAKm@*rI$=weBbDCBfj}$@n4?{?D)~Q zZ{OQ}#1B11#nycHb(cRIxLBFKVc|!!%Ny=!ZR|{r`|*J3HJ4l7KJkXoQzLWiS8w-W z&F=3WQ~c1*=S)6!=03jMwg=aSHx7OAsR@^V6dn?P_^6yqE?NIg&Ph9dea^un+RM+r zeC1uUyNrA3gWB zgo7?DUH9QmmwarQf7ZdPh8_K<^)I-`9JSMm1FyR7#V7WuJ@=544llcR>Xedo&iDUt z{cSl*NBryZW7?YIi{^a!PX6cLd>?!6B`AZAhH)2l=S+@%{g;1S=)dBZ(HFlof8^bd zOt}0q+f9dEa^hzTkN$D=^OK$%H{_q;;L+`4CVw~Spi-ypo`RdLFVEQ}zUzL?&w1{< z{<|wSw%oCC&BoxomYcqx{zG@o%)*bp`Fz>m>{so1+a;g>5;&=B+XXK#*v}q2;kl%M|Q#Y;d-1qg1bDL|5eoma9dT3tz-V^U`nO9wL)(r6W{8?P}g>x4Ov2vww~}|I_eO z|NY96F}uF?;-|yEy>;BW#Rs@HzQ4zkou0NI{$t7CN9?xxgALAm3Q9iutYY{gZp%9rRr^!WC_mmOa(bG1uZ3>DVdS zP%ZgWU?8N$=Sg`~`-i zTJd^idu`r2Pdi>4inZk(J8SbO=-2Yk2Qc{3;;*%7^D}h(|H8G};W~8uvzJ+0{$m)3 zYWZib4!<+3E&q~Ey4xDGAI(FvjuImh=6C7nacz0B>(p;|>XeH%opg-fpl#1*phqj*DyXlt{8_TA5S{!m1=<&_^!>L^xZCceZRcA$={rfMf4lk;n1jvC z$n^bIo%D5|r0xI5bmCPC_e-?=d4f**KA~g(HkWIMyVEV&`p?m+XGZAMtBpG4ZVw&* zuhpr4PSvURHtOX6Av*2#P^f3L@_CI859oxO(2+Om`2S9wdT%!!|A?DqT6T^+TATl( z6YkzR`DZ(w^a|_5_p9aF`QaUC$F=O-9-tP#2QsZzzV*SlNsI3c^?(-tyN>-I>iDx% zC%^qrqHSl6PQ872owj_#3T?i#PCK$5>KQHn?0d5||5+y;uYsG7T6!+NK%0N7lW%X) z@!K$+dgeBrdidGN+Tos|lmAyizSTR@!L8l(R z9rC$Wx|?*>BOQ5BG%rfR_BOc5U9QQ*XF++S9vq`n|bpwe|0=GjH=( zoqTe#j(={|Dep6N=F`sCDUZ`2URvogPRIV6b@Iu5kl(cYTyE6nwFhhSdvwzGk&)W+ zAL-=7dL3S*QxBi4Q%{O}wOalet&=WR9sk^+lkQ`6+TUw*?3tvKE+vr9wfenR>(qx= z>xBD|PCgInq|1*w>8t4EtB#Yk)A40!H?{K5Xq|NQ>-hgxoqAyJ_1gMlkiJ^sKBS}n zLmfYypwpj!8|>Fgmv?mPnejUH)r~s+-h_^SOgj1D^}V&@dy!7O9@O!}!8-Y~Tc>|j zp(B6qHQM$Vb>vUdY41`x^~t+B^mOTz-&~!1b)HUoU8SQZ4E2vzee$wSy);Y5 z4{LSi^Uu*K*Dpc8MJwEOI{9G;_)V)^{HSA3TqnNQ>9h+eoqY0$j{MU)`S3-Zbld>x zr4`?urfbLRIi39fkWM*u>a?e)>)5%QPP*ji@MSvr?KU0%ICSctzv|e(4(g3PmA;=> zboyxzU9Ro7;X3L5fKGeYrZdi6qGSIXI^&MuP;Gm@Xx8RuU!cvG>ZI2*I`)gY+}PJ` z%Hv?CR(@Ni(?9$2c7mU2kDAe4BLI!IO2$*AU3#5Vby^;fHJ6f09o5D$_~FUv%V;fPUkieL{t`zB>Nj zA7qUh@)bJ%Y0xRxWewW#`bwvL842}|Rz7)Fr+pl!WB*q$&#$HDBb{_ym!~bi0_q1X zJx(1zJPpEH`SUE$uf>g!j#~T?opgM}E7Eb45}k^_I)T#YvvsiMSlLdAoHk98iNx#6 zQQmSs_LfKG;Dr@Xp9?+8x2Ok-iTvyi^?=}sD^dQ1A;@#&eU?#*>3+Cz37=<(KM3KD z0r~iK&~U@&QmF65=T3NRL+CNw4i1FRrSe}`w|xZZe-HH^M0yN0WY0kbE<=cOu;6e$bJF&-cWyg8U%-V>}Y|%qQLh^@)%-O#*}A za}wFJZ4`Ml2sb9+W0U`ajw6vPNeox4Hy596_CY_yo*6CA-`rOIQNDuwDZ({9i|L}~ zrF$l$d`jHtfzPh^N4X1v6aKV*g5egU8YS+;aP5t#;Y#xJeRkxL3gp{UxSyPX+%R{% z)L7!wi{G0eHvd3>i&qFmLKU4Nad3z5UekT4*X##=k zA-=hvpg++|ux^{=Eu$gB!>1C)UE;Hl{FZzj^-QFA{ji?=yc_B{1;v#!uA=z1VLtqn z_|ii~xVtIF+o2(V52;sXH=~_KC+2f4Hj9_`%qM_B=&?TSDa` zdNsx_F66=D72|nlzMVY<_%6E=K|KBLDD$41UE{UPY zPa?;?3dt?Xg|Zwbh~VR=aC_ziIOI8=b}fo?W_ z_ClV_$8c5qKb?;}emd$uj>P?CB=11J?NGdM=v<6%;th;1UWI2BW}>|R39NtClb%}2 zZ^}Dp=V`<7f`0+&zZW$;O!iN_9Me&mj(%Q3dd7lUkx!yjPSt$ntiyCvmSQ>vN&e$fr>^~9f4ONec(#06T z_!>z6!`Gnw@pg>Y4AOrl1Sjk?ip(=ub6290&0d`7O!(|1MNV!at@n zFxe z^-2u!Uli^V%0Ds6KLy06Q$CEphW?pO;r^9)>}%v-Q2BZf`d1>p%KI2!HN8YLB*Klo zfPOoS^21TrQvQ4y)7OQ`rgT~`y^K^pV5}A89}pes&k*XzTnEqZ97FLMhw&Xpe)|Ec z1?ivD5vb{9sYY%%9_1fIvy_4u>NmZQ>9Py?;kYBv9y_xquLSiNpG3nyBl)8#eU zPdtqF984E(x{37fiGFJ){xzh#@Mo0rp=#$nN1}Y}BlP^=$et%aUidTO$Mh;D{xamR z>qR~@;46`VS*L>-I;Uyc4;aAAUL%^;lW@M(3kEujk*A_2&eoh3XSE z+!IbgdHc8HWQbl0H+ekjk23vh8&KZA-xw)5j?(2Vh?l6Blv>Ou7Ah|{?u+u4OVR!f zr2oYIkQ=T-uGWWN)gX_biGB-EJ@C}I$d!dyg4BGnR|I*~jQoDmKOXYG@MrQhOvl5? z&gG?;4|A!#AgqY?MA(1oyO>Z=9OP#jwF~y|Fuq695B_-;>bD<;;eJN)S5zVIOkudi z*sT z>QVi3X&Z9Wei$$Hx!dY>Xit0|)-w|+-1)=}Wysb1*#P-RglngM6f|4%vt};Z8E5U| z4`ao+au+2v#w_Ki*eOdr7;fT-Z2ueJROFL5ji){({hv?9a675qBljya+^8qEEL+e0 zwW!B<0j5{Swy5Z<^N?E>p?}1)!s1f{hX}W(8!ar5R8guaU&ZI6{CeUCL3xyR7NY(# z()0Y4$dfli0fdiQj@lqY3;E82FyE@>WyHxOZ^81e+7pF}RQTEI9xe4eNcyjb`crWK z4AigMxq|X-Vk)NZA4vY^L$G}1vGV1C3?uCEuYd*)K5Bb<%hAXULor?tqC1qIAUF}O zr5^2BD1W6Wk1P=SCn%A#vHnaE|KmldC)SMZks9C86t5`hSx)jZR$)3?*tlRfl20-D zKNO*UMclxGPbrn_{cOms2c!MRlOHZR6S=7r(@`y_FCT_HaVFLeg`}rCK=PDc>b${l z$ner{&!YTf^3QhgJK>)hA0zlT#p`MKEBNj2A%|imKYQb<8SPtf=a+$cYfT7~`FDfKjuM9HFbLBSWimhne@sK>BB`T?pz`LX!PZ|3ZJ zZ@+8NPUS(Y$1b7zc^;gK{-mAy|HY)|E~TC)P~P|u+H*PO|7|^#UaTG8QKsVr#ZLWd zRnKSFpgl<%kC&64pC%Kh_I>$2=;*l?p?`v6Vf~+jsNOc5ftqh1J(F)jJ7c?}{ZZog zfjZ%b=~TZ#%E`}PqbT3m2n7m0U&()A--IJD+z1PIcm(CGv#=Z;O8PHZhx+|%uwJ^B z3gn$ zTs2;)JxR~GsAm@GU%CMGL}=a#s(1Nu%t1dZ%+KA_KTopx+c>og_C2s%htM5L4z-)g zIhY^jP`Y$deolRa`2k}A#r6;kH^%y_mmPq1n(o7TUaiL-Tu=7zih95;^7Hz2LeF-J zf%^GliEo%heh8r-dWioK>=pTNX$5AGnZ)BzjSD}=@5v5#)!`KGbr`QM^5?x5BDeZ5 z->U7=URB6bAEW#P%7@!pk#|0hJdgbI4TLZ3DP{AtpVVW#EUaIB(_UoH6m00!dh9&X z(?#tmh{;dB6XoqbOs{`nc2u4|7P+z;a&WKwSRfzD`e*$9@*Jl>hFZ?A;L9PVn6>W3fEDCJWltaeuVZ+d^|TJkL-*2Te4eC! z=F=#y6fPinR<3Wl0=e}j^yH-^zs4f`JV7zB^8WhCDDVFUOX!y*|I1tv?rw_0=9907 zf+q5biTVk7Bwsp>!u?}*eR$(^;_b-Qd7B9koajfjtiyJE2|vgjJ%BLJBjMyeIb2Be2wIP zwca>sDd~9v?fH(%*NP*ND<2}ijO_e?>IeUK$g7E;1a1-fW29d#cc)VRG6VVU36z+8!kSpvy;J5>kcT#(# z)+hIuV!24s{4EtcK9%>VO;;}1T)3B$GTgY~M~{$5p&dXj8D@Ib0( ztSuO?FUiiOX4K=SaVQLP@ME*pHTb-?V8{^&*=&lfV)-IljVs`)a|c7N!16_<9-r5> z+)?du;Wh0mHfPvjt95%F9`}hLc=Y1p8h1lcX<^yQl`DHs3*@P@alYH*stg5Oj)o&0 z?$8kqPot}-P(gl}zp*bw;c|z!#^b8+dfZ+YN#hCphR!nuEB%f@P!+_JUcpkIzgYwo zaQNw`M6%Dsb*nGv4p%H$<_ZOxv#(}du^nA(vVrTG+)fv`v$5J{JG#)M6{+Tx&B7_g zv$%Lc5sH&3)`Frsf1}L_rrO+)MEo3d%$&`26wb`nkzqXlJwF#V_0d;A`qG}JUp2Tw zj!di4=bO}$PKM2D35FmS29#QV!0ipyDh;j%XM-PfFRt_z`5QxJPW(Qz*3%fQFKZHK z3o1i1ouOvGtHN1UP-I(VTkWoKdBI3`ND5Sj3QBCYP<_C++E(qTu{j;VkoaMZ$J*2Y ze=9@9P7$W~CM119nMXlE&=m+(IDr;8>m31GC;-_u2%(fM16EY+2)doBbj5Ppa+9sB zvczUxP+4U2C^j4D^!jWbpVJX?`@F)^N}nfK=7vj-piphAb+|zgcnI=@GaN1`C@4g& zV1nCQrxkXkLl{s{2=R3Kydc-;43#wqw+KCEkuO4^wgA3`d^TZs&{klwxf}eRij`$$ zO;+d1<+d^*=dOd;^y_yGn!gi{2Rp#0!Vk4jxWTen?x4-*cX=^sdfg;0S2xyb#i*=U z{=m9Gc)G||;S1W9fQANNjjU2CL$fgiw-0;|B0Mo>Iz28&piCMgehf#*5u)F!$+W5P zL4hym0*iyrdRL9D+3oVwD0Qxo%iE;Xc!Y8AC)nHo|4Kss|$y1epevq6U|hp+16xIM4|MA+#n22tCe4* z+aREFN3cF5+Pw-lR1AKHJ5aH}?Jk32S6OH)%PL|fTcyk6a)t_mA;^7Z*9nad4-~oz zkPa2sgC6*{xU$#=WpRs&U$p=iqs;JA6NT1TTNgcob%RrQiJ00u%Li(lCM zK9AekjOu3f8mZPv3#(0KcodYuhl)g#NXVcoBoopTtk5Vt8a0^{>W9jiP>+c;US2tf z+*u}mSb+)_&n{gd8vcd8x)P78$>p($tDv;R2{p3US7bY)u%Hl1RLIp}gW}~}Rpj-p zhQbI1(C@C1vc8!im&fC$+PpWr(XV8dglbi2{k^21D3F-+Wev*~P&pHIdb$~N1Okp` zo7c742BjWKooLb^{?L+S$auh^vXRVa8bGzfFKTU#EM6qCxM(l>le6_QwoNx*i!0jM z+6IQFi=K9_URVuz+Z`@jB9j^#pLAoVt+k*SeCTySjjlQpYBrfk%(i9K5QfWDF__Gq zt`?w>6cii*4Y?~^>ht(y6O`e(iptqgkV3^CR}hNcO!y9U2%xe;VHjj@>S5R#z3vkl zT~Ne>(6N{WopF(lX&a$Ihnl&;6lsUdN7$ z%?$$$N5~hDPSJ|E+q>C_gWB0?wb)^^!EgamyxQS$c%80l9j8^AY|AQzt04!Np=TjI zSzG~q#?k_{?~={uNiN$KXePsMQL92FCo9PctbKgK3Dj+@7QIB@auLMxifS29=4I=G zrd|Q)7-swudRx7}l*1@U_hRe=`D&rTf&r9XM~E6osJ06VOIL_a&l0~AJ5tLlMD7QR zn-p2iiqw)VUt`eYa>+h6bggKR<_HDNhq*!vMTL#-$huZA3ocqcjnJ-FKp#{%T1tWT zl}baSw*iJ%wNSp42IwaFoJxZLqRRx|!G_9$VrOHGqfB%qpdD{S!=Q6u^F!U`fs`&GyS(D8u=1f86&sJ%`vx(S3S#u)u(sMd8lZrekYK2OyMV81sDN`{s zcY87e+>&8VP~^`tFt3=Z+5(NDCM(?RQZB~s+1WOW1Xhb8Yzx5PETb+UN;QONM0eyCTMa-5Tu^2KO)aqeJwY#Z6bf26a7@ph2gaXv%wLaOI&6W~+gKiB$ z**f?e11?*WI}n25fZ`X`nc`m^fYuIzlU>x=wo1RP!LbVFi(q&T{gaTRZl(epUxaxFx zq4zHQ0KFL}xKe(D`2>y8I8IOKcdO(y$?^gy!Z1%V(*{|?Oj%=~Qy{YfE|^4Vg5j@- zR7NWf(~qLdyZngF&KwA-<^612F_6tnMHI_PC(-4YiS0GE);RG2ktVbH)tX~~{h7b$ z?XmPn8teBgkIh4mi3u@Ql}OK)G{GPj`f1IOxKI~C84+U>*_x}pox_(cfGcH9i($5) z&I^;5Fqs7j>h%Sn2hiKovo=?Xq@U+sB0ENqYEbyn-F^r_9dW}qa|4Wv-OzEUa0@Pb z(Krq_*V3cvaVMrzA~B*Xia)Y<;|imF2>RjhsBk1^#(6<^+zxAlJ@Wg)NOYB z(mN{8@~RuW>elrtT-m%=-C15;zC5$|nbR2&W*sm)>X%!p>oVpe2k~?5+~0TJ4l{TO z)LIUYi}Em3#~Fe579y}+XZ8>)9AP;8l9csk@qtzDLg7h#-9YTu1u9)YP(`i^` zK;=^75|eUb-m5I#3T(ALpP0q_E%rtGZ`ao9iw^kige(E9dm=kq`%KX@oW}&@_8R&^0gMZgK^nC_**qh0&LbZaqQoI$aa=^Zv{% zr>_C-L%PHiKNy!;sr6GsN$))Zx-S9abtl~Mg#Mu?D5qK+H8n8Im3>YcHup|UR6^#3 zVkF1Ra;k4(X44FXMs%QQQn|29*86gLcwj#fp_GW;Ec6P!A?V2tAgBTV4(BEyok~Su zG|Cb45RQNYZbP~PbA3LK2CkI%(lAlsrUt5k--)qLaA5%l={wS@M3G3q-hK_-Aq<9m zjtZEMKU}oVaNEy1e>qH-L$B6qg?oSV{LA4^0VKSbL~no@KlnY2MT*slS+}Y7VlXACcG=RtgIUj@ zdQ-EvaP+^u7F|eD9LuauIVlSz46?Vl!>`{t$+%Skixi;xXi#su&ay4j_YjOdArf-P zA%>yw%MfG}StffY2;6Y9XSS^Z?i+{T77^aT>Fsff?pXQh5eNw zA1)}!m>Ht@WZsbcRju5T zegs5w8H`RSVUCp3AnAOHHL#dtrt9fiIfF?d_$Q!dI$RIbTT$9-!$C;cth6r`cl2#d zYF&=`R6-If3;TV6khQeJwcH2Ips!BMt3itQYiJIm1W~dYnjUfQgj(dJ`%0^(Ru~ zCGCk6P&d$tlyreJ*%m^_0Q;cgE_OeA+UcGWEYpBFU9pykijt;gny=|2oHdg*sJ26$ z{1SaGOkepe`v$V?wuyA>Z*qZ-bb^WRzgm(NXs$>ZXvb?)H_I2$#E05quLQrq8aK#6 zeJ3b^Z+;?eW!6L*Bw}ylJE#;D37OHYq@>7N5FpZXlW~L}_35pqD*|`l*#H=Oz~$b~ zt5~+Q$q+>I%u{9H0c=Sp0W6fA1ZKscT%J*g7Q;>cVh>aaV)cb6GP3M!s%s__2n09V zIg_h2wmg4qJ!7}T{j!hN8zXfheI{0?>7Ka=qS0IL^Q}_r$Mgc60xl~`pp>*i8mPHT zPqCP&5KDf%K^T6NiC<`B$t}$cGHHL46M6%&Y)g_k^Y(J~eV705Sje?yWo5#>>SD3X z8i{f)Tvk`kZDp5EHvcE?4@pTLH)gT zeX=r@T*@gMj=p(n%RC43spL8FjXI4bn6KbZzw#A4zR=rOgzuskt-W}8E9R}texka@ za~UoRfFX8)ygzKKZVtJEFq6NPmT>mBW40yrE%Y|vUSi+g+g7eRvW9W2frBvu)F~BE zUEqLWp#8xAs;OJzdx*HKzs18FHST~|@fdW8FE$%a7Rjz=dVDv~shVXAw8oc(HkkdF zQ-AC!7CGnKD3=?-O_tfNu+!zIXM*JV6MB?rQ)@e+q7@5T(hEF5rQR}7E(%i=)jCh! zQ1#6p;z{4Z?pJsj(wXgmShRtUPr$d|-(rqpcC-yJc3vb3;x~nNzH-^~z@WKcRE0SPHS;>X!D= z$K&f>j`;lz_MGI;S68V@?%n3!#q@N9z@nm5=vLiSG`A)5=H z?T1G{VDX+R=rt1C5^S z(u;d3nm5|Sbap>(wSid1!ZK+R%=OHJp$R_Kn$;J9$6$mvD_tjSx+8*9xoq zTTyHJ*-#Dl%?`rmFAbuMH>km%(&wcRG5J(8EIaUsO+>`g zRpRNdQhtvmD`$(FF|f6RnzJ3N``*CGk{8)GLmr+>hNrIOs#thrA9Ig(5fWWbC_P?^ zuv&byg~ft8DGYlQye>WG1ucocRN+*I-^qRCzP8T7w6%V8N0%6f7{q%8!sE3_GUC zhfl@2Wf(itQw-?o^wu_oZhQuyw;cmA6U+fFpLfb^@#7SbGiI zc*uuKv5Hjp#Mwm3(t@YK$3jh0bxz1rY0E6h11vfP11~x-A&6z@Fj0oI76>f!KtY-> z#G1rY1{K!I!)%omaGo&*l3ka0AcMlAl6qB*dYS5stdSraK@~tc`BpW;I%@IkA*7H? z?4D5u^Y0KC-wl?uC@ zjp7lo{#0xOZ%<^(EQS^#BOl0n@ZbR0W1*164mPBw;-aON(GdIV*g>O_z%*yQVe>sZtI*U%<^!XzOfZpQf_(g6i~Lt>0{xfw>WQ zs2^rQ;YktK|87)7n+d=)&~>#exoY|4$cmHOu@C3c84jW-S)19hgU^u}G#OSRFVQq76eO*<;w8ZR*_wt@+r2YN9DMn)A@?zRSUYcsdmy z#fA~QUwxQ(W{sGRsGyF#Y=``??I^4;hleNO-bw{*djLsU)|4?spxLlzr#+?E*~vAhV365Ei9d%L0_X4;$H5<*_t{F-YJgW*=z zFe{w}i*1YN&&eDp_8kjg*tGSRNSJ`DR!zSQ>(fPy4<@pPS0X-Q35RBUpi3pL^&>__ z;)%no7^#*xAq4PS?;PFc>T0K)!2or#GY88*V6){wvn>cuDfDZesdu7}f`%JRvf73F z>(+8h#Ebrn3r?D0@SYfPbMW{G}RJ4IrDUP>%cTR>gFNar_P{q=q>+E zG$WMG4_i4LwRZSVhl6)KAm{uF@e#MfFq}qJZmnqr7$@?Y^En~p{iCF9eF&PT6+T*sp{I)vlkl6&<7E~maJog%2jh6azCfT zMLh#c-_l#y4W@AyB^GwJg?lx%Zn--`*6jnTRWvJ1sOUCdSz-mJHlXa*^gx??wV*+s z+(J!sKa1TgQFE8mDf5rm%SbckveMps+(Aq>DQfHoRi)yMt1xUd2KNJC2Scb(8#3z9 zYItlO*Wpz=%b=%i>)RUx8>(Q>-zu?zx$JahGy?s-N8zX}TOuB>A7mF2W+~F`g18v~ zeMPPIfVw~fZx3{wq&5J9bke}>*mOKqbDAigYOg^}!9k>p*pXi5Rk4YKc3u@%`jJ;> z+2rF1|B1Y+7Pj9|GRS6hYiBpLdissTQ#D7;ZiC3qV&tcmS68|YQt#vqT%ouz1A78D z3|@o0KMH%rucVpIEz|_t#Jd7sc!L9MG&tzqo1DYJcRoN3J$OBIGqEIdF$>fQ{kyLy z+C*4E4%;wS_U_l?4~ZE7xhhx;v(gFHpMjUGR$!d7*`0+zF-=TEE0La3WJs_Yvn1gnmFpRBOk()qZgU2qZ>r-HRr2m4u#j=?HMzG>d0qG0` zQ!RsEJ-X$ZMD;B){FZ4_+vBaHY0GUwdvL$IEwf40v~_ISI(`yb@X$)T0j~>%xpR#y zFkm&>9vYAuefJDljkYy|8767FXE2(!j!pVb8mLX_JOuOmu#KPGr$1wtUw3~Vv!d@ZSB4>Zaya=p<$*RkZlRk0<0L(6E zyw;{%|Itu+NqgTHSWuw3?+a!NT;j_%(A{!}fuAtinX&ENucNP%Xx|&*sl~8*QRms% zS^6H3m$W?q>U2GzW@+Yu|H!ja{eK{A%M&0Y$HG%PkQVSTYi3$N2-+{A!7SXHofku% z)Jcsw`l%r=X{QFL(@hO^+?2gtz<=_|ZgdVT3KH`-x<2`hJ-jX75BL9-TDnqKADF^k zPC668IB1c0hbF9JbHNseF1fEUtm=jOg?6^zs^#qW*)j+prZ?{RPnJXt_sQ)REVSzDuO8_IRn_c zX?TGNwymVCkm*|b^%v?k(eU(b|F?ifW4ivAm1#k^C7Atk+rRLWINb7#u;$(G6Y zhh^Of&U_z){$|Vg5Hc)6S2tWy??r5CkG*9J2Di(esvDl!3pM)T)tiSmH^UpG-I
Oc>g8|(*Xb_r!48YFO&L27`+9-r!l6(w|&PIbC?ZCU0vrlK1zZUk!H zEP~lvd6RInFM0tnx&9~Xc9D9Q{#T6kCU5VnuK2H{2fVm&@NZ0%d%1!6Zl4ogr~oq> zj!-QvhA1p*fX&%m@K~cQv|7H+9bT~qFY0quG%Rc=DlA*rP*PY7{}#=jCH{q>Wkcc2 zl3B&(qLPA{a8e*hapCOZ*(I|IXA2_a3QLMgW*3@EilN`yAmxfpg@v<)+gW z7uCt9#Tv!Z6%4vxb42O)Q%h_6^%J_?AvTi{uf!HRw2S97#H4XW2w#OjuT@V!2ue}M zTQq&Q1l^K~O7x~O+??(YL8q8)j{{p#rt2;-O9km5_TubaFQ>IZ4oHwUGe?_QTZ^cb z9Ys>Tbp?^?yk0p^s5xrO**-6mHzA4v?b1z-5k~MtZA^{QSIJ$unoEY_ZrzvzS|AjR&2rP-EOd} zboRU5(odJB_u<`aK7bKWpDDMDdtcd&yIwP)-%1R45-zi0@12B8Zx)u7?pv=G{NHUx z^=9b)W7FemOZ~s=GR+Dl-Oq)q>L%7(mcPWjx0bVDmy%7DIGiM>TX$4C|Ep8qVho@* z)0=${*p`gi-LUx0t-u)2T`OMQ7gWUNMCx}KpoeT;@op-)---?1WC(AGtIK%zp_p5u zms_jvN(>4nU;9iW1F9h5UP9lwL)bB;$?9AQ4;{*|{2`xL7$Zy(@41%Nq)+M`Zg|aI zAae(%%)ymA-CKumC1S;<+bLeXA-aX|Fc)O3bbf;xP5U0Mcy$G412_DjM6d2G(XV{v zCG9RcsMGACXI8)cxtrdb#RpYbz#U=?)n}vyy+n1S)%!ZIO^>wFquc@H)=g@3YmMA~ z9|^0@b*f#*!s14+8*Z*Pz~pSm2CIW%j=UO%Up_Cq>d)zs3nqUHvu0&wZg?nIJn{^? zLz(>Ity!7NUb8v}zmJsacU!fo=*s0d`U@knD;m9eM!%ZbnteRz*~5k$a{m#r1&5>B zBPQj57GzM^r%6iq1HN!``sRW_3cRVV5Z9OagzNB8%8HsY75XgYqlhI@x67A(}NYn_Ov~Ur_99tZ|eD0^W2~b}ZN$fCuOK+q4vO&U?jnxfqx$+a_yd3h_<5(X5tSP`s(W7fyY1q?t(&n46!XJ$-Hu;BjDA!ByJ1# zUNUF?YOycmcDi~mW(78{x~})itjwP+hlk?SUpbskc-9Z6UDNlnGhcp3JLic6?0ugd zylK{4x?(=;4Iy4^xEwrD>#j?`n9)Ygf_G>O5%Ho~9SOP&Q?*@{O}vBC-Nf zv-GCTN_R9N37~MZ*+wYnYClR$k&5o8ct(Gd6JhFGYkK=p{|O638Vz!S}|Az<%YgGCg2U#^p3=B5%S(@)j^DL-v}1O5|k+H?-hbktz_ z^nH8_%QAT$1T^40_#3f$OA-X4t(k8(Ssm!42fnzEYO=lqC|KaZoi5gV46@*BS5#Zq zvMq5eL`^yt7V^8iauHI230nuz(iF_b@6Z;)TWx)T=H+4^QFvJrG!ca)w`|^`Inb!W zON#^6#*kI)w7ghH2fPqiyapT^i88B>3J6KQi>aUx*N!alJK^rK71W|7Vuef-eV4De zl{T|YkYuM-jCWW|*3V@yCGfzzuu;C3wN3ydP)N@4e}L5f5$QS>u4d z3s?iKOuE*E8I{ewu^jHK*NXm{zdEoA1iBZ{Vad3R z(^zSVTKSS=@RHLH-8vsEPjQBnI&Y(FBt7nGr>zN=t-y#p-7SOGGw63YVcQ9(n5S|z zx@(l63kJlnX?V?Q2Xyb$X|TX*F$YE$0&+e~y#yiEI70B0D-<1n5O$n#fs*`lqlbxGOA! zQG1&rKI(T67g4Nr`D&E_l;b9sSfwJT=9+?DKTOhvAe+GtWZcCUaB)ZpG>G?F1;GI@ zb`XgwPHSsDuu+v#;}H{jf_nUpP`%;_x?HQ$=F~uDaMmk+x8J3}zCtxh!>U@CB}re; zbZekSy0rnywL1ugLE1owux~LeJ`y^GIp`3aGK7SN|I?~g!G_f!evvvNKlo~E9L-9tl&uZ9Ah25b%CEEm zy{-q-#Xig0SJW&5uY{N5F)`ul_O24aI9Eg3h`-{b9y~8s@u&%(k%iRs%)TVe&(52w ze*?|r-5O6*uvsg+NLPTj;AwP-tW8aB@wk^#D+{nN$_AOl=L}}YOoS_wP83bAPiX*| zkSKfblJh2!8V##NhEa_b39A-5Ij3A`68l3t0s%*}&Ffli10{8#di4qC3h2jb3W&N$ zJZ-LbF|%gut+HV~gie(WwIXaM0}sGsOVYb&asWS0Z{D6BH1+xMYB3WdHl|V^)>tjZ z6syxA%XhH#{)(CyjbF(D@DZDgrN*x?Eb-gH{gRd_*LY;ZovCABI}2*~d4LM~`g&li zwlypm*h~8Q<`m5s=q5t10qXC3!3quOvSLvj1JcmfTLb(#bom0I=|SK00_Xx%Q}ZLv zP2xNls&P)8Do#tpX+!#3ozrOxrhn!nUNa3^>BjK1u(@PfNwI*1;%C?&6{jZUu+man zk@&l?Vs5FeaC%YtTjBJXz29dkrBzjP=2qAWrWZ}0g}kZ?epx)dkbX?31?EiA*_kKi ztlt$BWS#cYw#>lcNk( zhAG>?zr*3*9C^O2k_+d8;JNsoBV}@x5%5_^Ps%)?900eCkVT!PYeuI=VNG=W~LK>=w(1q5~@E^to|5fGC;*lUBG>MQ#!@uIM(3PX?DF4Op*&Z6HjDc(7KOs9B z!t3?ZP-U!SNYI}ssd^i|ioef+-;M?g(7QSE8(tAa=pRPm2#=~)#=&=S9pkwZNQtZC zm2E*nO@$m~0-TB8DD-!G_=_na^lT&jiuNg_DFaS;rsM$=R`jMnrlUB=R1})g z+ruIKM4T{fa->Jm-nQ-MU%C_QnW*eS`ushYL*~vlu&$m;2biU@)DWHF}atfWFAg_;9&ZqN6sc(dG6`i}}^<1Tm z&fW5STjgFlf91|q+lad5FLWN7a&fMx8()HRjPG#e35u^DzIi}AjnLZ*-(ZA4U!*%f)0(I8~6rMN_Nd3c<5w~G_p?pqS zUWv>SVoQbPZ7^&+_(_sO^inuBR4Z1BW_{b zuoUIX8Mjv=w=(W0Ud4E470TNgPaciDo^iV$xu0=A@i6B>l#ej3G$C(c+!{t6W!!!u z@>a(Ee?T5%JaG#0HpV+6$m5I~&p_VJxc@BV3C1JmAn#z@cs}w@#!YLHcQGD`B2O~j zc`@>C#*LRDPcd#H-ov=173G!Fvh#oRO60kWC$C0sU_5#q@;t_4#EpzcH=ukzavO3B4zkFm8MSx<%r1Mt1(}ByM25o%G}}uH1`yjEqN!=QExd zIZ6g=X1tU1TNt;Ho^r+$#I1}gKaZ69?VP`k@vLV&ayQ!VXWVcP@-XAksmLRo{|R{u z4+#w`@D1mg+f9gHU_UY(3bDPCQStMN)QuEwjI zaW!5k#?^Q!XJ+TaJW8)z#yiO#1LKyv(EoXi$Nr4m$hei{^BGT&yqR$m*<)cmLH3k0 zZY2Fy#{Hzfig6Rk+Zm6Nyr1!MvM0=Voa~7(u8{r~#x0~j%D92#TN$^Ld>iLvPn_`> z+0)K=lJq1PPf)lWjHgJxlW`OAB;#SSr<-vj$)^~%Q@A~h`yaymqnwqUKcgg{%XpmX zjXcJqWRHiK^A7@-yjPeP_tH_=X#tna&x_*OBl#@Eic8s7-x2fi{@ z+8Jg1l}Xbik1_uImB{0a?{e7wQa-`>B;uWn?@K(%_%z}v#+MOS&dE;SBH{+dXA?Iv zekgGh<7LDxjDIx`<7H)h0m<7LUrId8cvlzN9bw#1hWV$3apf@NQO4~P$4Ec7G9Gz^1pWBk1PjcVHa|7d@q$iJYBk3_R9wna7xI)~-xbYE;mxXh(r<`%?H<-Rw#{I;r z7>^RSGaeyc&$yj|*BlJO+zPcd#MdwLkRki4=cJ0C`O$8d8Q_me#a z#$zO($9N~{&u2VL_Lvwqk-V94Kk2tHZX$ci8IO>>mGK1Ww=*6kd+HfClDwaBE9nn2 zp4tQb7Gc~@@-2+VNq;NjZDdc3aRbS>F>WILamM3hPdnoll20%mBmJF>C&->I#ubuJ zGHxLK-HiLmo)qIolJ8+WO8Rrp&CZ`)WRHRI6qUz3&Z)c@88?wV`HU-MkBRXJ*<)cm zMfQ|4o+Nv$jCYbfRg9-7Tsz}QlCNjnPxgcv&wUI16=A%S>}g>2`Ypk@r4IFUFz%m-yp!=x@>>_<{v{}%WL))IH{+_`dKm8{ zzbWTu=UeMo)St_El=6vz@x&sO&tqK8Z$`#dzvVNo`pv|+n%~TftNG2sIr*)eaW%hL z8CU&Q#klIXdd9oSZ+^y;l&`{!o5-IL#-oeTZ!L_g`7O%0>bF+LRlmg;SMysN<7$43 zGp^>hcE;8GmS9}t;MbJjJ*|`K^a>)o;oL+4))ZTQ1|O z-wceae#>KA^_!7#)o=NXt9~;vuKLZ)xazlZ#`DN;R>mW4%s*9($5tY@GoB*(ddA}< z?`PaVJi@q%>}g@#Px_;b8%a+q;|Y?FF>WIHHpY`A-_CeB*^^-0PVya$M@WAsCb08O!k-!#h&bWW)U8J1}#v^&iI~Z5z6FM1>?SS%0#v^2B zH{(XKGsU=x?CfFOl8^e83$yd5bzkJUjH`AU829gv@KO4a3hRIh({TZlYd$nw~~KijN8dS zZHy;R#CXLSPcfAkKxOT?lYmnD7ZoL9|nDGwMA7R|`4cgPfxSe>E@x)}*A7k9`9@UeKnFSUy1rV7|$pDos9cQPZ#5H;z`C;{VB$K$Ui-d$FD+rl#8^^99iLHRJ_?W8}# zxUm)GTNpQ8fjr8%@m%CF#_goPjqy|g%EuWu6e4eDJh2FQ2jk`MV|sToZhUr6MSQv# zPZ3Wt9`8o^ZpIaoPcd$x^>RIotLt!-i?j2gx(+9oadjO|9^-b3myvU_C!g^caTDW- z;d@Cxm>D;ayoGT!UgeCd@v<_m#;b~PHD2|Mo37Yb+T&;3N<7TCpLh%73F57cD_5fa z7~=^#?_&I#$aHB>it#@Y&%Go&9Xp5{8GoC&nelIlTNxjA8irfX_ypn+#-|Z)W&BX$ zamJSt?_j)|c#`oZ;ysM7A#S)d+Ygr#&u9Er;ugjqC0@n&i^Tnmze~J@@vn);7$0^z z`m>$!9f)@_z6bGc#`B3Qmu1J-OgxYA`NU0(uOME|cr|f5<9^~{#@7&!GJYlTHpXuu zo?!eg;$4hCN<78*E5vixW&7bX;zq`QB5r1U$1^Zptc>RquV;J?@d)F~iMKNDCLU+J znRo}|QQ}F)Zz0~p_yfcZmuLIoRpR-K|DCvn@ompUKU6V3iMXHf{fW0QKAU)q@e1PY zj2}b1lW{-sZpKe1uC!*y_hRCCjISqdV*CN(<%~a1+|KwH#KVjaJq!I7Wqcy>HpUBy zCm5ecyo+%g@f72Y#B;C6_QM6ljf`(3Zf3lLxRvpbh}Sc&oQ?5~Fuo)4R>r3hk2CJS z8})QB9wnY+{BY9K!?=^U;mT}3#7R#+<6XopjGsb!su;hBxSw(59<;xO@qFSj#&01# z?TkN2yp!=x;@yl}NxyPcc6`4e`8>vdA#P%P%sFU(Ipbl{Z)bcO$%h#~jChoBC-FAM zn~5hFzleAj<1w-)#drtt+^e(w&`sRPxZz%mubFWZaVz6@kUjN`Cx}NFe}#A}<6jYv zGj64DI~d=#1?@~SZY18r_<_U?*JS&_N<5$OI^q__!(>kt<1ylX#uLO_7(avb#~AM> z`F6&yC;3js?BH}%aA5Gj4%l3nZcs}FJ#4U`UN4$#hR^oofHxh4Q{Bhzj#@`^` z&iFUPI~m{ZJoINbh+7yp5wBu=K5;+e#}RK~`~>1L#?L0+ z&iK{DI~l*7csJu6#Fh2g@%@B&9^*M{(GMoZClW7bJfGSTJL6X3VaAI{Pn7Wm#M>D6 zlb!_QH6-7~_{qdmjJFcc-H`2vR?=@|yq&n2@jFS6mGLKu*E8NtdLoR!Px7sdtL;>r z@qdzh2jgQe#PmusK81J>ZjEsb}0w@)5>cNWPWv z6(k>L+(o>D@zunWjGs@uhw&SU8*a(=!^6b$8GoI)h4HV6S1~^PV)UDz@yWzn7@ti% z#`pr_?Tl9w?_@kgyqod!h$|bj`yLr$|1`_%@fIf1-@< zLA;IeX~YwZA4a^3@fzYO#*<`c?ycE=Q0_;2jEv_KH#2@3>9;a&CHZ>B{lp`Tw-Rq< zJV89p__Y*n2jlk=Pcq(3dU_atiR2BpW&6SK0Qw=H@vlhU!nm2_s~FF{l=460yAf|; z+)jF8jJFVPXS{^;bTV!w-pzPB=}~Uaj&G899^<(WqWvbu^NE);?xAq)jISXcX8da6 zQO55g-p2S7#1o8vK)j3bUx=p|-{~@pSMD9ze%PP5k?{)RX2xrYTNyu@cs=7+5|1!` zFY#8!pCcY;{4?Smj9V#Pl8oo9!}#_vo=4npXSN^qC7#c?g}8Nxy~h6Ny(bzLvP3@ix-m z!gwd~7~?78?Tp_>`a2nal6W`c9}!pnoE_gEiRUps{tC+fj87w8&bZ-Wl(#cpLGoe7 zk0Ksr+)R4f7_TCpVBAZ3x)_g;e2Vcl;<ot*-#^K8o?}VBAVP$#|G}592Z7hW2bfbP~^JTzL$`wJ>fXUd4D7aX;fN z#9J6|Cmv%wMZBHy{KwIrPR4I0e|9te2yx}U?D)PzJdg2jiJKU=Qn=-ehl$%6j}Z?u zzQfgMf0Xgb#M>C3O+3N)65?HqyNRb5Ka+Uw{n>uFfw+U2^tUo@cmn+sXFT^BN%^1g2wJ+!R+|1C!WXnBg9RNzev2Cadq5bXZ&N5 z4>SHP@hIcNuElt@F}@4&1mh*dyBI%=c#3fw@%)Ff{qP6kCdONcTNuBHcsb)Y6R%>t zow%Lxmx=osPZAF^{xk6w#>ZTTev2|bm3WMC3-LC_O_Z~!De2DHb(cqi$}V?0GXpYc6OkBRZTr%}I!@k2?zobf7> zuVOqx+|GE6xS#PP@i61cGiXl>yu8#gCyU@ z_!{EfjHf8v6ytf%VtkcHv(w#7JeTn*;(3g>Qn*IOBP4HPyq&n2@jsHDa>kz~Ze_fS z^w=4HpXBQq|DJf5@$GL!KSUTe5|1)oK)jW4!*i&ojqwVSk27u|`2^#2B;Ub!J;`@5 z9wnY+yq$Q8@g(sc#&e%X`*R=5&JU-MJqE_}N#4l#)g+(KxRvD1jJK1#h4EL3TN(eH zcopM65U*!^{CbR+pYay5C&GA~cnjlQ#9JB9dja*w7`G6QGrm9B)6RG~@ean1Bi_k) zg!CsFZzlO}#xEt_!}!g_mB+Kwy^Zu67=MD~^B8}Fcs}EQCvIYV_y+Wwh4CbXTh4gy zizr{k_$1O}XM7fMKjTY?hZ%PfZ(;mo;!(ygBOYTsPP~nA6WQO+xSx1}@mAuUjK4to zyBO~z`EJI)Ao&#I#!mF7@-#`Ox6s-_Q3pzKv>p}}7|w&72IMe`$bdI6oCi5LfQJ!iJGNE_s&;Fm zPD^4&lH&Y9?0RS!)3n*vG?}DL*^1Pm2rTERBy~$Pj%kx_dN7rHUa#$UpSiDJa^JbH z$Nl-u&hEay*Y$bk^UbyJ=*RZ^DdCyChR?cw1OE}f@9%-y~iv3W3>Jbzv%i8_!nw@@ISo1?{}>a;n7d*_aDK( zMb|mPze}FLQ(Y&6{}rvz;s1@ig#U=Vg5Tv0{GZ8N_=lbM=XHXAjJ${cz+c~gFZT%l zLajf;ze#?9mwFv$cq?Dvqx=T{Q@Z{ge%1O7ewPP7`1-zoudZ`||CjOz{v+}j{*UDe z{8#+7{dG>^;cfRE9&3F8&$PaRe}>lA@LKCz_*ZLv2OqV*hqqck!0%drhW{n4pWuH> zKEr=leuW=@a({hp@L$yW6<%rm1|Q`Q_*H(mzRtrh|LgnXhVYM&$ME2%_Vq`2EKlL7 zu9Lw_tuNqTru8NKr1drYB5&Z|sq1v`RqIdi;HUTJHNbmaXN0F(Kf(Vqt-ruWt-r#5 zNb48);b->yS>d((4)5g;`2VWw2mj;i`@U*@2>)kVAHjd^-`MXbhWC}`0p7?HcqUKb zp*(}HU$MBc$e z`3b&##eSbXe31|ENj}1R`5E5GCwL*hz+?Fg-^%?yukb~_z(@HFUddN@CcndD`34W< z5BU1!`+WvK^g91n`2jx3LwGNb;EgpjcqdQbnLLHZ@(doxbNKqZ_xmj1v%G|l@(SL` zYj`DZ;F-LIhw=`-<@YiZ5#GrYcp*>Wi9CY` z@*KW=&VHW-e3F;&US7c~c@2-{4Lp#y@b!1?_tU{=`3XMCdw3@w;FWxYXYw;VmQV0N zet|Eaz2E-~pX66~Ctu*1{00x@D}4K`{c-Q`MZUpD`2$|bgXMMpWBCETX8YrY@KGMY zD|rmh}d>8m4zriQ@3h(82cq8B7h5P|e~eu@(4c3 zV|Xt=!Yg?KkL4+R{kZ*pGWaad;hnsIXYvvr$}4yvui@Lr?)THc7kLYx^kL7oG^#}I*-{6`20gvUu z-+!I|Kz@L)U%y{JgwOH_KFVWwCqKd~c>>SmDLj^E@ctY3`^@2uyntu&5+2Jd`1%d| z^=tSjZ{VH0g;(+p9?MVgRqsm=ALRqQlaKJ?oA&!Z!xQ-g59Am4tk>rXufAjddw@51 zCtu;SzTV)I)(1cKI-g#Dg!^-661YEiCWZTRXEL}yccy^He`0@LCEWMZ!^fZ3--m?H z@(I4mXZR++!q58p1`pT$aaXw4Z}3FxA8~Jo{hv z`>)}nyn_e-U|&DLJNX1(+@ZIVgH=U13dVk4}9o4$0>u0#vFYx#i_v_!_UVn!tpS!Q$;9ej6?CYGYUI!2K`Klp2)cY90{XWL<@q<46 zz3=Z4?)Nc)_gbI9v+v%YR}S~{D&fKR?CUGI*EjG&U$^i^uR{m#^g5j2ejR#v{Db@F zv<`5;4kLX0@AmZ*y#Fiv^P1t4e1R|W8~m)V@9<6QH~2+g2S4{ZKjGip?w9=1AKR^l1fPEEzWxGVj=RtB?IU-;!jsS4eSue> zxBCqqe9rDGJpApu-{H-t?!LjtPuu+g?>}kx;Qd}-pX7J!et<8ZzIzA{KXdm8USzw+ z@cy%QKf>pH_XHmNp50S;_656V@b35Sp2O!a+`WJYU$lD(&x+kEc=yG-*YMzLcW>a? z*X`cIyK46iK7al0CwTA;yZ7+y8+RYz-8bz%!sl<^{R|K4-6weVExTXf-M8*O!-Mzi zeuZaWy88m}zHIj!eEyQ%SNfOleuoENvHJ$kzH;{my!)!%gZF=(|M{zTKft$i_Yj_a z$L#!k3TPy@Su+w)+Vle%$UoJo)(D2YB%byN~eZ6L&wuw`BJV+&>Ry zxPKm8;r@BB!2R>!2KUc{74Dx0cesBZY;gZPc)Nz#sAy9_Y_c z0YAt~cqp&nk-Ub-@&T7E+629e1wd@LGO>H}VPI?p~! z6WqPf!`%x5+`TZu-3w>9dtrjR7cOx3!VGsWT;cA81@2zB!QBfh+`VvzyB9XNd*K0h zF9g5*b*|hC2e^A7gu53axO*XnyBCgd_d)`9FQjnyLI!s)PH?p`><-3t@ky>NlM7iPG7;R<&zEO7V24enl8 z;qHYy+`X{D-3t%6dm;E0uk-I-IKbTtA>6$X!QBfn+`VvwyB89;dm)9p7c#heA&0vc zO1OKWg1Z-LxO<_2yBAuxd!d877fx{ZLJxN@3~=|t2zM`>;eqy16Z{~*z(e^AkK|W) zEMMVA`5m6fH+U+4z%zMpc%9o^et;M95MIh7cqLEZwLFD4@(kX}b9g5&;3s(r@8uPI zkk{~0-oVfD7Cy;4_(gt#&+;CAl@IVmKEZGD3w)K&@Vop9-{cGYA-}-`??2%O??2(8 z_n-gb>%2ws13Z?8@S{9}C-NAc%8&3&p1^Z?3NPdtyp-qgN?yQgc?oai6}*+V@J`;r zPx2GIm-p~NKEOx$2tUggxO?FacQ0&k_re42UI;$$bxzz12e^A7gu53axO*XnyBCgd z_d)`9FQjnyLI!s)PH z?p`><-3t@ky>NlM7iPG7;R<&zEO7V24enl8;qHYy+`X{D-3t%6dm;Fs*ZFrZ9N_MS z5bj=x;O>Q(u3k98-3tlay^zA)3mM$Kki*>z1>C(*!rcoM+`Ul4-3txez0ktl3mx3O zaDuxRdboRGfV&q)xO?FYcP~tE_reA4UYOzTg)7{>u)y65H@JIYg}WE-aQDIk?p_G~ zrPn!kFC5_Rg%Ivuh~Vyp817y;!rcoA+`W*(-3uAqy^zBL?V}3#L0-Z`c?FN;H9VGg z@T2?$Pvkv3l@IVtKEiYP8D7XIcqzZYEBOMi--3vY3y)eMt3nSdUaE7}VCb)ay z0(URWboIg&?p|2n?u8rNy|BXF3wOACVS~FD9&qPK?q0~??u8ugUMS%1g%a*wsNn8}8tz_b;O>PM?q2BN?u8TFy)eMt3nSdU zaE7}VCb)ay0(URWaQDI$?p|2n?u8rNy|BXF3wL;+ebfd&$RF@f9(?fYoJaBlJeJ4s zqx=X@IFXRQhl$Y>I-oR^l3vc8dyp^BeoxF#iWC5dM%y@WA^|_`&;6c@TU*Wxc zfe-QmV0`6WY;qHYB?p~KUTER&g%0jsIKkZuJ>0!8 zz}*WY+`VvyyB8+7d*K3iFU)ZF!WHgbSm5r38{ECH!rcpZxO-uPyB8jC_d@U?uk+(x zIKbTtA>6$X!QBfn+`VvwyB89;dm)9p7c#heA&0vc3b=crgu53ixO<_7yB8X`d!dE9 z7dpECJ`&u$(8Jve1KhnZ!rcpJxO-uOyB98S_reT!FI?g7g$3?jxWU~EE8M+shr1Ux zxO?FNcP|9L=5_wv3kSG+A%wdZBDi}YhPxMzaQ8w2cQ2%H_d*7DFXV9dLJ4;-RB-n~ z4RFVl0zDkOL#A@;Dfw|kMah7 zmbdUp-oY>O6MUBU@T+`)FY*a~lV9Mge1_lUSNJAh;1Br?9%$dV!4L8WJd_8&?seWG z`2ilwL-zue34siEE2zM_;aQ8wCcP|{_?u7*IUP$5Y zg$(Xq$l>mV0`6WY;qHYB?p~KUTER&g%0jsIKkZuJ>0!8z}*WY+`VvyyB8+7 zd*K3iFU)ZF!WHgbSm5r38{ECH!rcpZxO-uPyB8jC_d@WYuk-I-IKbTtA>6$X!QBfn z-G3hm?p{dX?u8WYUdZ6?g&gi)DB$je67F88;O>PQ?p|o%?u8caUg+TNg%jMp(8Jve z1KhnZ!rcpJxO-uOyB98S_reT!FI?g7g$3?jxWU~EE8M+shr1UZaQ8y+VXt%UUO2$r z3nARS5W(FGG2Fdygu53KxO*XmyB9LJdm)Dh+D8@egS>=?@(LcwYj`a0;79ohp2&N6 zDj(pPe1zxnGrW*b@KSz(SMmj3%Wv>TzQSAi9p1?|_(}eN_wwLheVxxiet?hi5Pp_N z@JSxSFY+UNmM8G5JcTdv0)CU1@Ks*H@A4YH$s71X-ogX#Kj8=OKjESGpYTY2hR5;= zew1I}iF}5q@+&-(FYsJ`gBS7@Udr$AO1{Bs`2*g_gAae5&sHA6J9!L0$&c_}p1=or z3LoVe{4DR_KlnNO@0mQoe@NcL|DJq+|EPR~|AhPu|7rOI|9SZZ{tNOM{=dnu@L%@1 z`}11h|GU=T;QzOLg&%aCJN#G4H~4RqKj5FR?Y}2B_}5m0sfKl5dKl}2>!A1 z82*X!Bm7h33H;OLDg3kK8T@nQIs7aC#{T*j@ZYWVCHxEJ75t0kHT+BE4g4$QE&OZb z9sD2beLum!Uh8}Kx623kcgaWipO>HEe_1}k|El}~pX4+AZ_BUnzbjwhKPSJz|Dk+^ z|5N!L{(s6h_&<|B;NSOo`#c06@jCw>AV0vr?+x1X!ivEK}XF${HWJCga2(kuN?lJnv(+lr}g@m@INcB;NL5+ z;omQB;QzI}h5z^R4*vJ#C-_IF`|HrdzxW3<|L`CC{(a6z_^1Bp{yLxGf9ZSn_i=*1 zN7ui=|LK3eKkf|wC&hmKEBpsOa$mo|+y7{P+#CEe{-51f_+R^*`}4ZPn}51L?gsxP zt$)DZ^PYWu5WmjPf(zW|1vA{|1y{Jw3l_M~3vO_q7p!of7u?}KFWBHdFL=OxUJ(3-*ZK5$ z!2#~`f)MWWf(Y*Of*9`ef+O7L1qs~e1u5L;1sUAu1v%X31qIya1tr|)1r^-q1vT8~ z1r6Ni1ufj?1s&Yy1t+-A3wpTE3kJB)3r4ul3(jz#7ff)U7hK>zFPPyzFSx>eUa-J@ zUT}l^ykMp4yxz;HkWXXYvZ3%WHTcZ{Vf8g;(+(Udsn~ zBOl?d{0#5p6Z|BT7E+629e1wd@LGO>H}VYKIPwu^Tgm3TJKi?;T zPk&+moS+mQe(kxAK|e)gCFHN zJdqdhR9?a}c?HkqHN22F@KWBwD|rvE~y#@RrFX5rQf=BWi z9?Ki}QQpE6c?VDBCwM0B;kkT(7xEEa%FpmhKEZ4G1>VSKcq_lbJNXJf$?x!9zQG6i z13t=w-}X9hXL$_&0-cu~;cLHlM*@HL4t)H6eO@Yj`>VU>@I>ni__KH5{eQAwr-FCi zvwIJJb`bp8LGWh>!Ji!je|8Z3*+KAU2f?2m1b=oA{MkY9X9vNb9rW8@=i%8w@Mj0X zpB)5$b`bp8LGWh>!Ji!je|8Z3*+KAU2f?2m1b=oA{MkY9X9vNb9Rz=N5d7Ie@Mj0X zpB)5$b`bp8LGWh>!Ji!je|8Z3*+KAU2f?2m1b=oA-5msfb`bp8LGWh>{f^i9e|8Z3 z*+KAU2f?2m1b=oA{MkY9X9vNb9Rz=N5d7Ie@Mj0XpB)5$b`bp8LGWh>!Ji!je|8Z3 z*+KAU2f?2m1b=oA{MkY9X9vNb9Rz=N5d7Ie@Mj0XpB)5$b`bp8LGWh>ebnomKRXB> zXnz>O5Ap~e%42vWKf+^q20zMkcp@+0sl0?|@(P~IYj`1V;HA8USMnZS%LjNPAK|V1 z4DaL<{3O4?d-)6>YUcy6p1&`!4JeD``qr8PD@(!NLPw-6M!*lrnFXSV_d*MIFLZSE!U^tP=;7{#0q$NH;qHYq+`TZt-3u4EdtrvV7p`#k z!UA_M+~Dqo74BZR!`%xT+`aICyBC6weVu>z!U67H2;uI92<~2p;qHYa+`W*%-3uw) zy^z7(3pw1qP{Q2{72Lg0!`%xF+`Z7k-3uMuy>NoN7kapRVSu|AM!0+73=g!An&1cd z1s=+0cqG5VWBCd{%J1+*zQI%Z1D?r)k9(clTz-HT@(^CiBX}iG;I%x3H}VYL%5!)p zFW@J63Gd|_CEUGG!QBfr+`Z7i-3u+;z0kqk3n#dH zp@+K{2Dp1+gu55caQDIlcQ0Jv?u8ldUbw>D3k%%6aD%%SR=9iN4tFnXaQDIk?p_E! z@pb;)3kSG+A%wdZBDi}YrmGi@aQ8w2cQ2%H_d*7DFXV9dLIHO#lyLV#1$QshaQ8w3 zcQ3SX_d*AEFPz}+g&yu+7~t-O5$;|%!`%xL+`VvtyBB7-d*KRqFD!8P!VT_TSmEx4 zJKVkSfV&rhPkNnm_rd}0UI^jtg$V9mh~e&qBiy}^z}*We+`W*&-3vK9&_1ewALJ!G zlvnUbUc+N~2S3VB@I>CjQ~3bTNoN7kapRVSu|AM!0+7 z40kU~aQDIm?p~Pb>V+%Zy|BRD3pcoXVTHRF?r`_Q26rz!;O>RscfQWQd*J|gFNARS zLIig&#Ble*5$;|{;O>PK?q0~??u8ugUMS%1g%a*wsNn8}8tz_b;O>PM?q2BN?u8TF zy)eMt3nSdUaE7}VCb)ay0(URWaQDI$?p|2n?u8rNy|BXF3wL;+ebfd&$RF@f9(?NS zoJaBlJeJ4sqx=X@IFXRQhl$Y>I-oR^l3vc8dyp^BeoxF#iJzz6vaKFU}4Sss4+>s+}Pj&S!v0(UQ@aQ8w6cQ52{_d)@8FO+ciLIrm( z)NuDg19va9aQ8w7cQ2ga?u8!iUKrr+g%R#vIK$lw6WqOUfx8!GxO?FWcP}h(_reYC zURdGog*)86u)*C654d|F_>9;2bT1s>?u8KUUWnlCg&6K$IKtfv3EaJq!rcoQ+`W*) z-3tZWy->p43l&|xP{Z8|4cxuZ!rcoU+`VvuyBB)6dtrdP7e=^y;S6^#OmO$Y1@2y$ z;qHYi+`X{C-3vFkdtrsU7w&NP!UlIQJmBty;4?A*-}V8)Fa2|XyB9*Zdm)0m7h<@3 z;Rtsxq;U5_26r#yaQ8w1cQ2H1_d*4CFVt}NLIZa%v~c%A2X`-=;DPp0J^Uaa;Gukk zNAfc~me25`{0dLx3p|zI;F)}d=khzekZvi5z`2n8ELwGKa;DtPfm+~XLk|*$5p28b>25;ph zypvb(le~ua@&-Q0TlgsN;Ai;+cQ0Jw?u7;JUbw;C3oG2caEH4WHn@A?0e3G1pZz)~ z?u7%~y%56P3lZGC5X0RIN4R?-fx8z{xO*XkyBBh}d!c~47fQH$p@O>?YPfr$fx8!4 zxO<_4yBAJy_d*YMFAQ+^!U%USoZ;?;3GQCFz}*Wo+`VvxyB8L?d*KFmFRXC)!X55j z*x>Gk2i(07{I1vepVbQoxO*XlyB8w3dm)Cq7mjfELIQU$q;U5_26r#yaQ8w1cQ2H1 z_d*4CFVt}NLIZa%v~c%A2X`-=;O>PU?p_$+?u8NV^My0qy)ePu3m3S1VTQXGu5kCl z4enl8;qHYy+`X{D-3t%6dm;Fo*Ex4D9N_MS5bj=x;O>PO?p`>;gZJC-BY_{}DLj;C z@JOD+V|fKX%4>KcZ{VrCg=g{(p36`0Lf*qm`2erv6TFsR;EjBSxAH5zlP~a-{08sk zD}0dO;iG(mpXCquBo99Kbv`fh1ALZ;@T)w6FY*L_lc(@ip26?(9KOj5_(NX8gZJN` zX9GXTTX-n%;F0_UkL5l5C?DX7e1xa+Gdz<|@LYa@7xEci%CGQBzQAkw4c^FCcq@Ov zJ9+SVuk&`2AK<+_gb(rvKFVYGSzf^13pL!m(7@dbE!@4(!QBfdxO<_8yB7wydtrpT z7tV0^!UT6OT;T478SY-V!rcoC+`VvvyBAitd*KduFKlr4!UOJJ2tNOHuG|X;xO*Xl zyB8w3dm)Cq7mjfELIQU$q;U5_26r#yaQ8w1cQ2H1_d*4CFVt}NLIZa%v~c%A2X`-= z;O>PU?p_$+?uC)AUO2 zv~c%A2X`-=;O>PU?p_$+?u8NVUO2KhZ{R0+3-9F} ze2|~uqr8Wor_{3^e|7x@Ce$#3vgzQXVFJA9LG@Q3^X54`{UJ+Je5 z@ct7XdjAQJ@XZ*cd*;R{~p!MzZ|-3t-iy%59Q3rDznA%VLWQn-5|gS!`U zxO<_1yBA8hd!d567izeBp@F*>TDW_mgS!__aQ8wFcP|WZ_reHwFP!1-g$eFnxWL^D zGu*v!g}WCPxO?FScQ34P_re|SUfAI7g$LZd5d7ZPId?A{;O>PG?p}!C?u8icUO2+t z3klr4kiy*y8C|`Q!`%x7+`Ul3-3t}my->s53k}@8(8Apd9o)Teg1Z-bxO-uMyB9{d zd*KXsFHCUv!UgVLnBne)E8M-Xz}*WsxO-uRyBF?o_reBuFFfGxh2RTc=ij|>fV&qW zxO*XnyBCgd_d)`9FQjnyLI!s)Mf$evr5DP~O2K`3WA& zNBB{Gh9~j~p2{!qOg_VN`4wKs7kDYZ!7KR&ujLPTBM*Mx>m0W71H6-m@RK}(_wpD% z$dB+*p1{xY6h6r__(h(>XL$j?%1ihnZ{Rn13t#0O{4PJiH+c_#$Om}f{U`k3{U<#1 z{u3U_ukcvDz>o49Jdv;PRDOqN@(rHLAMipRe9`NCmhuCE)V3~%Krypw0} zlRSs_@&Z1{OZX_S;AeRccQ2gb?u7~NUbw*B3p3okaD}@U7Px!i26r#4aQDI;?q1m7 z?u7^3y$}?ybK+h&z}*WW+`SON-3u|?y>NuP7ZSL8A%(jaGPrvohr1UFxO<_5yB8|B zd!dHA7aF*Gp@q8_I=Fk`1a~j=aQDIhcQ1@^_re+OUYOwSg$vxhFvHyoSGap&fx8!O zaQDJWS1;V*?u8BRUUPI?p~!6WqPf!`%x5+`TZu-3w>9d*K3iFU)ZF z!WHgbSm5r38{ECH!rcpZxO-uPyB8jC_d@U`uXFBRIKTt#qeA#W9>GI-43FeTcr4H0 zM|loUHFXRopl(+Co-otD80B__Yyp^BfoqU3ymV0`6WY;qHYB?p~KUTER&g%0jsIKkZuJ>0!8 zz}*WY+`VvyyB8+7d*K3iFU)ZF!WHgbSm5r38{ECH!rcpZxO-uPyB8jC_d@WcuXE*I zIKbTtA>6$X!QBfn+`VvwyB89;dm)9p7c#heA&0vc3b=crgu53ixO<_7yB8X`d!dE9 z7dpCn;RJUt^lglBiy}kh6mb5P4I*K0uSXgJd$7Gv3!Le<#%`@ z-{7hI0ng;Ym%q+!EUi&{*d3`f%l*AgZH2C(EHEwb>1TR z0Upak_)#9g6L}0zd!d257h1S`p@X{@PH^`^4|gvNaQDIpcQ2gb?u7~N zUbw*B3p3okaD}@U7Px!i26r#4aQDI;?q1m7?u7^3y%2om>-@VH4siEE2zM_;aQ8w? zS1%ml?u7*IUP$5Yg$(Xq$l>mV0`6WY;qHYB?p~KUTER&g%0jsIKkZuJ>0!8 zz}*WY+`VvyyB8+7d*K3iFU)ZF!WHgbSm5r38{ECH!rcpZxO?FNcP|8A^*ZP7g#+BZ z5W?LH5!}5H!`%x1Z{QDk3lF^igde>BgooaL!Xx<^9?K{A zQGS6Z@)@4WukcL1z;pQxUdUH?DZj%j`3A4$4|pRFzUFm4TX_WU;qHYA?q0aS-3v3^y>NxQ7Z$jC;RbgvtZ?_j z9qwM(;O>P7+`SNd?dzPl7Y=auLI`&+L~!>)40kUa;qHY5?p{dY?u88QUdZ9@g#zwg zDBglBiy}khPxLgxO?FOcQ4Fz^}-eI zURdDng&W+xu)^I7ces0DgS!_VaQ8y+b+7a9UO2$r3nARS5W(FGG2Fdygu53KxO*Xm zyB9LJdm)Fr7Yew0p@h2^D!6;0hPxLUxO<_6yB9jRd*K9kFAQ+^!U%USoZ;?;3GQCF zz}*Wo+`VvxyB8L?d*KFmFRXC)!W|xHAGN^`@&`PW2i5DGNAd$amdEg;{0L9v2|Sgj z@Jyb;b9oLg1- zSNJSn;8*z#zQ{NDP5ywd^5E-V=j|>(z&Cjaf5;glBiy}khPxLgxO?FOcQ4Fv_rewKURdDng&W+xu)^I7ces0DgS!_VaQ8y+ z4X^X*UO2$r3nARS5W(FGG2Fdygu53KxO*XmyB9LJdm)Fr7Yew0p@h2^D!O{1hPxLU zxO<_6yB9jRd*K9kFZ6Kt!T@(KjBxkD8SY+~;O>PB+`TZv-3wQ^dtrgQ7jAI(!U}gU z+~Mwp4enlez}*YMH)8(%`3rFOLI`&+L~!>)40kUa;qHYL?q0~??u8ugUMS%1g%a*w zsNn8}8tz_b;O>PM?q2BN?u8RPc)$Jq=-~(X01xFOJd&T`v3!OfjFQ>Z}3pQ!Xx<|9?LiQQT~7@ z^5C0a=Pi{V;F&yx=kf?%$YXdZKf)_{0_d*MIFLZGC!U^tP=;7{#0q$NH z;qHYq+`TZt-3u4EdtrvV7p`#k!UA_M+~Dqo74BZR!`%xT+`aICyBC7`b^f29zW{eH zgmCvl1a~jQaQDIy?p{dX?u8WYUdZ6?g&gi)DB$je67F88;O>PQ?p|o%?u8caUg+TN zg%jMp(8Jve1KhnZ!hODQhPxLgxO?FOcQ4Fv_rewKUbw;C3oG2caEH4WHn@A?0e3G1 z-|{-=?u7%~y%56P3lZGC5X0RIM|hxpR02Q9Q+O!P;E_Cs$MOn(l-KY?-oR6N3(w>o zJeQx~g}jHC@&R7SCwMKtz#I7tZ{=5bCtu(v`3>I7SNI^m!$wI41 z2ly-x;a7PCU*rk=CQsq3JcHlmIee2B@Q1vF2i||e58i*mL+?M~k^BUYz}*Wi+`Z7j-3uqUd!dKB7Y4X{VT8LE&T#j_1a~i7;O>PP?q0aU-3trc zy>NrO7go4?;SP5%Y;gC&1MXf3{?O}Oxfc#__d*DFFGO(nLJW5=9O3ST1nyo);qHYD z?q0~@?u7#GUMS)2g$nLosNwE~2JT*H;qHYF?p`>--3vY3y)eMt3nN|U3um}{VS>9C zE^zn440kVF;qHY6?q0aT-3u$+y>N%S7dE(i;Q@Cq1b_H-{@n`)xO*XlyB8w3dm)Cq z7mjfELIQU$q;U5_26r#yaQ8w1cQ2H1_d*4CFVt}NLJM~C0$$5Ycq6ait-OYJ@&mzVHDUcpOw4X@-4yq34{M&7|&`2g?aBm5*k!+ZGzALJMKD4*eH`383{ z9Gcg8a4&>#_d*1BFT`;7!V&IXNZ{^;6z*Qg;O>PS?p`S1?u8QWUZ~*ig&OW&XyERJ z7Vci?;O>PJ+`Z7l-3tTUy)eSv3um}{VS>9CE^zn440kVF;qHY6?q0aT-3u$+y>N%S z7dE(i;Q@Cq1b^&x&fNPU?p_$+?u8NVUO2P8?p}!D?u8@Vy^z4&3n|>akip#x zIo!Qaz}*Wa+`Ul2-3v85&_1exALK1Oly~q*euBsH5q^}P;fZ{Lr}7Itlh5#6euWqE z1zyT;@JhbHYxx7-$b;{Aox@gsfOql`ev(JPL?q0aV-3uGsz3_m$7lMD|bxzz12e^A7gu53a zxO*XnyBCgd_d)`9FQjnyLI!s)PH?p`><-3t@ky>NlM7iPG7;R<&zEO7V24enl8>FR|$+`X{D-3t%6dm;EY zU+3SwaDclPLb!V&g1Z-DxO?FUcP}Jx_d*JHFJy4{LJoH?6ma)K33o44aQ8wDcP}(> z_d*MIFLZGC!U^tP=;7{#0q$NH;qHYq+`VvtyBB7-d*KRqFD!8P!VT_TSmEx4JKVjn z!QBfFxO*Y^w_fMmy>NgB+DC=(gFJ$V@)#b;kMLNY!H@DBp2!P$Dlg%gyn^TQ8eYg7 zcqwn;mAr@7@&Vq+M|dkg!#nu|KglofUOvMI`4v9O7x-CzgHQ4mev#kdvwVYJ zJeLpfLO#Mv`59ixCwMKtz#I7tZ{;_5Ctu+w`5oTNH~1ibz(;xT$6x2|EKlI>g&gi) zDB$je67F88;O>PQ?p|o%?u8caUg+TNg%jMp(8Jve1KhnZ!rcpJxO-uOyB98S_reT! zFI?g7g$3?jxWU~EE8M+shr1UxxO?FNcP|A0_Ul}^7Y=auLI`&+L~!>)40kUa;qHY5 z?p{dY?u88QUdZ9@g#zwgDBglBiy}k zhPxLgxO?FOcQ4Fv_rewKURdDng&W+xu)^I7ces0DgS!_VaQ8y+@4U{xd*J|gFNARS zLIig&#Ble*5$;|{;O>PK?q0~??u8ugUMS)2g$nLosNwE~2JT*H;qHYF?p`>--3vY3 zy)eMt3nSdUaE1rkM@{g9`~nZ--3vY3y)eMt3nSdUaE7}VCb)ay0(URWaQDI$?p|2n?u8rN zy|BXF3wOACVS~FD9&qG;sGq3wJMcaQDIq?q2BO?u7yFUKru-g)`i}Fu~mm7r1+2 zhPxN8aQDIjcQ4%F?u8ZZUbw^E3lF$^A?RM`+`VvsyB9*Zdm)0m7h<@3;RtsxByjga z3U@DLaQ8wE544Xe;0JjL59Jj+lGpH9-ocOZ6Fiak@Kip)Gx-S5%x4 zOZY0U;CFcq-{cMaA#dS<_n+{C_n+|4`%iczKf`1B1V73z@I*etQ~4F1$rpGozrhRn z3NPh%cqQN9wfq5ZPU?p_$+?u8NVUO2NuP7ZSL8A%(jaGPrvohr1UFxO<_5yB8|B zd!dHA7aF*Gp@q8_I=Fk`1a~hCaQDIpcQ2gb?u7~NUbw*B3p3okaD}@U7Px!i26r#4 zaQDI;9=zW^uN(Xzf51a|@Mm7|8>{@I}7CZ}JCx zl?Q+Jb>8ms1ALQ*@P|Bt2k*aMH-R7IDLj;C@JOD+V|f8T%1d}6ui&Y?hG+5yp37T! zA@AU&`~PS?p`S1?u8QWUZ~*ig&OW&XyERJ7Vci?;O>PJ+`Z7l-3tTUy)eSv3um}{ zVS>9CE^zn440kVF;qHY6?q0aT-3u$+y>N%S7dE(i;Q@Cq1gF>ebT1s>?u8KUUWnlC zg&6K$IKtfv3EaJq!rcoQ+`W*)-3tZWy->p43l&|xP{Z8|4cxuZ!rcoU+`VvuyBB)6 zdtrdP7e=^y;S6^#OmO$Y1@2y$;qHYi+`X{C-3vFkdtrsU7w&NP!UlIQJmBty;6K3p z`|}sz?u8KUUWnlCg&6K$IKtfvDcrq~!QBfv+`Ul1-3uk$y->m33pL!m(7@dbE!@4( z!QBfdc%Xe$4?oBUcqkv?k^Bsg_<f7Mc>f6xz5j$q@;f}1Z}6l10Z-(?fA~6Ysr&%X*v3}|Nrmz&sY7KfBv8Fy{m)Z{)SgS_P*Dj-tgfKKfmGQPrUEzPjC4AhA(gU z`i5_BcyN2)_Y=P1@f)7J;n^Eryy4Xw-n`-68{WU+=}*4z=Ntdj`}Y0~zyI|6UVr}C z_wAQAJo~x#y}o$E+c$i9XP*DjJ9D1DGl%bb^M+sE@Z}A^zv01;|NqbH-N%jI@Z=58 z-|*@UZ{P6#4L`r(**kw;-o5|w4R7A?(;I$!XFlJ({`Q6+-kIBX*T-*o{)Sg?c>9L; zZ}|BQpWpD?8@|2ahj;$mz59HVH#~pC$2a`)hA(gU{S6P^`9AROeMWD1@`mScc=d+2 zZ}{U44}a!;|9Pz6@a_#C-tg%SzrNw?8=k)Nee&Jcvv|X=Z}|F#Ki=^0o$ssfKJM`i zuio&}8$Q0_mp45B`S<;PRd0Co&iCPO|E0~2{)yl4^_}l~@2wYjkdT&1dZSlaf=8Nkx1Ai;udj>s1OlJU0O{9H3(?l z=Q&lK92lATe|x_SAH4N@>eQ+AR@J??I@az&uiJ%QzYD!d^`kClhUzb^hjyXoss386 z`msRiBif~U*XN5V{YIr{sebuI`3dbp&)tQdzYD!+7kb$)^vYf65j9S9IZJn;`_y`& z?K5_v2X~?8?n2MsgPx=-B~JJfdevp(j*7E>`2PT6yY^CghSKYl zo~85|s$SVjFI4tnrJtbmT&2IF{NyS9TV-FM^c$33r1S%nUaIt|%73}ie^+|Cn#ZnJ zdci^Vy$2<&`_|cYD)n5QnwiRXq5GY_2Mpg+{xg)$xYWOZ(l1c;%2IlllrgSBrDrHT zTj>WXJ*4!5lpa?4!Ag%P{V1j9Dt&+|XH@C!m7b^cpz@Qi^gc>2Q2IZVpP16SE4@hR zAFFmwD7~-pU#j%)m3^7g&r3YNem2^ctm)Qst~w`UT3qPU){G`+B9%Rk~67 zFr_ys{W9f$i_#laeSP2A@ysz;q5PyP{qM?;U+GsWJwxgLRC++^ot6JArLR-v2`ar= z>DfxZPWcZh{SxIrtn^ByN0gqg{NyVAUrLWEeX;VBr}Vc}IrEi1QTZuQ`UA>7ru0e5 zzDViIRlW(O->2+Loz8jb0i~BYz3WbTx$^UnvaeA3V@j`7da2T@m7b-_S)=rPrPnI` z2h|RBN}sOm>y=)tbfa`n`Ds%6WM#ia>H90)x4v!sKdba~rN6A|>sR{6%05HskE!wm zlwP6yWGVeMr3aOMy7Hf`^f}5tr1YnheOT!Wlzl|$U6p;V(w8XvsM23k_IXNQs_gTX z{*KZMlzyx76H|JPvM*BlvC2N7^pBN&snVZQ?O*0}-WQ)K`*NrAzR-Gw^7ECluT=Us zO0QP>Je6;a(qB~NuT}at%DztN887^QDf_DxEEOxbTy`o&83ecv|z+pF@V zD?Lr=ex={5{A4J-qp}Yuy-3+-Dg8TTA5?lk>Dfv@Qt2V3XDI(+r5~g0BTC<<^jxI} zl^#|4Yf8^k`pHVqSNhXRFHrgbrN@*$Q0YZVAFJw>Q2KewzEtVwE4@tVe&wfJ>H8|Z zLg|+)Kb1FG+Jpme{|r>XK}D1C*}14_SB`N>lHT}lrs{XXRs5Kmm42Mcw?gUmGET#8Teu7GW zTa_nU>8C0CkkU_AdRXcGl^#+08A{Jp`unQBQKgSm<;hd}naWST((hA#3Y7ki(ql>w zDL+L@AE5Mv(g!NNROwf$a+WDwzh5d>`e5a!Lg{BKy;A8zmH%p`pQG$+lpa=ktE|l@CZ%7l?6)YrLbbndbKCgOQGU{uK1}I;rI#o_8A{)v^nlXO zSAMdT9#MKw=@%$HTj|4<9#Z;+N)IdjBBe)^UaHzBSLqik`>4{ZRlV|*eu=WrSNavo ze}U2uQ+iD44a$F!(l1s16H3ojda2U?rt~tUk5GEK(nl)2Lg|+)y;A8Vs{GYTze3s9 zC_Sq5TBZL(>2*pkSM5-*^sAJ;QTo+NZ&La-O5dXNYnAT%rEUD@DLq~3->dril|D+@ zXDI!8r3aLLgVM8>*tlBNC^jnmDMCl1tuUw^%R`yY)AE@l} zlwPRv%~yJp(hHP+tMVUH`n$@$Na^KZTIshby+-Ndm0qj#+m&9Y^a)C@SGs;rZj^q9vTsuQol4)L^t+Vq`?YQS$CRF~ z^t+YrSNfl-eKM3jS=k4azEJf`meTcm_@L77QGT+Oey`F)N-t7+Sn0(|k0^bL(sPv_ zS9(fcJGKd$^#D}9>MYn0wc`L9*_6Ux3$>C=^7uk@{|JVxm=lzo%ZpH%u5r9Y)~ z-*0W>zf9@rN`G9H->>v~Rh|r`Kdt-(ls;4GSxO(T{0EhOqSCXK9#eWq>9dsou+pDV zdPM2BD?hnPe^%K?l|Dt;=PA9T(({%6xN4sQr9Y?q$CUoO(uLyr6*Lr5v9*p{&SUHsr0DQ-&A^@($}bb^OfFJ=>Rb{|0bpXs>-=V>H0gVZ%fE%lQLg^JsuTy%Z(!W%CwbEBBy+-L@E4^0f z_p5fOQ~FY+*DHOE@?(^~R_RSjuUGmOrGKk*-|ubXe~W6*bfsUY%Hvo1I^`!r>Eo1r zKEA2+T&2%Y_EDv8Q1*FBZ%}%^ z(v8v!l-^GHk15?#_C-ohDm|g}>y@8UrT?hx%as0`YR__||D^0Il>V}^uT*-YvaeQp zlhSLH{Axxe8A@+fdO+!)C_h0Ok4xzhCq`wFG+ zrrM!W>FtzWt@PcMUZeC=RKB%J*XM%jl)i`ZQ?K+rm2Q-tuJk6QpQ`fRqV&C#y>DCF z`2SSdrz^dKviB=}uF^A<-bv{JrT?V#ETs=p`39BVS=nbR{bgkzQu^M?KCJZVN{=YL zi_&wI?pJzL>1V2Z^OW9I+2 zU#|2!m3@WM`zyUt={3qvwbJ)jdX3UElwPa!G0K0P(hpGf^-51y_D1PFlzo%Z4^;XV zrJtt!__nu=|AUl$y3!9;x?kxv%1?&U4^j33r5~#FETtc&^q|svDm`22*Q$I&NF23@^OSy-(({!bPFlwPXz zrAjYTdaWu?xzeX9y+Y|E4@nTHA??X`KeX3x+RQTj=$oViNxr|hFjKTYX*N@|1qUs zsO*cBev#4>O21g?rAog<>19g)Na^KDzf|cJO3zh#rP7VktCjvYrPnBZgwku3ewoti zls;1F^-6z3=|<@TReLrm{qM?ti_)V?_qDW*{~^jxy3+rl?EOmrr_wW&ewES#N`FE5 z&r^p!9^&Z&G@x(r;FJnbMaly8~oiTIpkzUZeDJ zO0QM=>#7~RSeU$68xmAz4VfwFH>`h!Z}qVxxpAD=H<-Y)Ek|BhGo=}Ny{>3*f} zru<|m{SIXxPg@xyn9U>4z&lr1Y5b6IS}&N{=YLO!>)G`b1?PRr+M5 z=P7-m($%Y){{{co0{?4)|FyvXTHt>z@V^%LUkm(yX@SjM4%r%>^h0_$p7!q8lYHUA z>M`wFYQvM3r7xB8w4A)|u9JK%N36$xyBr!qh%6_;z4{jXJ7P7NI~=c8comsDC$Cy~ zC3$yph42z`dvclZ0&*HTAv}k?2RSA@o6PN}moGe%oKB7kPb2R|jtEaBcOZv^r;t06 zgTfQZoyY;<@#M~Azwl`C-ejNfC~_Ba)1MHIxRUHA*9(szcO};f4<~mcR|^j%??bK- z9!Ty^E)(uY-j|#Z?nB;>924$E-k+Q=+>@L^jtci6A3%->cO&;8hlD$j4+O^ygpCHEqSgr|^?AqRygl8+?^gvXPQ zBm0F%laD9+gh!E2AUAE7{wD{?^}-{_y~(x0!^wTf)xtx`Cz30K2a-=BmkIYHpG-~& z_aUD`jtTc7^Cg6rFWi&NhcYiJ+=JYg91-qD?ne#@cOaie4hpv;pH2=4Z@mNDpX?Xj zL_UM;6W&NZliajT`kx#k*9)&E4J_?+>Shw91z|*0em^xFT9C-1=%OOk^FaZ)9=#% z`-L}=?xc!Yj#>$Q8m%$dk!s!VAcSFuQ@KEwY zNM$$x-2Hh;i=@=-Uj`D})D<=aS2W`;q67 z6T*GSZ;)fcy~y*)`NBQPmE@>!5AvJjh;TRZ0&+;W1Nkj-P`Dj=Avqwt^)_%7*)P0_ z{5IJqypgQkza&S5yOCFuL&6=%Uy*~t?Z{t~1HxMiz~7Ml!kfrz$UfnX&Vr@E6LxHD}__6d(7Hk4kzz;Zfu+D3F5Aa^C#3J)jq zXrosxJe0f-xk7j#nMW4AGU0yYeaQ*oKIHw#G2vch9v$@Zg?o~DWYCKW_aO5~pcfJD zM&^+}FC^T7d>}a}+>Xqnd|p6!>o_ov@OggWO=KR?^L)Y^$vm3pHT@|4PY#glg;$e# zM9-@gUPb27Jg-`KCHZi2h42z`Cb>*_0r?1WLU<1ONODYgHu)%WzVJ+P7C9;XdS3$T8twWFG1A@`Zbnd6dhG3ilxM z2$vTT?ndSjEiWY8fy|>>UQoClnMbm`fbdql_RHf@EYB~ziOeHdo==WKd=2021 z$&>ykN6GcVtI7W$*9xy9UrDYOUP#dy#qM!^;=$ zN#>CbFDl%Fd>c6;+>Okm8eT}a1DQuOyr6J9@&s}~cP z8l?ZpF><}|YVzIWTH#gXiR5bGmE=j}3gIQ>$>cKO1>{0-`896LU=)idev<4H-bj9m-1NQlKe>!tFT9%kG`UuI z6?rDPT6iUS7P&%r3HcdvneYPgv*d*E9P)GInDA`!^W=QtndEYERCpTs1#(1qDtR_J zBs_)uA~`5Lk^B-lAUvM@GTARYn*0jcCp?P$D!FOB^gp?RTrWI={2IAdcsO|uxmtKA z`E_!I@Idlha+z>H@;q`vxDWXaa!j}vc|JK`xF@-i92M?Cev=##?nYif4heT4zeNrT zw<9kk2ZXoY0m#YaxJ-Dcm(-la;@-i@+xw*@KEw63?!Pxn6iR`CD?W@G9~;a<%YE@^|D4;U(ntuOm1O>;z^f2mLT*nk6J9{(Ptd)D@EkJ#G>aD#o=xUY zYrTBondEeGRCpSBFLFe9D!BtW1kNdLHrYS7w1ndmGSkiR2;~&Fm?NnaH<~s0!WS-i zDU+|0!jpc?qSk?NeZLvom{Z(fs+@rj^@l-#1|D9Ev>HsOL3~D53ogZLO=o;E=5=2T zP-b)oqH~aD9@9t>UPOp7v#22EGFT*NGPTvD$eF~PNjCGC)W7D!lYG80=}dGAcBU-e zA&e>faZEblFcBNgUM|l8tqxCh4o`3n8}MOo=W6f6xKy>@aR$2DoA5TI)!*-P)Wb;f>rjrQa)DF6oDZctlyLEKvk>2Cm_v8TVYzw9aeK$p9sh!FdEt`jnSL3_ zNetw*hVOsEeUo;ie*yzmqN9|r(d_QZw+$~r*yyh#zIXLoxUYQSqnCzD(k8axxX|M7 z(!#ru#*q3h?NT_A2JC;>bC=>vzE{aa$z?)s?cVC(+Z`NyVjYY{vZEY^)S=`uiasg0<# z5vGFL;&A+qns8yum^2eQX?IK#n4fTEo%sDS729BXLQU42%P@&Ca`V|;eQ$@@0)P#; z6HHf`#Fm;j@tGz$-}Iqjd`8sGL`${(8?^sc?*65wnD+NF<3%ST^ZSU%DgKGU0leSh3p2~u=!Gp^ z3i%Ny9G{$7D%XXX{0Q9pw{S^!e!cRU0az}>@wqm7#pFzWqvXFZ!etU-a+@rC8V1>z zy~2w(>~0RgVuG59N&UYa#%UgtUVs1ZC;7~|*n~26R&QIEW2Ar$=AU>uldNT} z@@x$@!GO~x)&kVeLYK*>p$RE`3c)*Gpurr4wDfr>ecTt0pYXOH!Qzs955*hE;&qvPq1g1F@h6H{j(wsx5Q2H-YdUT)&%J^v>K4u* zZRH!DD$-R_ibgYlMY>d=!8{EAUY>({36}xF#Y@d<40CTiJF4Un4v28^Beh&*OR9LD zEnHk!2Qn8S2}S{9Oqk(GRiy}{!6kl74@6Q(*)I!n=t~?jL1ZOUoFxMZHqeID~j#@N&~Y}xThlYHCU%F7pU8L_z}c$rj{j|+PM zvqo{DRMC#6jV+qDAEPH#6-C|xGKUyJyedyI$YU<#VgE@oHJXS0X7R67q9Zub%og1J48!JhSS7C z!pVhgX}c8Og8V%Gr%i;z>y^X5TZhS)cd!@&wYBL_r}+*|FULMjCUoyI4sc!Cy=gtE z%Cxp1LuSiyf2FRYx})bKtv}fx9nPD5$LKwG&h9C=Xf5f~fA{w}T8$0-1zwb(oZ|OA z8&0rbix}Q9kJphTWm@*{(GNS1h05b?%Hxgyp5y{a(rkt!ij)3OG3Rcd?|-;NZ{c>% zZY2A^)b(VaY5vBRd##Fih!JaC#5;_@)Rk@r?qkQIDdFe=Tv^}e8C|k4GlZMStmdeW zr*%C0Bn+epnOWgU)&6ktWZA8l%dr%OOK#w0Txu}m_e+#yNSGzDrAxV%trOOq zj4qQSGGZrZMvz;$B!4&aIMyw%AJif7vrRajlNrn@o|{?Ef)(G_UanZd_=v=R-s!M> z>&bl(dhXM73=cc|T;xadJ@vIM$i1BTC-vX|9C=`24GLY%jfmmO^DI_17Wr~(`6C(+ zk2bWt%vqjgV?Ig6G@Ah~=4c!9W?RfrE~X1&%*r|G(pl|jR`}JJeZnPak2ax6N-DXR zG+V#2oxhHIy-EE?r`$A}dc?3$HHcw1^ZgHtv<2&1%2ST=RN?GP=?PDfb!eW{Q{*zH zNj*aR%Ng+0Kup5(L+CBytsuot||&EyLf4x)Nq z)n?^}HP$jnP%*jzmp$pB@jp~-a+Bb*Chk6*|lp%~Y<7UO9wO}t?rmwgtC z^MELgW>2{GZooKW>u=q5Aa54430Ib=nw?lUmz7?a8N@?^$$ry9HOgv^5txt}ar-w` zc)m-TpaI*0lnHJs&J)SgXJgtu|w z_-UM57MXY*6YL(2`@`|!=C?uqz;0t+Fefiampi}nn7#1c1ZALazW?!7I@o+GVu~Gn zz7<8K85`_N9dkN2r6rRy`L|}m#e*_K?B=jJLiVa`^8*oL^FBluTQHY0r+Wa&&luXi zmc?U|O$=#I-kC1aQOXVxDgL}%~d>YeY()0dw6(UuL)8>NC>IFmLLoy{Y3v79bC z(z;X1+DxF;NQb#-vax-Kq1`Z5v>4w}T%H_kJ`&?=66Rmum=4S+%X|yPEPMrH1H+E{ zSMw2+WHoO3I|jP>rokl9t*q!LFyJ_SZ#2hiqgje;Y(i$PZ%mhP3CjJ>AcW1!R?T*5 z0BW|+JO-6M9^fD-S(qsUzb8ecjG6)$&F`1U+$WjO!Uq4)j+it@p#aH8T9YMjNhKTL zlJ&L8-o=oz&jqFflAVZT|6ab%NCS1J@-@>Z%GZe1h;?iLvyN+VO)fB{FSCsrO)VFz z_{n|G;Of*cr1)!d2G^@e{m+xEF+c}bViqmqT{IWV6z9n4NMkM)2W!m(grN>55@yu4 zw8%ptZG)I?%w?E-%snZY*&aZ7kjzp`%@1-v;rSjGOtXFQUOsb_L@qZUxdr_w78EZ( zWPbq<`-2mvcgiW#E&CEq8|98(ZXR>#8r_rDQL>)4m_u>pSV=egG6YW_zyj}b8ccg9 zER-aT<`*t8Fb$j8pIOtHh(VH^;_uC#YdheEMkJSdbKCngOKix#PQFeA50z`br}tzk8nn{(w}Y&5gnMl@uGz>y4e^8m9zM+VH`x9yB`2d$t)%!yEv>k=kT z&mnkbr4OO!A@FR*Xn9Y{eI!FX|I1B`=R;WVp4eE08DU=+S!E-W-?C^G0*xjenX=p= z%mJ)HnN22_!eT&J3 zh4<^9sQ6FexNPxquoU4DG|15y4;hX~31dWNw~ffqDR%A-V5v`y$qGc9`77Y-c(&6R z)3J{2gk@~EE|U{zDGr|oEJnD(Sh0Kb+K(Q z*UNqr-(O&sT)#UA$QhoKK-gN_dE znUDUc#aD83;3#g^)4JpCrR{+Tmm?j!u}ir4C-j|n7i^bd!N`d}lNm$q-nQ%xKD;6K z>d+?~o(-RO@Oh_6VVlittZ{6_IV=&bvvH--a2a{cW(wky7+;Mh=2pWZXAu;OMw2HV zT1=Gj@v1!JVlJ}be1^j|>}U9N8g6rj?+z&Arx(v-5|0mb&%x8<<3bBInd^$lI(BeaPu%eC2DfSo5tM6obFF|A4E zXvRU3PgcW<|1{SDynmtjq>L|R*5a09883jIN|7qNcfPgL&W>jKQ>{J>Gr6m#=}P@j z=xo9ErrRf+_>x#4_~SE<_S&Tw=I6SNfj?X_C^Hc5yJF1VoOA>7D(yV(KuglD{a(#7 z-FojZ%j{FsHp~1p8Z*bJI?OWju9jKml@rCb%LD5dBlCFL8Aywnrpx3{$uiq~axcoc@~z(>6v_}4a@i8;_2-LuvV5sZeF`q->NITDPQfM}3?;;7go6a~+a0$a=QH}z$?VI}+1y-k|1P)vrP#+MA7eE? z;Gjmu(aEl9-hv{NIcMxw0JvlLYGoFJ$$cE`*I?gq-p}N4vxjhlIRgXEnQY!*O|Ew) z-w8LE1I47pTu6ViEggc8OLPXsj~%?`JRI#jJncMuiIKy?b#3*qXPbxZ9G58%H#-jv zcJP|NI}eXJ4J2xaVfLm?XT&7ehvRlqq#yYGH-FxBm|AGQh6Ddaw7zM-bIEUg z6XSjWC#RjhjLb%w)-NNMbJc)>?9<)(x?*j>{VU$IcbUvzjAEX{=fvtiSmwe4UgA}} zn9mQe&s=-6I`Jxg$TkD%CSKLF9pO`K*hjq=!#GjK@RLZ#+30glwDH0yv~YYzE-%G} z+#B1cr|D@DE`Be(qL9016b0Rs<~y2GL{)_5vc42nBhuW)J}W5@BM7|Yxr*9dxl0bB;$BE zL%371|7Qqq4lsWp#5?O0UgK9~7I2BnAJX^hF-P+QM9Eoxw<;mPr=1KT+G^YKUaq+5p zrmeMMNwdtQnSeC3n``4FZMln!iofgPO+R&m$3xI-ik^M}N7 zz0E<0o(72pzTcq9_@!zOEVCKK9r2osTV(0V;DHn z`P>``7r$gz^uPGroSYeskI4+=9Q{-4$4w7g8un%HXF8$e?gQldV=N@#-#iusVAQp^ z?c=GeMf~(kb36jcI{IB7R+c1$2yZYB9MHX zi3TH4aw7J#%S}I~FX=x?zSK^)o5AN+pqbo(#05x{)Au|3miI<(ZP5Yznw~m|__#L6 zfq}UeMak)#9J4oWogtH!2h2ET{G&M(1(F^8HDGpHmKo_n*=9IHsB{OZbfX#AYLksn za<#QT)>*B`4v#nHL5@Fl+=-0asehreOl`dmb!kDJXzyOwb=GUIGG#PBE^&Sv-uhD+>v zx2l_6%Q~(-`+Q@c@}lTzC|bvtf^s6cG^-PE^Je<2&xXLhpgTmo*wBJ68&0DgJf9MFWbrFUmj>E;h%=;Qa}Q=Q!DYBdwnH+o3GhzDL=?KB)L=wDieC4u>cU zz+j)5jHwE*Kw0GjaC%$_zozzX zY(d&{=wJyZBkzrMoqe(*T;vw-bTbqoHtIkssPR_W1LAv{vk00j7Ydj)ZqoVO+3bxN zt`z@y`~Q~@B$HeN$DOOCRdDq<``ugQ#%LI0ln*tzFC%Kfe}8IujHzGTIdu=D_HIKn z$V?J6z5YZWqn_Q6aX8+#o5J@$6v5uPr!WMYpU~)ZdSq+NK`!P~7t^UVrk#sf;9@rM ziA&}I(M#IHfzL&;Q&x3;-%p)BN*3TIVr z8~N*7=(5+SBoU&Ip!t^C3>*FoVP^UPV_|i~ONhIhp|_yOSuOy}@S<4aJUjK9r2(+p zKrze!+_o$eU(T>h6#2F#*k$rbwBuR%AF(s?jwGQ7dFK8qd}!g*uRFH*j7@}nq$G}~ zU4EdQKf|e;SKbnRfzru485Xby3(`wmVlT;p)NSkR^A`V!mgUYlJ^l#)5Mc2>oX$#S zR3MBAJg4|O6YXf9I!j+?d8+adW8TNZA1CHza&0sVaZLuP%yG(WTvOJ6&bG~VN;@20 zidSXOLkD<8IE&#stu6m>VNS`sd`j1gn`ZOSQ2Wa6KujIx6m%!^xPQ`qKJz1a3tB>P$_%OP!gjW>SL9+9` zv$&C0Fe&LV9&&*oDSv2kI46a2e0KS3x%VCp)CXy9k)heFHEM%{t zTs2a|Dqal#S_<667|zM!o7t)&h6Bh0;ZlYlW@;SaXSfJ{5w2%=J0Ifk7KPzNOFP-S zl*`@_@6Y*|f}6gMHaq9cW;Ji~b{#97*kE20bFBX~$4@nAFhjH!^9T)d#SriRM8y7| zB8OF~U^hzy#xo;Eh;_5+^)?L(E8z~~yMmWu`;JJyd_SC4%~o7dSc8jO(9hYQvqDul zZPkmLYPRR@aBDWaU~6_~4ENIuZ&~;mizV+S4_6tpW)aLxzeT{D;d{$MKJ4S2JHZ<# zW1zvzk>o9AHm>|lO`|EJqkkgWjAMTBd2D68e`3oF!58ddm}l@dCSd->BslQ9)O^6o zmQ=~DIp9rxa(QY!F8W+S*-3;2v`N=cwTqtU`U<=Hast`{X zV%D&a`Kdi)ciE0&V!^gC9cAS|+^XMpXDu+Py2JFYHZj)b;^*K}y$;DsPBdMytCM{? z$Hv?@?4~K5-?Pk-&tL$&WX?w$yd8#j)_5Iupr-SiEZTB2kBy3Col!*026+D?+xBL2 zx?CI0Nm7SKbF6TKSuX==$204G+N8D~OPzs!Guz08E@d!N#t+VqL1cNRI$r76jxW6b zc0Ag}&vtyJ<7tkEJD%crpyTn5W&esQj&j`7#gA~@&GAsj?Hu=Wya~gFP1MWrI>$X6 zuX5bM@e;>du`OZ!<~ZKyc&6jkj;A_a>3E{!1&&8Mp6&Qb$I~1ScRa=MKynE;S_M#8 z@*ox2dR;>Wp^zErLRn_jOxnATgoDLNqvj+a!PK%8xS|5>p7w)&4S+vEvXVN<6!<< zE6yVhC88eX0Jdn<4%(dJU(F+sSfPlCyU0mY>?_Iw7nx;la-pEP%7rq*C`rD#SgbKW z4YKEr{APFAS~Z%}oMF1@jSz2*qs4Zu>|aqFX1|{^ikMDfgzp*F2(LJ82EX8Lvzy&q zlkvK}H~n&NPAOy2(>D9nzs!>3Pau8|0_Eia;Cn`?-R%ra-XP|%$0Lb>J`7jg}E5YSul zClgCcbaK%V(+(ke-YO4vYx%Ob5kc=B7<1lV2jEP#n(_F#3V*SB|JV4*;p5ysAmVO} zG#I?i!VkeG?%sSR_yDt${r>5aKY?rOA^zi=+sWK^wj>q1+nwF5yy91h7(>aA%wV+R zkoX-LL*iqzTE9uuVy_BOezesS$JQUiSjCp;(oSP9j-S)1B+^oRX{SkMx3PPK<9oJ5 zGUOxzYfy@GW+`rayjrZVzxaCgHx>l@6I{J3kta6)Cc^E9ErK@$+N7G6rY?)yC0|6k za;E#h+z9*RJFbe=uhKo_6)ccw#Sx)kn%_RYah8~Z$sv@c`b_U`T81q#l8A|agSZ$-pO zHeAMV7Q*b=fL!tY!^Y(?u9FRyGwieB7{kBF17lSI!^W+Z^;RpQ#`P0<@lVQ|@RJCa zR8=tiLx0(OW-(kr8?2*wm~~()c}%zIB#(p*OCFOE<|vyW*G4nO#z|fBY*^|tQsOcG z<%<0+uC0$E#f6ebw%E^LShmadQK%{b&MBT3+|E)hOq1)1!fYT0EEn)VXU=svCH1VI zHgX>qRv>5|MGe`4Yxp4fyX~4`#lM&j!ARJGgs31Z;!=f~D#Cj!^}X*qbHQ{BrPn(zqYINsndiQO7sIRA!(;LE*ofbInG0z6J`GRk217<2fhHQ<`!{n6qh4cF z4x%t{b8xo~VBz@F8R5-x|9LrJ1Am%)-Un&b09==_7NRJ^PW5U5vL}3WW1>80DP8(#_)t@m_n7 z3Wn_v?mc&U3pkc>shvlbGmveUdkc7xHrNve@=SDwxLj-YdlDO`D0-Eh_5yZM=2Mwg zn$1DZ;ulmwELehjX)y;D+*)yeL2(ZEgV;B7f5B0_1S#llV_6sc9?cma=Zp(soG?$Z zU66GCV872?2@_M|l<%oTsNC+9NmS0Da-CBiq;f2kOP%r*l^#?EJLP36=~Pa1$}v=a z!<}mmbIRYStf$h&Dfd!Y#k(8z8!w}v(X8U`4?N2862~JP&v87|@l41498Y!J%kf0V zJsgjA+`;jcj7ZEP{Ht)YiMse)7tj4`>NLJT zr+5rLTNmf-_+&9`FAm_-Gr50>r1me|;+mz?a5oMQW6`c9wx{oS+Q}X4s-BUu=wl#?Ae9f@{il&Iynn zh6$7AZ~)=f9#Xu0Y=gPt38*Er#abaT=I8Kk#7AzoKw6Ju0DJQ=N5No?cc>8_cQG=uY2RL2=Ppx`5ZS4o!!sA#V@Tl zQ~XCG) zbwg`25@9UBxG#CXCZDE#*x82|_W%oU3R57npWN>5NU%2=>1lp|Gw(|AauKor6A|Cf zrRA{x@qx{j&=`chlfn!)U*3bo<4fo^H9hXd}ahv7uxhog{s;X)o6Xvk;?- z@pC10qdvoirQ8o9?7fWbQK|`I5Lkx-Ya}JT z!G@&rP9CSlo3wZU zAvXgznu&yno1@2Cdr5m8Bih?xDh_gOq?95DVYp&X4roimp5*fpT2{K|NE?=}>0!gt zHGA7|j9t^thNWwML+iRxkYvyer?oaLqu>*Ez)h|--y!6}l{KK3*kz@9Q7sI*z}u!1N{duMC~T zusgDG8pD_>H}kWF&C(nN4ULq_Is=%Tgh;lw=>doQzR^}TJOi+8IU{p>j|gu#EO#<; zF;_9h<+JE1I|S$B%BN(>AeHN!NAMWi!CFfgR6i?!MKSZLj{VgzDZFQ-_hc+z5T4KXe+&2*R4*9dKD9(<>FhSAXn1y}cN843A1BS=MpXJu z{tCn9DJ*8%$ZaReR0&hO6LD{2Wa3a=t!Zv#o zfH4|c4fDO}GN?@c!1}}S_$#j7{%sM=|68t2|Ea+YzfH#M zM*lZ^cHzHga~hI)m$yaH)lt-jv}tBP2(0GbjQDJuh1~%E?k|b4`X6ikGm`&%vbp~) z*@C}JcE^87hLXrFi!a`&jyLu%on-$PC*B!Mw$mH8-I*x$NcjeKf;7-?+}81dE@kit z3^1HWHe4u*EJ@?(}To~>m+@D&0O1l{T7kS*N4SLfczA%%oU^p|K)cV<= zc}=^vKLoT9z#pvRb%^}QfoxMp1%+$Ej?TOXNG_MRg8?aGv&nEp^b0qb8rbo)IgaGx zoH6#_4Bh#rqR$nV{EuZMcZx+a za6aK5GKtGeCi%i+-h9xO`{${=wipjruJqrcA6TCQBnSL{7FU!mAL-5D_x*VNE^i;U z%DRW|zhaK_?`|DjhbvoewTqwX+zlyVD2!PjhW z{c<9QNa|e)?=W-fJ=VpUaA8K=i~oE!9W{%c)>XDDd6FZ3|IHG}yO~Q|C}MJ4C~OA0 zP{?GvP_8-Ng`)fsB|lD@gQ(z_%y?CbA2EByER-#@tY_{dDF5bKPVr0ad6gG5d=W^~ zc-pqjJCwf~f8osh%QeAWPon74P#Lo?%iqwSOh7Bhi1 zsAIs4cA+d|CP72`0Nm4GE@G0a7&_0TI@{T1o6}t=V*0oc{{9_97ytpM1kHXflxI4* zP{_1%prN_xBdbyjA>!;!rD^cL@C*ya{Nlrkq}6S!Y6KD@>zpSJ-m2 z@zqT+1U5#4xl2r%&A)KvPo-~`Yoj@8hOPMDEi=(Y2->Iip(3v3_u4ZNWLBrjwZSxE zPsBT*;Q`wKYtbt#!v1YZIw6?+geQEXJQ0w`U*`HTCR2Y#M8bGQm%%s8b_D$XGq+ec zsE``N369}g(Midv^zJ>xompDXO?IG^;N;pRcO!BcBd6o$bU**X^FM&~-gBZY_nEew ztjZYLh0sc2^n$#wU&WtJe9Uo>#ih!PRF)6Fr%ruEZ~qtN9fI;A>o9(X!&m*OQp;cC zsY1@l$ygom{Er;zeF1M?*or6jo1P5`XsN%P{BB9ah-xI8)2Z!cZ-zK{?+rFbi%`EfCLBNiV`=Ni1U!{BC2E7 z(-!RN%s%K3b3a4Qe|x@;El{twJC z^_|r@_HvO=@)Ne%hYl#@C?CJLyvgfBAOnVG++T+fH|1g@{H*yfQ z{w5&Cs>Ik1_!;O9QZP|)6`QiuPzpNkmPCin!7SkQ81ndm$!ZyB+;nQt6eH+3}Tvl+Ll;KS3 zm;=9-d&m0si!c2BESpCBZ^syx$DAg5J0xKrvf#mf$lhk+chG6tFF(q2R)8_~LpdKK z%#CRIWE>AuVMg$nQSpq5?FjNO7d^AD1XmPRLSefm-$+%p5ZQW}yxm>h$3Wm+aswke zs));6#D%!RSPFd(jW)=0o2}U?&gghXe4ru@b`kqBVy=p4?;^JIDbcxYvf+HT#CjVJ zvMuYRFY*6>uv(Py%Mg~cov8}EE=G;!MMey@IpxuE<^5>W)Tw~Y=CldSFzuNiq&-Vv z;o4IkS`WSxsk;4b4T1ggDF>`;ry3evYmKC_=2N&trFzb#dXf?S zRYZx4C}cz?B6!~vI58hrj@dl9HkzpD`1>QWUu`xKXBWm5zj{Nd&ajHz3-_kHBEg+K z&niuP3ul#nbX$qfaO2Ay+6hLSG=gT`5u8Ra|I7BU!EADi=WLf`rs&xJiH_%gTxq{j zxWP zU%9^PX4edJ*XlIPb#A@w_JeJY*)U{|>+pah_Fpn!r~D5^OKlS6U%e8@@1}Ir2e(pfe zKF*2oyhV0$RWaNu=2#?PTqYCZYXG$j(VC6lYWbX>Gn1$-&M+~)=pg*L)cCvtxz(D@ zn^+l##K)x%iJuYfD=&-Pk7gp=_PRq{nH$(zYi0k+{N@%(oRpy)VSXHGF~`Gm@)@KN zJptYRJr^e|8rThmxTDnkR+r|J2OIPdTlX6Ah6cS{0{oD9AwqO{u2UlB+xhkfl^Oid zEW4XU>}xoPnv1c2qg>Bj36ym69n+z)-a{qWy-Q^ezt+6v(ge)UXinzf$x?&N%dp-t zvEO_y5`I2pa!}G#evHd7+>a(73YWNF`FyoMb7qcDOQN}%{5_qFjwp)Y70BGqO5Tll zueTt6m&=0Uh}|swz8Mej_(dvBuAm9~3qRBua}F0344@!PdEYGlf<-|&x7=mR88FAg zo>e$fvS!H-a-lrajlOsi65HM}#T}Ec+2U`*4d$IIrGTp+WeH{0`>-B3!7YCu2G33z zaxl`obQ^Mr-;kLxr0+L4j^Td4{RWcZ06z=!B0cDI1le1{NyHn#0e31VA?#q*av@GN z-0)(q6Dq?U6Q;Y-c`p33if1t&w8Ck^4Q4Y&?auFb4y8@%_FCl(^gEtEIS5h)uZcm` zsb~wc?+2Vk)|weg+s$dk&^T=`mfL|nJzvIDi+NSX6n?+qveNH@9@1Hz?F@8TMr(s3 z#Ndv{%zf|Mf^<&_w>yFR*MvD3!--?z*8}$PnR?#enDUCSwzFyKG0(E8GNgF8|6TFY zg&RyY=V1&eUCbXQs}_068R%lZrw#6OIlMs;Io>1*IDD?kz$s8DBdNsih?xsfLIf(z zPzEN+w?_4!uX7PS5KjcDN2&@Qc^)+u$)8RAWn6r7Stx(CUH&E|?|kg5vvK7={wxOnKcPa& zWs`GQAcw0mZ7wBFjHa>(aO1rvvS5k3pu{_5R0gNaNUq4J9L#^oxh#LKIRsVn_CRAY z->z<9f0x4p(fBxNV6x=MrNYM z+}YzdE+M}62{V7R*V1*iz5J<~gjkdQW2~dWaAcyWmiY?HxcB4)jES9|L9b-qslO}1 z{i`kWTl2X1;s4(ylQYWPPs)hDALz=yQTBT~{@=9r)4tvn13SiU6mJb?-d*rtV*kv^ z0p097zo%ixcKZ?!^Ss|b=0m-VlNAj8K&=WPj5=9nU!%H!DV}Etf8eRX%wT8cJsid1I zbiq*WG$@iTZe=8wJ*JE(<39iIckT5&XFtc0_x-=W>7!@wwbowy_T6i*y`O#d!&ZL^ zPu2;)=hsj(^N@yc{~$xCXB8<0-hXSnjK;4)oLa6>`aalHYOk;K3-ILS6IeeB1?3ml zZ(a(=QHZJZ0}2Pxk|X5HLMa*jM$G#gUTI23SC;whcnZE&SOY;Q><~R_mLb??^tN(O zKZo8PEr;XnYvqrvjOm4>ppQW&{h8rQpv!qW5cq=Bi~=ElJRNhy;Fz;mXh|tuZwe2v zWEjdfya~033b@n9e_Vm9Ab?c~&VQ-O z8y>++g~{UI>@>d(MNgatqs3x$h6E)q@+4S-1(et&<9>;GK^%fyQyLQNgPun!q?lF0 zTxK$aiT5|+1uir9YJ48zRQt~pww4hy^)Xw!cPWYAqy9!SW-sBfmJC1Rllwn2`hxw> zW^3iD`#f_UhnAf^aAigNheXZHU#*;f&&3vu8*_0#=9O!jA}?##@f$_GEPr6|YIR)4 zC!2Y^#cDZxu>6s1l@?m;RC6gpGzS-vf(mV;-e2r?t2$ZTB9S7E@i{j89qEra^V(@DL_~@VOg@Rh%n(s5^t07g7a@e+-a8K>E$-Zh9$R8 z5YAu0Wbdlv8+giw4vEhy@fi~LvsJWy86@yT45j)Y;xXET&8Kt-eYyw()h8SHhvc3NYj#Oc9E7jvogYw%%}IT5$k>(!Ix`r z+BV00%;77yH*Mx}3Ll!PHeWWYUzBkzw>QP_SlZ{`vDAx0@x*s5twA;!xEp(Be`Xt- z*MlX=>dVsQn!$83d3(df$RmHF_SDuw_S7fb-exnsi>mQ?xRENY(_DeXvNJOP ziAh+g<7un5?>XYa&f}_&H7Y&-HGG@OEafnQy01hE-!FunobRm+KLnHKQ1$a(*$eHK z$QrSw*iYsf4&X_l9a(2K^kuZbJfB)I#Y}*Wn2+QAQr5em2YZ%SQiNgD@B`gxDq0J< znnx(=Rqs-YW>T~?MW6B+RltyYFw7&G_+V)yroHmZTL`bvu0fH0CFbV57Hr>^nxHFl zD}e;2p;A6T(m7s}KE_LpVGy!%kwHf$@vBh4?>eqc|}Y2mGdPtGOz22a|oVe~3Q37#d0P)Qv# zM?(7U@W@09?_Qh*G5@SbrM=y*EDCzl3;kCLxVv5bT!9)CU@1*k&8m?pE2ESvo02kh z;`}nY&q_6hRQ`Gbx$9squ=vga+s+tIln6EXIbjCQ;^OU--bnOGyG-8HcL(R*kL|6u zxG0G`N?g2E_7-pA+8-HYb$1or4_n>qezLk-dL70|)!YQ#?AY5-#6S)s*e1w9p2%S= z;{3C#wq~XehfGCjXM8UX5o)3TdLOoRm!KZ^-4`)So&-Hd(vkcHx|!sUNycWS<(OZG zBZ{U-HD^)}LS4-Yx+KuJh&;Xv-)?FJYV}$#iiV15t*U#q+JfB7Fd&GjM~P-!bf`b9 zmKUl#MHcubOg6KuY+m8A51~HRA42lhNKR|_@ng0JgJJ!d^Dyfrtn|75+~*u z+Z(A*(afte^E!OB-`~E#b$Kx6xqgnHyO}!j##2LPk=G{^Ha?(94W2lVG zi~fr*4tX<1vwe<@E5GdkR`}Zv4rv$>bY=w!qBCCuiGTT@vwCl0gyuiR%wCkS${(Y& z(_*yJVho`Sb}R7yn<1<)abHM=ZI)(Iv{JTc{eK9&liPw^%pYtnw8-BukG5#%){I2? z<8>D6jtV`vChsE!!WWm|Pa}&ww1_l75!P7Vk4ep5M!G3yJ0o^+6&%Cgg5i(h;mkB) z3{Q0hx8vH(-!%^Wb@;3`9Ecc_*k8N z3LiP%l^>m@$EnAdbo*}w;*_c{WDPUvgs7UyR>TJDg&AKL7%f+(<@(Q$CD|Jfql91ze}Rn=5cS1ekdn5+(C1 z5MswRAqAX#I*$o?RB~0UQ~@`S{hWimLVN@PqVYGKm|mB7f%%?s$ukEb=D9#620_Bx zm%>fXU+I4Df0CU}n7YOe>^`1VkqPs{o-DPlakx>;j5?a`%pj&y%Tp*ZC)HC~0o3%7 z0URTtDNu+ek?C#oT`Xd#t&rgUzNgcR{bFf#;LLn^x2;_XtxZ=mrw^bdKcg#<=_OSC zds{?*>xvLI12{NwQxtoAKVIju8=hoRxi)OuBT|_2w04*tuyuGNij$WLs;F+4fbZ(tnNu57+j$uTOqKqY6ZaH-2yyx)u9(SXFtnO_txE zNxx$l2pnVilF^qAf4U7z!QQoDS<$}AaG)@HU!~n_8GJnZc9vT|JaZe^-dO=DM&x+; z%N_Z;l>Zy$MO9eCvnj4MJUx&!8$#glVLH8U>ps;ws7$y8?VO)Wod3+wPpWSPBhxhU z6(jgns^m1Ck(YR>T#44vCh`mZuAcr!??NWK>3NqPCpj^PCy^lDFf50h>qA;68-Kjwei)8nmZ|6|WxB~! z`U6HeFCZ8OITC-M9F7GpGxvkiE^`nTdqpN)v=^9};F>k?emP!85HPGi3=W?MN>sxA zPqa18=Y6h0Ce%BOYXkI@O#}#WA&H|a`2Le5&oy(9JpWl%(E1kxdGr+TNI7xOv$n{D zp(TGA$#u;AvTn>Ztxz02VP9x|#Aq-@GHin{Y_FiSXK{AZ(L)Vf-|ie&U=;+i%uXQD z@0p?0{5~|BH6EFjzK7&z#c(VU|AJMT1_@UB+LCAy?&q*Q&sJyS5%EBmnNu}>x8ya< zQ_6H@skAxLv1hD*vC}lCob(L+3$JJ1743Nc1+KXaO5C2gwmY*fFx`uz9C>0M;vZi6 z2)-mU`wf{T@0n7PJl9l1a@#Xq#3^ulhW3+M-hdXbXTD=!qZvNz>h#Rz$j;o$GN9oN zp`(X;-l4SDGo1<7gq|7U3N(R0mgzvvEun;2Z-J|7%0RQZ%p(a< zDnNp1j-;VQ)(LZ&8LsGFCq1&v^wW3_;#uamTb;ZHQt8`B$DU~mIVyV_avam^fOTRs z)vOZK7nxv~Zlf41Fxg>0BpZfMM|DnwEF45V@vn3c9g^$eN3^sMSpkgxcX48OHfeEf3!R zpr4Jo#Zht?mV-*pgc9=>j29t&Ey|F;7!~xt=G7TRWC8wz+UbWrXg22w#`I2=8HCDz z*vqaXyAC+0?CMdLzjIUu@%wHJT=3I|V zP18xPDqcBOQ^^ zKu5*Xl#?-A1r%@07KnD7e*xEwgc4SD1p5(%dx6#!&nd@X)x%cOZ{B|}BH2$3(9Frl zY$r*cYx*L&9kcIn%%Owh*0dkAQp-*h*&DM}h#2(mzRo^I3(Ygg&V0(L8wGU7?4Rgf zzq2M1i4btD>9?-Ha0q0X*QvQBYRRlGqUKwn*^KnataL?^TQWmT14af%uIT{@rpdkw zJ#&FDmzi&biSH#ab3pM+jh`ubHSm-&-NHMeG#^HUJ@cZB5Pa_){UIZ*21|;p4|Vb@ zUSwiSk}YOziRnSrXh7_p>2%Z(g&@j5Kym$fYy(USTkx+VXW^D*9Z)5uxVZ0MfV0e0 z5M4a^Gex>k*X(a1lD`tg@O!!pO290xK^FOMm^)B9Kc{}0(-`Dr%A=Gf-77q6vIgTF z?@w47%>VQ=fV1PeupaaG#@nxIm)$Nr)fM;(0xZtofQ&V9yAYylu$2^W#;e3yUt+mR zEL4fXDlx;C_&_DzQi)q2Vb0Kj7*%2`Nmgiv_{sWdvfe6D4H76q`{6#>m(XN7~NpiTy6*x--=G87jGY);^&4fh3b@TW!xgwkic(E&pQP0`z$x|fF>B}t1$1{ zjQfMau{4?UGE}9Sw-6#CULggX8zfE8*QL)%F`o)^nYm4vxW7d$a665^gLszt5=ngP zegl;bK{{I8^C3rNLmKBT-7(5Fxf_EmBy1c6vgmm3CEF|25cYyt3D?#styuc+Co?I5wiG zbDU4v^R}f728BSH!Gw_Lqw$Fv@2c@EjYp^faw(7UbCx?zGmY;VVB>W(zD47eHNHmU zsTyCX@dIMK@%wd+8;wuY_ru4{+h-+YJ9B5TWWl;#v5t8 zkH)KOysO63G#=4-ipHBU9{Z~1M2vmY*8-S}o*oFYe>whWhC5o8Nu@mcyRvB!7jA+e zelF^%sTt>-P0j+`uc$ek8fP5?(wW14c@~=8c(P|cpzkO-{9-9A&i4p9IV_HIW|M;) zkn&?vxp&686nuM*Ea94&ijUyC0q`L^KyiC~sId=yz8?Hg!JTsa#T>qgc@~%^&@3%D{tlZ}4QuqxIE|MVbB*uca9xE2 z#U+mK-!P88ikL>?U}8T_D0uZfUCP80#uX(|u2}^uPAG+MK-YM5b{KNL<{x7h-iFa(e8QPVbn***zV`JwZ>j^AMAe1*Vu))eDu1Uv`=TCuf z{;pq@6uHQNWj_TGj{Fv!R1n|)u#Gp=_zsO%mEsneTbKjn%4+;tjUSW7FEE#Be7DAH zX?(N9i_BRXU#;;|G(KPB`*pURrtuvbe@o(p<`yYWfmy9|t{>UvspczE5K1$RRc4CF zZZyNVNE_$pL>}jVBrlw=)OZbzZ+wVD2m7}gU#aop8lS82 zz2Xw$dm%{AUYVryjY==CdRJ<^xW?y79N&i&@MC?BIP&9&&m~EU`x8R!#Z@Zwv=zes zsqMH7jejC?JI%d_3!2YWfzB#$n#Nme{K$h=!KH|^)DLO~H8p;R#w$o1_g`wfq{gq* z_}}VjUZnAD8b4R#KWh9mjW5;s5gmSCNW9QIDCL3wp!5l#OB47PA*>_^jZ)dP6j|V3 zWOGe_)lmm@7%pkJ3E<_gA=Y1DNP0XKeD)~!uZVyHeQmsv#*N0SYka-N(=;BD{4jrN zyqU)Lh}((#PY`EYPSkYkm7b<@%Qc>&@obG(@5Ik2wZ&1W&io*=-r^d4spJTt7Xy6H z3=VMrDi0ap4_+;3F$1B4HBK{Au(+~yPibX&U4_?1EJ*a%qK-IdO2MZf$d`&mW)MO| zS3f2t^zHzA>jM@U=P)%|X|2XfYy4`dJ?`&^Ic?P$_X#hkgJO2+Xl`pwZ9DXfepN6m zaolx6cUZ7k#q;(`Q{%qheN$=D+N7Ad@P}Z?nZ=E;m+Yz!6IGrPP`R8VD;9dhsx0lR z%=T3Fj;lP<)~f6bmF(*YR@$_d_)haU)-25WQjI@dB=TIe+^wuRS5YL_oS`D^lwM5Y zh35X7JX?-^(e}{?OIB|eYs+0v-ffYEHZeIZZ6@ELT&!OyXvlw$p`%=OAp4oZDKzJu zRM#-oHA;1HeMAk9YJBN2o5#CKKitBWzLVv%Vq?L||DCO|nk|VZ_xDj8S>PDnGD70{ zAc_r{EK<3q5%AOiCD$bHNsZvYAqkTnJ>u7FLwj4eOSDi?6B5%TD`W3bvOR30JpxYh@t3*sCwu>vc)10UD45hD9dR433oMoQ`*j@}5zX!JK z7);l6FH1VSuWf&_ir+4MhWCe>;+vDEsH-V1(Xx#^WFdGr%Ha0EO^kazFz}>m*GkcG ze*t_wBD%h+Ev;4SdAV)Oxys+$&NlLON}puuY?^go<$psZI}Tc0{d0Z19U5^!;jFPg zpeEAhcGB!`kE_X|8vF!sr+G&6+T7fhf&MGu`qoL+9+A=&n39^}!IP#~sVUZqU%1m; zAXSiYR)qOZ4};?V2QC&+hU>IUlT?1A(is_Kr>Tm_=n4YEmx}Q|@S5gby|1LAfPE#?i=`T#xY=CynY^S`VA{#)@ z-y!qB&O+t``>di>RrE0tEi{|koy_!Ksrk3I%2~4^)c>jIAEWy3Q~mRs+M=AL`ky?h z{$Hd-)_+AwssHS_{@SYl6xH8d_0JNIvCvdKss6`R|7b}e`sZ*VXv?3o-?q;OAh9Wr zU1rOFOI$jW(lSqe8aY{GmD9{BA-T+xy`i6auZ0r!!&|Cc7P z+eA$y3)~mzXoY2Yuw*00n-j}&PzqIGirGS$<}A?{C_lcZ+ROS=JJdz23Km_G$261G zpo_nBmzA3@aqJgLra_mYO`70G{e#iSlqvtCnt%OUT8K57gVC4&y7W&Ds4T|^^p~;C zlO|V1U_XJkMGQ*1({q^qq_@*Ubq|QIjqg8SY8&Pp&GBYtBR@$Ud~Lkpy(Z!h5p2&& z8~ua|vmn3H3&kE!_4ajl_*Wv2RTp+4n5@%*Yosn_hQ4g~iJEDYMDMVjXfJRO@sX>vsDY^mY0I{BN}0QilapS}owAo14} z>d}8Y&6s_ba3Atz@#i^mlP3@jcz1b{TaKo*X*g zsEauYJ6eo?De*${sO)gzJR#)rS4-C~Gn=uxlOt==yLo%1H0-2hT=vN-u8I^f*E|Y6 z)Hf9z{+a>5H*Xy;Y)c}!WjkEN=yj9qh&0r~UZ#n6>t0taE#x5N$ac9!SDDiqGm~6% zisiE;S1>=ZCwDvfd5sfX2QAR%%z=L??OjRr@5j1o1j}--5Y-`L7+&gc}z!SLsH~r zW-kscsJTNq6{KKz|E=+o636dHH2ycdI?7+9@ogGESK~iQyuh5M@ul0U2 z+Dy@uTQxqOlAzz*&35cKjbE+tp&D|4)iF2P0KN}{BrMZ0`jKcs?AH8lE+H4hx{?g*XNl*U4Yo(- zZ-HCNL)TGyre2~WvQ)%*GI^3BgBy{rpJCmBIW5|`WFzeHo%Uv66MrJQ+>Aw2un)74oOOz50Y^|BGDASXvYzw=PSHGC__{Ae zh`C*)d2FLOPI&X1=H{_P1>8Iexa{)sm?XXXxToT*S;8tb)0A}|Sj6sI z8ox#2I8UwdYnfC^{5UBH)iI6L_oyel&^;K4kxcs{)xLMb-AeogLR!ZC7^jbqw}w}L zoC}`$ULjvcer@nW9V!l8`MPJIN7*02iQhG=9&3gBZ^YB(t)*fD@KNLkD>ULSMw?;W zr{ph);Mx(I0P$mQf=``4dSAJ!hdOp$kP2!?v-=`uQgQkl%p^RKc|~)O>$40=hNVn5 zIB54ZELUwbQlzAeNdNPCd;ut<*pj?YdzVbfYISS-SbC{zE=_55ORFxeI=7Eq_&~EJ zDP1D52Bksl#HN4hk5s;I{ETKlhAr+$bax~({hkRlR9kt8do|vFS=GEFzRoVx3)}nI zhic*dbA9|`5C*DcB+5_xZP)?YCZTn%c^(-(K+OS_-!NZ@(wTY6JvS25*B`O)6efF5 z8CA%b2vMYbnT$+j;F_Rtl&S#wK}tKD!dtBH019^(hJ1(`qoZgpf6i)7m5-g^;yct5 zznMb)a^%y=rU#dgn1NFx&DUq(+f`fJM~~sB-b3))Zu13vLHpsts!+_nEDqg5k&Da1 zr-O`+Yzd_)W=B1r*B|99+%CL6!dvO_zLMWAgT0w-yYAyJbIoK=BD@kDR1nN;F!+N+ zlPS!+c2R(6Grr|mrWHQV$e-{+Xp0JQkiK|1`yzPsYdBZ39BGlKma>nfio0(|9Yd(& zovrR@b!V&Yt?tUpfziP$n!HOe;Q71`&vMm9KzmBwmq%TAWf3`bPy~+t5i%gsn{%i{ zci)NEKV>g#l9D$B+V1o4Ncn>;t-Q=Hndzs-P#O+5g3Tva!K*Sgz4t1mPMua!Xc@p`&)UA!Lp9m)Q#Lsgw? zx_I4A#wKMDuNy!hUUQV@;&m~FrwJngueV8_N$@&@EB52@x?(9{Qc^1$3qK6S#Ouw_ z?cnuJkbS&f7UvPKZ7r{l;Po7j=i{{@*$!S0)K<;mbHGW!>n35w@p{Eo$?^Jo)8p~_ z9oLUZ@!AD-jN`Qu946v)Fw85T&*S+ocrAt^5U*=wE=Z5Q>f^P06X0(Jyf+`Og1=jl zz{lU^kRkrMf#~9IB(=ry*92OF_YftCmEq#4A{k|rK|GyG zRlrl>1p2L#+;NKBg@C)8;4UEyh8`n_r1%l$M zG7P&}E3-#><_m%=I(hKw8bxCGv;c6e2`$$QmuTyn7o&8t++8Fd zTqIf&`voeV9U!k))*g(%jBxE0GT`HT! z6vIj*6*9%G%yRI>iTglQw657uDhAM>R!lW2S^!Ze+NE` z>j3*Z@MEYgs@j@WEr+V&pp5uqndysS=-F8MICxtk(|=DS8ahJXD-Z&*unS3`DV z`ahObtOYB2%(Md)g87zO22^vIkj~p-NtHo@^K7a!d35U~`=Rg0OG~Dh?=F-q##0QK zPZ2&ESdhUQm_Hkc?&lyuyWm0MXOhv^*p}O@Sdf064|@AdZo;F7(bsc%HTtX1x0G-3-` z%GUM)lENZkt6G;;-BweoI-Ocj)rwYwTh-!L%OXg)Rn5Oh+WaM$JzF!b4o|B&m-PU8 z+}h75Vu^8oh}dqlr>ufer3SY&MVbDBl|%E}f>%K8%#AD*O4D>uCRLua+W|+UzY!$GCu8sjo7lYQ27O9-+eu4DD zuzWkEeRrS~1h7?!UZ1dz_EQP8y3djDi4tgaN0Kl>2)@-FK-yTLh5I7R)*PZDYmhCH z-A0jnL2Dn)16;+TvX}Ori}@7mXIh_jqYA2X>*WSa0_~dTX5c4r=qHYo2eA+}AJ&j! zSC9;HO=ZadKa+y?Q$WM8fX#wjQK79*4>0!qEDRoH#`;(o`suw`_*e4mezy#V9ASsQ z1sN3pXEGAWfcgX+l)F7%Y?Za^-+T;a&v3Ga6a$RSi?Z|&{xo?5g_UH_t5 z@%cCBd<%|2*cu{8vheig-^0Q6ulRF2ucJQ)Sad(XG+=?*_d*6Z`<__^CexBpo<)Wu~8!DN7KP$6SxRVZ$GXJb@ESKLl0S4>|xNIS9m@(4F`{|6ne= zdBJGt9t1(@p%hbsdNLb)HO5ZwvC!TdX+~rcSjS+r;Oo$@2r$)3KJjN(Rp*#2l$^sO zD3%k-P$q%{;=z7ilJSy+2thA5ut{pf<*LPl=XyzcySZ$%g_%n60!sfv5SXs8T= z(37eZGZlJ(FVywJ->_bi#Q27@{vO)UHx1PI0D0htG^OcN_JL1o?x z$Xsh>3fhaFi7GQ9AXCH2OtmuasmvV#nPXL@JiV>V43%jXklAQuF0eA^&9P;!5RjQ= zWpc5Vh{TA4%HwmhQ)GPSJC zcNljlPl3wx2*?z-GMQH9m#?j!D+4l{&y)6PYh|{mOyz*gTq{$;%4}1azfW=N{)&}Z z&`!!TRLip_ATz+q46`y1sm#X#nH#K3Q!8_~%8U)j)Uz`CB9hnRTAp43nNzIHbSu+T z^|TZjc+!|s3(VGYWk7U-j8Jj`+^UkG|ACxPGlcjD=!d;vG;|sH(NI%9azd9X!@LSr zc1-M;jWMx4=4p*UB3x9#tp4cV4N(oO#1doY)YGgMVhrInokCJkdf-4{K1xW>zkY2WM*} zX{<>QyjX)dp#~BfaTSR5;{4hgG$WxMJ_O3rZx$M6NeOM3V+7y5WX95;#WD*5y&yn$ zuoN zT1zzMn7USUQb2SmL?P3`64}AgaD?fi;pTkggj(Ps&G@>AhRS=QUNe5rZSkDYYCNfHdU9nP#?niW0Uiaw^I z*ICgL0nzQ1r6pE#DHjX(QPFBvG#k{o*11-6ln|wD4-}Kk9|?%PXvMCy8ZS|etE_0P zfM_3xBG>P+*7G6ytt^XxKkv9}CN7tzowo~YNhU98;Acxc<+s7cVa?KPMax=upU zwr%75)*3Xqm82C6*MqU}D__{QJ=>OfEvWHU_`-_5X+=k>=5qnJZPMv&f*k z#MbXWOIo}dWc(IChmlx%eXcH};gU?A6FLy^e=A{3{6Z z57ZYmm=k(lLelWh#`&2VH1}EUl@P~P9t&w5+_OlCoj1D~{jq=`ovlmxf(T7p=?$D|4sjwJIRf&&qVQGIy)YM**4Z ztxN?g^N`9s9gwMQW!8kHJddc%-6G=+`4S?7;|plPMxWZAxXMa!_x!ywxL=tgm;++b zmfD#1@1{Dr>Y0ZPK=NOhEL@q8h(n8oX|6P@XwqtDMH;47t80F=(DZdS$L?4K2wt*b(#iqLS-c+ zCb~?V&%8wYk~AqHx~9c+7|W7UQFOk12lWFoW9Qv?3CkC53IX=rmV+`NRA!`=DPv`7 zsmxc95pRsDOm~q9=QMIEy_k_$gC=;O(jW7Y6Z#YnDb_`jBJ?zcI8Az$Zf)gS;h~jo zp-GVX3JvCjnoCG3eOa8(yhQuzazqsu_y3uON|&=0;>!d~#-EZIYcTX;sq`}tfT+no zpjJR+VpirdEAyDj;2GVjDBgVh4LyZ_R`DG>5HgE-GsI2S>EwSPY@v!2H7&2c$+_uQbxoDB2 zg>G%%CNtI`!lXEj0|B5+?9sh{iL0xG~F`pMp|*9 zwXa!@mOffw&r;1h#lD>4rm=Si@!2rp?VBH#Q%1VWs$2LMPjYuz?>-H!6J3@UZfc)5 z=<^nRKAa?;m6y3IxF63=)(_9Ho2;|N@58kjf25jym7p~<{o{=I>&*uA3(YRhPSJu( z_M5cEIQSb&&#RBesHM1h3pQytc7gM9Afo%d+|BKm)~a)tPSA>D-xo)4N!O4_^l${G zC;E?huq3tN%oz5GBcl$K8+0-LUo4|Wxmj&e#$JQ>K0HpAd1fSfP3qSrad30g(#p5X zM)MMWLTO8W)d=nyOTA<*?PnTxFCx(r?eHZDNfzZV99brgs%tQ{Gf#~8KmBTid@ zYKZ6%Etd4s`-ro&NMr37=s=$HKBDlb zRNzX{A9x?}D>%XT5m&&8PWC>c#F_Ryz|Dcl;ycat1Mt;nIinN{r_MuHU9JQ+;^D7As4E2j_+~z76_qxTwMEyHR!nH& z9}%X1wf7M!wucrWvKVCl9Kg@uE!e`eIibg}Qs5tgkH&-jHE1?T+u++Pp_@R$$8{pH z5nCu84RsVkzKoLyel8rz%)ndLF8Dn{E{0j8*j}@`Kguv_S#_3!egl6P7iqpMqm73aP zDm%ae9$V5$F$K&XZOhT~gJsw=DnARuKcF&?Jm-MQY+;8#mTdUSH5=OG{n(qrXY~wOvxLD5#hW)wdd#13jTSgLuIUe>IR|<%d5rn_s<*e>nDcWId6Okvi8qA zMOFh*!;4S>!De(9n(+R)p!F4+bKdDzQ2p~x9hB>yce(tm-swUzswji!ozA8z zyeciFH21tyaSHD~#sVdrcY0liHPF-bU|5b z-z=!CeJjTbCOz-;@^}|iw_*~dUF&$Aecq3!XWtUe8|!>`FG`{F-IP-;o*n?no$vOF zd+g446CX;P?>3h}0b#~4rE&tU*5-7B+r@eDhWH>Ui1g%yQ9}gxt;g#Q?Z=&@W2|< z!VnK<^0TBk?BLFKMKq5|-@iYNYQ^Wfw#6+D8eMOn?eO&QaNPTMneTqWn&0z(N?AN? z1j)t2R`H%)JY@Av#KY=hf`|MS77rKy9>>FJv(Rl-l|Vcc%>?0eB@hpLNjS2VNqjtP zCCvyeya{3AVS|cz{trc#ftG-Wo`;Xe!+e;)ARc~s1$d}ri#=L0!1pmF1NDDE^YL(( zGKhzJEW_gAS}l_2|B&b4p|-HYSBm}s9!>`*=>JqX0Uk<}J{}JRFmlQ9kb!E&@z508 zJ+u#R++?3$;CVtkU=w!?%HYp8<3bh><3M!ho3&gA;CxPX%yV#qM%|w{-z(4jq zbI?oW4hH6%gP((T_yB3ne6tf&f4=!ux$bPjh-%r_&rRylsYdHp3o=tq3wL}r(83n->BtO4E5eA57Af4(^-&Li?G zS)QG5b`@$mf4({PnZPLvmO+m9EcYbByTD19Z>9<}KHp?w|H!j1TO9lHIX~!`a9;au z+Qp>v&4s9A98Wus9uqw6xYgpR2u}}B$>*DyD23XW%S%{1%>~J|FC*cI2G4sn>YZp` z9!AD!ugqn(iJvPhi#pi#)yJQ*Kb1iH@-_(%DS@s00tt5r!M86XNs9 z_T_$xTnJi%eJRd{PMB}H)9?n)dp-UFz%d)2b3y@XN(Q-R{eD|)p7%NnG~d1~PzLQw z3Cpndy*c?g`KeL0M+H4hK&eDiMTc>D4k?PAjT zrXs2p$HThA77zb)vv??bdmInP%{QH|P!c~QlU|&`UF^PSt4l|v^zBI?cHvxCJ&FJ-VR>fyyF-(7nHcxv|v`(J1do|=N{2D# zPrQtse$a(@{`-9OK1!kU)wm-TPg6j0=c~1_^}+dSM32PzYW{vP{C4Lq*W7qXnm=D1 znS%aop#;uX1tc_30$X`23FivIpRd-EmMXOHHwbgSI@pL>?KgdpYz{@XgO)H~-OPqg zn6IYMa0lkAZ!-aoQnuIwC4*e^nq*-8;rl@I=d0n$;C$7|GVFYHpB72|;dJsGf4Hr% z!xxGEzC^)*{YJ zGruX1t%h_HJRW}h^R=+T&w|9Q#My|pkNyQm-u^x)mcAXWZmREQ6CU>W??%8tMxq<# zJw@|f@;f2uoy)f@vGfhFAm8037*&khxYE{+4GY%Ns14 zdi9h?9|q})kr)4YkSRkpE<6G2j}L{l9D=ehx93?@13PvNwJssike*i;uZTv=xqK0u zbA*b6KL~ms=1_kS#JB0QkOXzQm~}d|SL#&ij5-``Ot^-AiuBX7U#- zv2Y$}<{l;R=Szl!o0X6T!X^@02|;S|9pjfE&R6oW@KQuEt)-w8rV6DnY_aFa{Klgg zrj*heS=#GNy)S0v*uan*M_R7Z`dixLqX0%)_9Hp9{uk@l|8!o?8g?C=tz z+N}IUHBs|UgELaH$m;|1s{6VT`};AT$og!rp2Pya{*opv+H8L;6S1oIm9tIPJg!*2k<|^cXp+PI#+7y>u@O>y4CmGoLS%^EJn$uKO82m_fqv|Osm*5}YC^d>? zH%73DM&WFS`av)Dwfp12mqgJ}cM@_!_u#?51(oqXvw|HS&B<(oymw=FyJWO&n(4J2 z#8IIuAz6$j1{biKnBOWmT+e)=4aXI5U{!wLJtvVSuZ<~IbQ><1E zS%kRzH*0Q7oUh8-YShQh96Pq)#xsB=yS{4w9;TJeO5l8T6$z`9K%>=|gs+6)&sQ}_ zn=G_&6@)ooy{;l^mrkX~)1W2HSCjINpRbO=f(GZSbDu`lZY_}3U;3^sb~DMq&R4TQ z^XIE-%IJa8zH1qFzB)yVr1MpbJZHYzc>~)a{J7{3%vYrCFHAmPU4scJalX2k z6GGDU)y&cEd^HH~4T+G49==o(jU$Pfp%b>(p-OdErsU`Bf%fOUsNaYhZk~SAMX!u7zqef_|x-;pM+w9zbAA% z{_sN})6ih-rkHEvJR<*A%d`G)J&))6!!5{m{NYqjB3uug1b;YxJF|`Z!+mSU@w5eb zi;2W2+V_velL5{9f@d!6Y*K&tUewX?fBvv|;>YlatC#Wg@RV$QwGL(Q@ig==i>Hks zx_DYl`y9v9qg@j5^l83>r{&y!E7}&oQ{LO`f1x>eS_i6+r&Y>z@idpozEFmXr}xQt zLm9-=>r@3ijZvD5r;!wXSQrU-IvYJgAIrYrblyMpr?osDPtg%T$kJUNo*F_i@l+nV z9Xy=}vX7_zzxzDmsg&heJZvR=w?@zjNk>y;tlYM3_c!CyHu`^#S=d; zcmh1}fW{G?V1-F+$<;?@`oWHHYwZ0=tN&=6lGhyCg7?wP2HDy(CVwRU; zR!OW?8vM;ewRZ_S90G^1=_pa(SK2!sh`CZ}GoTJiwvtxICfkHC7m8=w==X@yu9TK2 z?!B}}79vsak_VieGIwrC!7UH1p$n1=VSt0@FAnkDO)P!gFqFN#tMAjTC&ig{5O{t~XU<=G|NAm!;2t_69{60WPT!wn=Sx>NoNt_3-n?Q7yJ z8NP=i$1kdRi+?t7aprsw%hJU4+jg4U=D+iY)>@}WQ77IqdIcSK9N(M7Lw`HXFF!B` zS#&)MlKGbLSm-Al+l7<9(L2Z+4Sj>4T_nswXh9?9Je^I%g+uF_bt19BX^~jV>XFPQ zk<3mw6T|zb`GE@@iz$UJ;o<;G7aWK&bv7W`sL%-LDb~LEzKqZ0!p_DrL+mv5@brJI ze@OR3Gq#`V*w;bZB;UL!_CdKqn5575^vSOzd*h=@lJg^l$l0I2=jK^^dk93=-WC_% z-+!O?d51)M``7P|y-meVp1JB*_Qc~gTUvjx?rWgc7n);lD}n0U+tZcn+S@~~BH7=+ zP*uYHUu0}j2JP(z5IAshl;+yo#T1?C}j=epwNi~Ph0Vl!UZW3nP-X6wl5^qRs z(IG*r@OwTRFnC|xcd&fP?QIv-F+P7++G_3XX0^A4C$_h89;r6p=K1#@?zDKS7k{6Z zN;CQyjeXo7yyyBvJiYUqgQx6|(0v6P19;l-GW%a>4xVyA_3<=Mxh|fjFxh*`aOdxr z$;ea&@f4*h;AxQ3Ts#e+aCc!O;OSKKNF`8=If|G!!Oku|HRNr|Y=;G-`EWZ=+ zG@Q0HsXrJ(9piY)$+dW@uXt+xFL*l1`QY~Jk>!8seDEH+vnM(qe8J{p_I$7`Cw}_n z7%VF0O+7Ca9s$JL`#y(mvv|K8B(rgz7_%e`v#VnItE4zE4S?a%DwQDtVMqOH)y@ zyitNcfUf<&o}a(yCsgsjG(Of~Ti}G_qr@g1ALFqmFf-xOxZ~reSN!qO?Kj&v8$oi% z$0SZhf$`C?P2%`?7MY-trpiWJu5ri5x6dJ4cYG`$!5tr;k&rMxCXuG&;|+w9jE^Wq zl8lcUKOH|lo`e+-j*kibF+SF9lw!A*41(k1GSHHaj|(g#>G(LEyyM5mk!Pg>;Lx!a zU-fq zZb>ha^rR)#u%wA3^|ho6Ea?-Hx>`~LOPWhk8%w&(l5$9DY)RKYCN1$JN!2W=t0nzL z(rK1-woSO3q=VS;#}cLdi}G#(x2@%b4uLKPB^t^{5LZ`MN9*>#ydr+4mPa1mZR{l@ zCsd%KUx)TEWa@K5jfH9s6>SjMJw$)<7Y*eiD0f)I(tABAR%rt$l2K0RXAS0rew2{> z2=Mzjf3+9H3l1c4UT|cuv*xvjZeI_;Hlr_kUOWJn?^{ z!c+g(r ziJTuT;1{a@yWwB_U*0GGDlDy!r*k%1JdFp@#ZynrJr17EY>|kkn~*CTRPN{Q!&&<6 zRRKIj$Fl#0=HO`%s6L(^Qm%`qZcNr$87`jMka2}Fh^OXM1w7SOnv16z6fP@_1U$_V zVv_ZF8uv|($5Y+=fu~+Scz9Yp#^UKSd^f|v(>#!UJiQX<5lZT5Iw2qn?NR6Hjly=eYMZ z@;>-|ltR}lE7z%g0?GBq%F9~BU9T*>BGDf^_B}Bdu7aI94%uqcFe$)3H3IF*XV{-g z=m^5aBpm(3O0bn{kno2P{5{U{q^%cPxD3Md$5yBay?G=%_%uXjf|l?;_=RuKzX|J= z-7uj+f9$m007qL}>@T2+#qJ{+*!RI7fad#SH!7nCvVGAqtUq>{7HO<4(i7x4{#Yep zhaVLEf%VGKkEPts?>q8iaXhewo_%Q|TMNPUN;Oo+!$WYr^8S4;9(u2_cxZ?TitCoP zczSq9T(6vD{qVAArfgkKINKKk-cP$*z(jk;jO>LUck}{YUq#yh zf+eAe#f~_?zuiC5!K=Hz{@pT?t{+yB=ipV>*I$8bt=D7)q6w}acH=UF!DSXEYH;_Zx>PPO zuRsQqE@Z}}*2VaRj9sgii3$JO6GK$JzJiUc{$4SVrKkn*E;3_rQ)n{~GMPnQC7L z=HFAF0N?It!ylO0~FKBHim9z{!ItjpMTGa^Eflq zwmduk9$KpD{Q0*m+0OjC-jfI)8tx%D+e7e|!gS`}XdJ&=RET(4@*`U|IR8$E9rf&O zDt53e=57ao!>D82pDSEx!PH3KZ?`+i`|S@=1|Lt?tEsl(AdY<2iMrq;Na;g zrwlUsDuZ~spQ?bTTb1VG z>1GPI5Jm!?@`RWKPc3PkkH^z(cL7f?t?=-4>f(SWhB61srP;eLVFQW*kpb$0Wzoqic`H(_OUVN&UI)-CaC=h)I`5X{fFb zUi_E!!Aa)tixwfv|I+-uh8FHb^LL3HZ~u>u{LE$k{4M@w7qpW4o84Afymtf1oxdk> zvIy?~U6SZ;K8sAypHp=s&7Hr$9foY(`FjBg?)?232?_J}B+_*Legk37CkgX+lp_B8 z9ly`J#vVy8~ggXG>qlYc>P`{(_PN{ z=0ty!>)8)chPeIvM(rPn0sALTx<8*@b8+H)`V?}F+rJok>AU$s`!@u%FNNmXKTzZL zPq_j6$7G|G5wL$`^i_t~KdPerQ(D0OQMiRL678Q5li5EQ^knw08|~jx-~J6&`!_FW z|3Hr0zc^3qpXI6j^LTOlN49JKJc;lWa1!mGFdh3hDvqZuz({eyNr8D(R_($0^ez~2 z4^P4Qbo*^Co<3Y+@zhZ9)Yie%aqC&G4^RdlPluLUJk15s#naW|`}=s>cTpmqEKlg z-u)#Dlz^w#MLG$d_Rv}$KcAl36?kgB*u&Gb$1I*+fNsY>dlO_IPmjfU#M2ndvv}&} z@q9czOtyokW}Za28#oDgsv^udp1yo4Ii4=S@;=c&E5`~ZoljrB)y31Tm;`B`-qHP$ zxhLKq;eoHpBe6)qM3BanNoM+rdYFdnd9k;?#(A+*q0K)pM)^i6zXjGG@~_9`AEx|< zg$eTORepw*zdtVDg7P1^@^YSHkZUi`fedpUnqV(`Qd`_#JQG@j>yMkD*T;7s&eCts z3E(?A5VTC8Irts~s*mr7lV^jJNWME zNrZ=jlYs9lgc-;8uoKwJYh*hhXfH2@(NB)=nVnsH51McBy+nVn_KWj-wPf~kjB77f zF0ptTmtZf;b2f_OX$d~G5yVq5 zJ=+ty9Xve*vX7^0<2>T&R?D+^s^{^1JhdR(!BeUy5v~VL0-o|`GTS(wGEZPH_sLQ| zh^JgG29ny#dr`-@KUe!Ji>H}A?dHg8JiYzHWOyn>8T|Qo=pu`!Lm;~I?_%-Y{rUIN z3ls75>6Z?kmUGvv=!*cJ^7^s=h34RC9jHE@Rw>uT(_AL|LK!Ze-Y4S?WzasoPF29u z7^S&*8cE@Yg^_@#v(Y1wSQ0$-hrvyPr)WpuY3W=KPYt1%cq$Lw4xY{f*~ioV&wU>8 zRLb%!o;G?sA5Xg<4&o`>lL&7FCjn1y2s4hS!^4x$zwgSbJ&330U}TfysUqqa$J4qw z7Ed`nES|RD`EPj2;b|)G{9wHW7EdeV=c!V$7h?v{`p50l1s5dZ>2Boe+o!?YTbuq_ z08g(!#QqnWgQqc|`gnRmxh|d_V6tAyaPicIjO&#_Jhh`L;Hjz7Ts$?Va8+R>;Aw>r zli;a33~mxUHNOF^F%XMbK~H$|gBDMVKlL#q=l?W98cfi+)}dhsGYEUPW0!lf{{&*r)3>nJdK%c@l@|Fi>GVw{5L!m zq6|KsHh!h{2}IXE)qwl&;OU3ziFi5#x%zmjgPlfm7v3y5@8jF`W&aD!!BbOEeLOW# zu8XI0n5=>_Ts(!yI6R$s*!k|@0~Sv^mFD7UD|lwLFcR=IL{uli(;67uBzVfZ9(bxb z%fr*NP)z$Y0J>ZF$KT|~(cQV91n{?_4`|;A z&B5PnP<{M;qFfh$JCF z!QcJufWP-X_wZL1iiy9y9|!Pvw6}x5pW{5@Z>Qy1{LS@vKK@pd?cnbnZ@6OcUt^CjpqsQCm+45lx-pO_AmjW z+{b*6Ob+Sio-44ydez(wtvJbbGlT#nytHWf{@E}k@};{DAm)Uc;Q#!?DX&IeFdAx( zASjn9#hh*Rtke@>vGnEd`FfUtm=l_c|Er$KUN9Q^6hY{jrWEu2r&6A)5x3>p64#Rs zVovA+6-BD*UN9P}iy$bqlwzV*&s>}*gPxqwC*HxboX`|6$XdqIbD2RjG!axh-r*xB z^p+>12Wc;dy7&t}8LuBAD}TIBnPnS$3W)A_-3uq#8L#i2lQ>>~o8gSt1K3G37f%U{ z*R$^ht%}f`@mdO0f4m<3h$({a`*!t0vTe$6$LmjIe4`AG*A*aeyv|mdJ6=Dd@LR%2 z7_aT5L`lZ$M3~7W<8@9OjMu-Xd*ih`6mz^@4c*Rs(E((CzNi)FalAIQJUd=Xdpv)< zRwdgRuLj%OqB&d|oP_cEjWFZmb?V^ctZF+N|ELS?z1^o`zU zwhhk{jaTk>&qf)1JazlR;%P33E}kZFvU2Qyf_I?o_Uer|X!kwK7~hg~_O|4C1LSRRK?x zl;+~8JcWO9rM)BL+Eo+d%JW1l_&*|$&6#CgQi ztCnZ+^nl0n@$@9w4xS>OMEC)467W=Cm~lMS&q$7^CbHEK^e3ueMoEsR_glJn>OIBc z>HAwOo_67R0z5@x6<17ej7ARc9VpXd0Uk1!$I=_EJckqJcBSN{L9NV>V^C(_o{d9t z`m^Iebn&;Avqc<#qs~mk-y*zd_3^hJJ6)#Sy8-+iyc4v;lSp&$w-Zz!f4?f%#otOM zTdE8fe>2ILstn@qBdP-aUR9clzZWR{q%acjS651z1b-u7pp)S5^%lV2kCQ$8wSZ#U zvl`It;I9G5KK@RL^N7DnmS^#|>m5z!edKFY3Pch}XcpA!N1C`<8>0UB!R|fHP8&v^M zZI$NY>1ql$6h;D`HV82Zo*KbGC&5#@D}krcA9#4$-Ob`@?b`u7{R*;=r&)0x@swkE z7Ej|no{y(#WIOh3uqP274^9G}ZWm@8Pge{`j;DLD$WO%6jWEi|@$}ObE}mX}-{R?T zKZ~ad{r??Ly-@}qPrIgAJUsxSi>Jo2jPUoPf5#U+f_OR~x%zl&#_hU(Zw2sl+imQB zp*eVJ3#yN&bmh8us>ftCmEq#4A{k|rK|GyGRlrl>o6NU!O&3plyFz%gFcR<-6%9%7 zv;_t?37!r%2c9l{&%@JOP)z$Y61pAx6a(4E(|vIs@ifTtES|3Ocs`!GlkMQCjwcbm z4x9u$l@VqfPks9*$J3dzs}P(Yi(q7vasQzH9N+;bDuX`|v!${3!P6Rg}TU z)A-32Pvb#!@wAoJKW?91JS`DV-%oPzWU$j^s!a&s>C{`<|3Y){RCtSnr$67YNO1AA z5d!8%Ww>}+M#h)QAfDz>74Y<-(p)@EqVTiANWfEbDNzzUWx?Pk!P7@gfv0WnczC)2 ziixMj(Cy$U9b_L*XT^EMQ*Fz$csevbalR`{wu7hjo<#Uim*epCr7+`odgI~bcv>Q> z-XNZ)!^kGbQy6uO#navRU9g~{Ju@<^YBN4Z&zBF(>RIkwTG{acrtRjPgL^mjmQJ+@SvaJoHe+wv zkMM1UZN}bK*s9#Dn+~)Zi+|;2wK~{pEdG_7^~j-CWAU%ttRaV6jU93r!mW<98H;}q zK8oZ=nfw@%A7k<&B**c!6$9S7b4j^sqgh6JcHzpA>L^9Xy)-E26kR?4058=rsQ z`i~{Ph`>Vt0IdI;EO_EN4`HcumTkPsR~kyw%{m6>y#8P{l0Ql4~UW8ZN*@_Q5RE?YG^pPEUSs@T^3`KS25-oVz7Bl?xnitrAbs8-FxgR&=o1Gb znQabW^XMf=X5G0&sH6U93C{XRG-FM)%eRqOn{9K7q3Cn@zxn(huJtk3yhwAP*F*HBzE&j*NQZNJ_bv7Opt1T#;y(<K+M=BXK{N!u2afS>hVS_QFV&g%^t{2E6}K4_=*6s=cqHRP(kaX{-1scx7sQ z6vRSVh_Ub2VYpySKBdvRY1N&fk`^CCIp)|I)l+=1_5f#cG~+$b9JVY4amTTTYwx_VJ5-EVqwu?PCoekywXps9qR} zWh@8ie`KlGmS?Y&dwJpLg&D&+kTP0h7-r)mW)SPL#b&-}ONsWe(~3tjJ1lQ4!=lTN znQeZ#^_EEV=jdXT=1wV1jv06gG8wfrEkEq(Xdmma<%G# zm%r_ZUk|@6%NOa0X3I`!vuw7|9<~|ERJXXaQ1K~jp>4JmjD7rJAHnw8qAi4$>9Phb zw4Nq|Ei?nYb$kmgM+-r$%bvs*T8|b&mAh=qZ1YFFh2FsD8>sB&kkdk<11+=%EtEW2 zFHKfOllj#T;AuB@B>opI(>6s~X3ymRYsi2t8kW=;|2Pqa+4lK-og8L7#NX|m)k zv+cS6Rm+@bTW0fz|JRmzyxf1GWuDV2RxRBti=5;ph4o$nc^hwM7xu5nUoAx>_^CV3h$66ZP z{0i?`bNF5=G)F@n7>$LZ{6%LJj%H>T{0lX;LPcv4uCEE+WrA4fsRNYEF{9hoN{MT3 zB$I4(dF$w+_R$V&;F+3emp#z9KH6c6^#(eu&wK*bIm2Xvf$l5Hs9cnhMvpTJ|2D@w z+T=ooMwaLLVjhB)C_Gf1jnZsjPqbr68~P*KF%@2M{PpSolyiNc`Okfg8(~cmDg347xy zDy!@wHH1wN0tn3io>SeK?je)#{X7rp?$f8LPQ7)us_yBU;SEHOe-?wkBj-*VzH&Z1 zYN-;jnUi!mpFkJpLiCFH1+HHTxt752GJO@&3oywDtx3a=9>IFPKCIj%OKwJTs1ez=ipe zy&zX7$GEi#aXG|j2gRj55~mdIwij$5`_@L|;<&va8y9ZvF|hq%FDRj2X-_8L3b#)1 zRW2^h*$W1O&!u%ip<>TN3hGr%F2Ld3dIrk$pfm&XSr#miR7t~bhsSBd4WHngz zvUpxi<-8pdZ1#d>RGro~!H-9*sB2O@l9Ocg%E85f}Um_zExO6=igqFp-7{zHA)4BL@&#O7=F+YBZhh`_D+0My8)@T+N)b)Bs zIa=U|zy*N!D2iIIk^MvD4yLX7_{s>HiGG5CAwRf^V!bn$uA*$H(%WYmcZ0Ks)e=yf_|ou_H) z1hE!Toeuv!s1xJh?6dSH3@J=dp%kBTkAF1R*w7&}}hMw?%uw_0Umi zkM@FBQ9fvp6TK(`|8?eNI?8R+QTwZ?UA&9x#PiH>QcD*5|3fTm6wRnVx}yG1sZO?c z&y&Hro9cDHNp<_`jzEZ6x?W13j{32n;Q92%<}CJqM}_^{3wmH+*)bT7 zz<)m|RIGMLu_SY`+^dR_VTv`dIrcjYpn5u`SiQ1h0YDOEQy?oG)GE0y;_Ty8*JY=y zSGR!WG?*5Gi3*LfiDIxmG|>6*s>g#4yej?~mGCP|zj=Mzo#Oht>l>cTrCx$FQ_m=q zkHt`1T0MG25>92EQgWfAQhrn^xp=dZv;k9=ggEg#uw&2GnRxO0>wLmjE%||uzSu)f z3eEV^?+Xb-#nUtn+V%K)0{sj+Sy{Tf?V{~d_TB=|Tv0iuOiMSF_dYcLZKN6{R~jfu zKhqKtnx%!L^H@l_SW8J-sf^qzD7#GBCe}BjmhpjPYKK43OTU*Drwh>-&N3Bs741B4 zpGw+7yU*JT*W%2+==B5=l0N*LS=5I<2aPu9%fA|SoX0XN??>;8UHbw)Bm8XGh%dazGfir7Rqq=CZh&FVPCk4x}hHBp7_(CUqO9f8heVA zt&m>)i110i0H`ox=(qQum}k?@t%}MW1#53=z*6Kmx2lH6q3*VS*Qd#q$JIV@S9m=T zB4<(s@%~M4aWfQ6qKMBW;~UA?PUQ%)5r?`9J}eezZpV2g>AbH_q>{8&-B?lCuHdU5-haP@nh4`r0XOPs&CE9Jn7?a&u>ui{-!T)_Q`dPXfw!1>z3JBZ@x zsrbIdGpoP~6tamC(0O?$g3wQ*DXu14SW=<7BOSI4Z?#tKlXHkke zD+V>?XfMWPr~FY`cnK(?Qd?=^0FdclY2kUD=F+-mDy4OPh^8-ZYoPRN&?eslzjV(y!OQ&-YPC8E@= z&UN4d>195ZQJ2TzYKB{zMUuL_?QEXbkaX{f*0yY|uPwW9Yu@e7-u=+T6JYP35`awu zSY5=x&yb&|K(n~g^jTD!eacOg)%jw_q6lPs4hLXSNG&MdG@IvcwD1C2aB4ZW!u5Gg zsY<81GfO>?0>M%TvtSa0G02yk>A%~(ZcYokBG$F%G4|Y?)qXyyw5L8Liid$D@fH4# z6U|3jkflkL_r?B!rF^%q$%RgIsJjeTh;%FXkXnqx44~0=9wsgj4qYQTk!xwKb{v=E z6_J+?%~PDc(3uy(-^;D;VoYAcg|iPvl6uge^}>MW^&c3TWC-Yy(nFgiwftK=mI>V9AX_TgALWYdI#kgd zS=tCVo{*r((>PVp}of zCVglQte>PU3fMOAC=k{8QX7CxT8OS~TV7(VdLF}QQKz;j-bybXk#{E*$Ie}HG_dtp zds1_$O(#oecL3@z^4PAK+FZg>jmxG91@Cs^i#-K)4D&f0ER7&XZ?&$>(1+Wpk!KV!vGPoA%gCN87=$tnHK{Avo}foG5t*XEhx|{21p|$c4ZqwF zLoBTo59MQxLziJlO#XXgk`sz(^F7-$0R)TxRHEqmK=D+7yZE*hWm6H;D&3s=Ra+1 zE^j(=2OpV=y`Y6eeG|42$kMvQuDCWrKEgg78@}4Kamfq?dC32vmY!MaPG_$kA{D6vlq%}iV+@c8sT~;sWVayG!7<;rZ^OB zY@7~@GQ1ab22=XT2{B^x)*ETnx?mTLwW%ZbV8NuZXl?VRMdjV0`Dng%1Rj4nn)g~_-q&5X$;5K1#?w4hlKip9(ynzkZk zci9c%gLRR{$a+^rZfQvh~u~y3DC!OWFdWZKI|M!`{E78 zoOC%2qnJJVCL7Xn?<~%H{6`T0kV>Rc9VG{AYMtwNU$`;Zmiu^N@r#e@VvsV~3v!US z1a)BnI&Ah~_JSt34}Gv<2Lsjz`*bgXFa7Nkzy$GEcTlU}hjKp804 zR@8nDW%w2nMv0t7a+P+8p@^Vp-O?1b9@cR@(a!uQ(pI>&xzwX9J%#Z_clwe(f?T)7 zBZ)95JwB&izL%^pBY=Z5e>h6{GMYekeB9*-Naikh20?u1pN2Qefq2f|;9CK{{))!3 zus!xrhIfu}_9fR4@YG18E@HYuR{8<8(yJ%$?I@!{?JbbpyE>C`F#I#LA040mDmw06 zPI(5@_?6k{qrG4VXxg_#^Ri2eP^4|fsi#Urq%wRn9wl+vh`s10$b-vpe~1Pt0GY2-i)_rk8B9@!C(*HOxMoN`9I1gn!{C1vy%vR-gd zS156N64*35EU}5o8$u(b`Dk?5e&GUVr2=OfG+*lHICX38`iaQrq9@aZ`WH@P*N{Ia zeb8~(^CKb%5gsxqS|h0#z41_*6++#N(a(fzb5>~Sb&q3k*v#3|Tx-USGrMGjBQy*T;U(T)#F~!3ZVL<@YXlMAdb*KsL zg&N5uX3ADW&NjyzT6(gI{28_HW}y<=Wjyoqhb8~R?1;lJ-Fk)34h>f z9A-F%Y`l@If}GC5OLRNvJv+hae0)ecoqM^AFSZ;p$8etK+W=V|)$!9UBPs5SV@%;F z*vK((!{zje221O6L)D(>Dp;ilBhO@#-QN#x&83$5f5tjiFrV!Excy`?%^9&~+Z*dB zaaz|XOq4d?O3>p;G!6hPDii(9B?)h0^hu~i$*1?=d5|NazH7(}&_8?q zs5NxdrjpiTo;1Xz{)UwlsMtY(GDGn-S@{O#HtlVmJAm96>@eU>i^#i4n=aKn^^LT<19FM)1gwZZMn-i#kms;7kmDT`BGU06J!KAfpYDP~_vufJrJ4 z-T63TSsnF!ha0^y-Ht;CGY-t64tBJ8+A3Pc%h)Br+c6?9QA=}cJ@8+NkrM{;Nku3Y z7@G;Fv_*U`y-~d48yxTUJvJhLqQge-7(EM>Z;$Pj;)IH|Slasufh9YRRzI{f|6#0` za6U=v|LW!5S=tj(f+D+k;AxKIKT?VVS=}sDy3Ny6(dw4(hfwJec{eZ!^$7&{HhkX; zX$peTdpO79y(e0%%|j*Ha+*zJ{!MiHC+{tk_wtEQTF4XbihHlnz0yLuNB^+iJwX=A zfIDX*TPUWbY#Dp&RrMPk=_`K&euZxqA{_C4WSw?5@b`J7D2I z;HfPdpbRkrvlv(U@41KFSXI6J;+4Q4G&+K+Nht<+=EXv+A4w~S5%}elu3L3!^-%`u zRgaV6)_z@A+&`gS|Jx@`ewR2n=8E*RP>?q$Q}U($oP4KEixEW{b-g`_^^Le?JV6Y66dlU@e!W6;#suE^lC@N6N07Pp}7FHmQ)5{71JFDKAk&RKFe%GY*Ac7z`iXXB>oq1~XP zhvGC#btlvzb=xzOWQDrj33V&lE7k30%==l+p4fximzstGJw#`p%{Jtbb6E*(u^w3u z8K-+VR$1{1h7GH|DS;&s`FJA@`3qdY6|uI6dPU2aNYXEY*+r{&?%|$m z78^3}y9cpoKO#5~q18XP+ZS7d>rS=ffGyp6VAT|Rr_`mUu=qd+EP@WmA_x`l{!8$h z_`)@G&-jr`F1i!3Q;FECMC@~ctY*g`9jeokJWO8)Ql0P7vZCh1;hAVW zo{}cI)$C*v{n=M_t>_G?Z`Gx~FOZvzS5mMbbl$CQb@qnjZ=yW+B9NQt>>0?7cWXHg zXJ0%%b@mhY{|1FXDg@c%33`4O?l7aTl>Av!bft%eYId5$|99X^IzoWfZl=J9)PXuCWbAU%%yRbTIPfbVPSKhQgWmwtCKkU z0=-d7k3ZQE;bq;v4tt=@Q0IWy&UXtE@^Q@!UShzFAM|4Iny}w7I`tEsI>LnsF5T#( z-l%= z!aDc`P*=&38YIt^XQ&%;YeO!y3$-u@-QBO>C1=HV>0u|vGR}qC;+$Bzr&U&)6F7_o zxsFqR>DeH9Qi`#xPo*tu`uTL9_|s9WS51{Tl^twBW zo~Rox_ySdn2V`hrJWi4DV7WQAC0gNz(TCECc7C2l3r6DOx;C3^;YqaMg3)225KnMK zy{AxRI?T^wCu$~9)5Lj%4T$mA%X$}ALyUKJNT?Qz4Ue-J9bv(`7^jkGp+t+(+mC$@ zz7b;71&5zfZ}BFIl-fvHQ0-fKwe|vhg&3hT+9|8HPalYD=MrM`t|tIzqh3ATj&;jA zeIN;ebVmFFKJU5!KMOYXsDqR}wW5(I*~stMMF2x>pZ+%x5H%qX8n_R&0lQOhC%~}o zMO@1KaX-#_LI^*8BN#9}k$HRuKZ{YfRlE{0KV&e+svH1}N%T zJpO>I-%Z1%z4jh@g``8#w0xXt4W}qtoh?e?`rLXe+M%TQV~^BVB!(jttu6cj7HnJL z&I+=5v4(GFF@OU#yy^wDMm^A+oCF3o16(Yg!cv809iT~#->m){OH1|mKgDJ zDoTjVxuAEBffLHjP6?zO*So0-?w&WF+R&mllj|tFj5=1#q^?~2-Msz{g;1xpu{oDv znB=k*8Rp&8v~HMRlY952cEXTI(iC`$WW4LI*t=piy$fdZ*?9G10%C7ef`-=_vST#Leq!J_ z8sjPxS9orUGt4$|*3#D{0tdWdk{x$PvU&=v2tM?<5$(Am5l3<15Vw7ANB`k+-C9%v zV%|vV2&@bd93mkWE=(i>AnN^#gk9jW>!qBxI+YbE(I%gWarFciPI@A-|vDq8Zt(XyW28t!-LbVIZ$Q zf4w7h31q>#=tj6&u6Zrj{FnWu1+164MV`{4rr@Uxl;AkMFT^HCzI`7OzfblZkwf9?MJr?dY_O>)eRH5pKb7VP&+)KNDB} z0REu=#yH}gDG&g|8GQbq9o=4BizdU^(cKHx!`MNZ0!Sl$+yaOv4QlpO2;{AW_1}dk zbIwUik5d2=B~r&;l0kqRjVA^5zsB`PtWrX9VQz0_6LtXcP)ZVVW%w+7P2A`)}p`IHB47 zFkPcIwC7-QSUOfqT#;jAM9DH5i(EV)itYj_jb{6xS(3KQ>pgg-s7Jck`E{hNOhw=0 zxi45*YmdR&xJ3>Y7MDGEBLOca`l3%H@QCFb@l$&+3LQHHsz^XeC?3It%R4a!-U_lq z@(1x3lE*k12uVdR;{2zu*eAzNJ!N|P5aZ%3@hW@~0C&rHEx)X+B#w;xw-F>3St! zKSS4qc(m&cM0gzDKqPjIb}U6zHpQO3l7E*J zTuNbiuv+mGzg)SADT z{@8Oc6I>lL2rq8VaQ2b!>u8T)z2qKj*5PR>`>jm^gxUO>S6wWeIQTV_Tan)=-Zk;G zsmC6d))H^_9rwV6V}u7G)l!m9AXfO#j}E@yNWsI@=NbH-Bbve+ZFpM*vxkY$w>{$Q zHZm^xcAugRs%RF9kJs!zMuq%R8KrY?;R0px%O<@KcN@=2X*{tEpq@kaP;#QFOTCQM z9rbMap5Aulg!gi7`%BZ{?Y)f2jJSd3|+A;iK6STQG;_C`M)JZ#5r&4` zsY{M`tauTPjHG^^5=XNx=?nP zGWkNsPIf5CA+(8$yfw;Q2I{DfnfkT@O6Qp)b9u*Xq(45*;YR7F5+`cGl z2-<8sgw?`YDf<`S*qXi((f-pIGX1)iZ$wT1L0v6ezTBW%#04Aj_cyd+IZ(Fw@nPD) zavJ_0SSLO}@#UlvKM>82mn2O~_uLMabec@aL(G-yi#LkzAB8)yt}o`+7_>_C{*5H# z_rrayx}XHssRv`4zT5K{wl^K?_6?5_D;~NMz^}&!Az_LFhs%o>YLVY>N87~gLK3qy znJ#=2V?-y+6p*T;Eqeiep>I{g5QAsR_UQS)57P!p zn(Gdx&1BjLNo&@GX)iHtyrg~AfN9S&?IlUeNMPDiOq(TXBbzbpQKo$;X|wKRT0f?J zBWWdY&*(=trmd8;J$Ezhex_}awAxT1@U>>zeo0GBVcMNcJ1J?yS~Kltrd^RVtaMP> zdQ7X!>)EkO@PQxDYA~&_q#aIW+BrNb##gv!tbVXWHXT+b3!7r!nmzrk#+qpVFE3Ak!{O+J$yZ z>%_D=wQzygfFxG;GVK;gtKWh7nlr7rq-A6n~{~ znM}KgN7nX&$0cnKy^fI{dxB}XlGdm{(+)DNK+?`iecr~j*Cg#Wn&PL&ZeZFxNgI3% z(|%yuSCWQwfcU;OWXR0X`A%=`Y_*HOxr7IImok7_7$cbm$c`4GHnXeE=k(_ zUQ8RuwCgc<1EvR>F>MsnZk9BkwDTcMOOmuXQkGs!OOv$u(pI}Lt*fL>mU_^RY5gQ^ zc|&gFZl*mZY3pN|c01ENlJ*-t;Y^Rck!fB@J8%=zu4CFvrbXx6K(y#9f6y4s1+BuL z`s&ud9`{P4|HK1U`UltNiGe#Th~Sme*alc|Lle7k8(iyjF3ED5URv_S-g6hT6ib%R zEi8v5ONT^enJ-ypT3CLSEK4M=(rM_hOw+xLfBukuyrG{jgE+eHwvRuZ~>mYPz zF0e{{CIik{+yit6Ei8XXmi70rEW0F2sfFb?$?~TRQ7a_NXBL*VlBKisd>=}dS1l~x zNtU6~5vr19oQ35R$udd$#iu08APdVJ$?{evi`!eWWLj9JNtW-N%#tQqnps#TN|s+c zF-sH4a-D_cNy+k;jDGZMkGw zXkmF-vJ9)oV>C~)Ot-L1k}N}LqLm&yRkC<2EKf<6?`4mklq>@cmZ*Ya&kc~jhfXl^ z6w_KA&zI>z9KBRSFG zt|X#{)OcMFgHZW!CaD;pD_V1DU%QA%9dhru7Fj8wvL@J7;iGs zazxoY5`HmO9RgDJRWr2c4S4*jzhy?SDObU^01Rj@+kkBjJ+B4lt$@vka~=nA2)_sp z#qC|(B}sE>@f8cLf&EyY&JYcO)Bgrm;PkM>>Cs+<(`w=$1)O$(i*VYAdWrTpNbM&ZL$7c-AB|fV#2%-2)#oep%S$6~Qc^%6lx*qBHbn0orXEC@4pHES* zflqf~!lwb=y|?Jm0X$R%91UcnL3|cG8pNkA*H8^UiCDvtxDh_nP;Hg?j0A%jpMmsn zSH~v@=MtX}0D34sPvh>@_zX~7Ry&9jQ z`oO18zfgQ?bhqF$0bGR7Xj+id?aR)+!v)#b)?*>~ypLzNgby9e_>3GH#OJ5O*MN_J zZU^z{MvsQi5sPN5QY8r^YBLsxCpQIaf zq3hE~;5Dx-1g~fCIG7ec^U){)cL3Lfbbqv6@k|Kxq(_4I`M5?yzZR4&kT}h&@K5xF z=@aO_q)#*X^HuEEL*t_seH0IDtJJ^sV1QT^{(T9q4gLEZ=TiS7;jlw-?J98%@$WHq z;Q1?}9^j(>>i%nr+oFHx>q$Jz$kBm|{QLAnCj0D#&}Q*pw?P)bwN=6xv`_!wAbvSq zgMnWd|2_h?A@L*swE+);tHfsk7|i(0!L@;p59bn}Ll~4$d>+w9JS6_r1wQ{nw6o&# z=mQpfc7TiYZ6i549iOKUn(%3jP-ej=0_QhHCIpU<*Nf7GnSR zD)CXlV8-V;TpRd|!MVg|6+jQgr>hh-M1R)R0Y0xI+F9}G)Xjp=VsH^YpOT}~@#%iR zgiiy6G7CNj@Ys^{hhQ?}vtUpVpSoN_HTWd(awrb z4aI`b1aJ{PqfxJckDYr5SvdY7lv(h39~;91pLrNE3qB(U2J!i6?=|2fpxZ%wx}n-C z@ks)M8J|YDHt?y7bBWJzfF6oZ0O(QQto~<2ZQ#@P!BBh-cCp|y09=I61LVk22l?ld zcnh&2|Na`G%7V}29~qx%veBUbaSaIK^Eua0jsC2IZU^ycj%usKr#2YO_*}q-?FK%_ zaW3)c42K(v&k>+^H9krV@M*}=-yFYIW?S${0~g`bf*iSy&!*o^_{>BovfwievOs_S zEgKEulhi+mkB@7p2A@x$+d+J;L$y`n5ljRx_l-7kpG7_Olje2Spk zL41y`uLhs>V1R)5*e9(QXwge>ZQ%1c&LuvPP|8qzYLUd0SAL5OuVRkN{IC{VP2lt+ zqLz-6z8>&==L(!?J>XQd#OV+@EQmqt0aJJBIMI4QH-sb$PK_XwIj{8h3F4E(B@KKk zT@N@SMnJbEKJx}~(n#+>>3OOay%hV?SE)~Pz+lEp#kGOgB%DjUe!(F8-|*TT1-#xt z6tm*ht&;_>VsMdOeM1gR$E*KN6J9qX$XW36ms;^!(mRM(6E0Z|UTMf&!{K%H`qT4h zj^Ma@{b?xfKw`I{XgzdJT7SyIIj=vxjll`U?F*nveVugm+7q;8b|i577owYvn?8SO z;3V8C<}XFyBHSjDV?$jue`&fy$BpJM2NAj~xP7&j?Xk6NJl9K&>&r%#`OC;&K|Fuj zPBj{MRx*E~^(XuR z&@~jltsO1+Dc~af+M|90zkPTskmDiG{}9?N_&u|R@v9*l5076`&mew2uCW^YK7oxG z_-WDCp_wY})xX+muRC#V*y~R?*Zn^ndMIu;Q4hlUxA+L)b_`Kb*E`+6y>-9EULD{f z+#)GpVD!kpeT;XPD%LwkA>>(bONUHm|5m$45T7wz(!eK-e=CA5NPH^uZ@aLce3f`D z0RsfBhzARBZQwN*=Mt|o7=%!~PU3EOyiNt0;rkSbl2*J%Wmxdq4=%#%7jlF;UgLi? z;nfZy(1KTOv}(p{=Yv7KGPqQN!EXe(2){w(2zC4dTTJ+^M6j^n_i8cY zce89fJbo^B5Wmm4#%l0e2O9~C-z{jha{MB2$Bf@!D}r`=80Qkd_86Q{{2rm6plId# zmv#yGMIoA6@%uX6f?p!I2)|oUzk%P1%_jV&AT(O=>j{}?zD)9wI2xLH->Ah z2EQWMN?81M{}2wp65KK4_m$2``Zpiv62E^iIHCC6CA$y?zw;M?-)cltD}Mh@v*0Jd zMfmL|2dV2{-X;@%oe&x=_|=C@z;7WPs={x*D~Mk!uCW^Y6xfP^AL?ITO}tRSV8-n^ zTpRIX49+EPt1u{`xZNXhvlqNk+5DmS0&sg7(NxDxkFV|SBi#5o*}pM=_!3-%+Xv(z zA;weidtHClaT|ub?mC1_3vN4?S>we5MdFiyl6ASHfe+&AApN5X#`8pp%fgEFXnOxQ z4z?lbGqIlfJgToUz77Nf1g%(acH!E-RQZ4$Kt`awV z;4b60AE_n-x39{+vf>q7zbCu|Y(e5R4S01!Ggac11O_u+jc{$?RTt+Hui+SkP`vKL z-K+5$Q4YM?B6?c!I@s2N*8p%4UJsDt)A2gF(S+C62!$5BCS&7xz_OAKyuKQOm$OR{ zulZclHR81xHW0+?X4GFLUKf^F@$%!^z-tfAC0=bZug1$RMGw)hv~$2Ks(mP4U$?Q~ zl?X1v>lV~&;I(3d39l&#eHOfWLKfil79A?XtA2J6uUxL_8u2QEEd=p8y0{v=)`I~9 zT#@fC!L@kjLdcNB!g>b8w&o2fS>D#B|_)r)5 zv+nCm`qluU&Vt*4MXYaAWaHuUjX9kpp7egn}+PY9w3mn*c7tZ!|eV9X~tw78f+1 z--_U1!SDTV8NY6_@$mQ!bO!NTzV;gM+W{L1#V`0iQ*$&+0A9VGZB9 zn+E%>E@i|}hfj#0;N(;Ach z%|uAF;5Q5+!QVBIjfcmtQDzXoNnB$!`ZpW45+1*!--N?&Gwzu2E7my)zyIN!@w*<= zq)`0&Q%}O;7jp{u{fcO6#cxV03x4NMO8m;mLF)KTUv0v#7eb^3zuO=Z@Y_X)s`A~P z_XqLI;2NvJZvbp1Jbnwm4u{_i+%e;quX7T99-K3N8!I>q3e8q- zzddlrj9;eCN%*zJIpe2ca6<7rf}7Om%I&x4IQc(BSu1`uT3GO#04~CBG&xEgKRfpp z7wrEKOf2}l|0Ux`{izbafgOVQEibtS{C2=r!sFK*%~p<|19!~$*>q0!e_t5>4}%km z-xt)Au=pv*$p0bQTJc+%WWg^DT!dc>a+ErLn~F{PHxt3cg5NNR1p93*8?VCuwGZMq ziEFIJerLm0!sB=Jzv1xPj5}uhigix*e>j)^FZF8t##2wi;ulj!{_mbp{H7#Y@H>B0 z_kZLlb^NBUFyYq=q0@rjZ4e3gU8F;m{x3azthb;at!EFgRD~pX@?~{aV*M*ZIl+A=+B?uhU%?{1$_Y^zT!0lsbOhe=y@n?SQR>$FDh>tsFlG?wIkj>74BU78?E!gA({5E}W(!ZGqCKmjLK_uAkJc6+*`)zb@5Wh)WV>S9W8@3W2zoQGn z;kOxg%=i`Sob3N_F8v>-4WalQp`M^*Px61wL-Ct(hXud$hjsr)j#9^O`ce~q zy%0Jr_}vDPfZr(Dc=-6SvuzN+46d;n{06{QLh%dwzfZ#YKiq-fLI0<7vj4-m?*A}2 zq4<4AJu%@I;{X02|A%O6)xS=+Tku;9F4DhG$x-U~bzfq_uK_}*1-}CyGk)!42hy?rHKrmM6|5AeZP2w7>vESLSmGJl-{V*JUn{mgCU$M@~{txHU|6$q? zil1F}A)Noi597tJ%|h{;a;pWu^ZRxGM~+g*Z~C_;{CXjDTJXCKA_2dd1Y=eB?Yt+5 zUk2A$4SoY)E8+25_(3@QX5fw)zkHpO@bloD@!N>O3B_+a^#mm=k00yyk^e)qwd!A| zCKmh_gNyX*+DrZq(bkGzjm8%ICV-3Z8%>T<$Is5a#RdC6 z1QQE>@4wIZO_7a<$8TV(Ab!igz6Shuz*fTJ*Bs4Oj-LZ}%=p=KPWFHA8U7E06N+Cc z^#mm=*FR+s`9DNkD}F0)w&0frF2b(`IZ7SBO<$SxZzh6?1;1es3HIAfHXa_oMlFN* zP2w7>vESLSmGJl-eK#C_n{mgCU$M@~{txHU|6$q?ir;kVNm%@1ekcDIABx|UMi%_e z@7DbvIZ7SB>0g@g>xIy1!S6PR1pFGv#>3;cvw0A|46d;n{06{Q!sEB_KjHA3fjegW z@^w!3e>j)^4}%kmUw`UJSp3%QBL9bIYt_F_aTfd*gNyXox8EMPW5zF2=VbqfbLsyuIHCA8m0bv9 zzePLA{~_91@vCu@1-}X4BK$^^qtx-Ub8m6M{tv;#g5Ue^Fn;qOS(W$=Obp_;{PSzT zZwG88Jbum5Y~}blaL0_FP3L6)_qO5xFgT(39ig6}WElUqgZv+&trfqOu@?N&z(x4A zAV;a=x9KyJ{>?-%vEVlhBEfz~$;QL$U!%K%_)X#(tFhnNu$A!m9epbtew%T}j9;Az7994ZI_W-||nc0lyuvmGJmAN3)gV=fE8^em0$x{ofmg z|HI&f;#W&{Aq;-XFXaCaZLRpNbXf390~g`ff*hre-=>dE`Zp87#Dd>2hy?qcMle>T ze~oSr;x~zFtj2z4!&buMcXU=b{5Io`8NXtkll>pgrT@dUAr!w&)Dx7fJbuJ%CI5G0 zD1KAy7W~d{(fuDeN*%xHADQs$h0tli?>2}8{Cdg8!`tu9_#l26Tw^u(4S=nL$8X{5 z;qaS*J7)aybx!twIG6qpgAG=@ z_43m+WWZe{4Eh%i=(7gh!3xoP>-a=>#5Hl^jlw2vaE|Z03Jrr3ir+qfi!Rs;3hBL3 z?2Mkp-=pE4IET;&Y3O@2`I~^F8&OxsQGYM;VjaSfHk$F!`&VPZMK}&8hY1?Je^rZn zjSG7JY6F6b1;;rv8OMioAqpn~B8j4N$SUAB@YW!H%ReyVhxZ~SPUiPV%f$}ZilhhM zzY4COHb-+|{2%T>$cpdz*mO?zf3F(;4}%km-^aj~@#F8@hWnmR=Fh;d4x+A(pZ@;Z z((5bqknl?e7vXmYIZPeD(s{Zb5`NPVR4n)nglOjP`6M-wc+vZ}J}${%Kt=KX8vW?X zq@;4=gfcUJC&g^oN_hN^&IpI!X52C3SFCfg|HHZTf0#Ce;`cOZ0O? z1^Yh)6$^fId{+G%*(j)gKmEsy*EQPj4%kR|{FT4)DvKK5s&~$74vExsQJAL!G8*_X;9q#mP_Ja3tBS)i)&EvX? ztyeAw_`~w_MR|pG)a-%sTRekZY8_lF4i`2h!R{mqnsO&#e;#apnTapz+H7kx9oRZy zKW!|54Qx}+xz$a=1DGnQE%)m)_NNtx(_SBS(f%B`#Qs0_`uG5U*$4D}_oeuRp3UC_ z!1D7{{d!=D|o+&U4hHkFvm{~yRZ)pes6o8W}sMrQ)ZB!I}S&#QWr4Rd8kC+j;|3?r#r*V zC=sjle%ErTk2rGD|F#$W!d$BqY_WiyMX*iHU2XFi^dnU%36v)FF^y^gTvFoP22mp)pBtf zam=m4H5JD*NM(CPM^aR+qe~m_P?E05tzsX5+aV?P!as|r*ek6m`>jGB^gNraUEL1- zKPz@oTk1-Mo@LX&j!KJcY(leg{4n&DYPxW-a>H)>e=`S&5MmEMqW5!GqxW6mI`r=; zRD77y*iz;eSq=(}UBiDMXvGN9RqPm3hD{dWuqN5C?Sil28r-sp4yX$IAH>lGj#Bfy zyg3fH@78K5+IWmiX|gN*yvKq4JR`9&uAlUu^gHx>U=?bO{R5lXk$D=s9Bx`e1cwe z4PC_NsYNX{auitbSzrd{PZ}{GGK8CrO5oi+2$slBf~5S2vNm7clPjCqmY$Z?e)27P zjvq7MnrIVG1oh*pEi*==sJ|=pR_X~mA^d(CIW9aInYA0Kl`&A!sFZ$D){iylxF?;2 z+6mO)0zrovi1u`=V*e0*%#vu#7C|twX3Tvv0TYeu1o)IA+W2_y&k^DvGN-aN04E7O z2QE8G`*qHqL zo99L$_+vA@lVY;Yvw(RbL&xki`4(T@*HEJ|W`BRfV;0o}WA+W)3i(Ca2L(7O5hod^ zD6tgfO!2wD+~~P4y+Aejn4o_6qCcV(5!(d9lG12HLToOD?Zfs{@WB3;kF~b7Pqe?h zg)Y4rDI@SvUr%$G=M0ph(OnErNr^i1`=SR@WvGX$m_lWIOgI`H6 z_0(51{epJ9`qp+Ou!1%M!wxQuP#H{=nDdDl0S3W7PSk%B8_@k8LmSX}65`dh}(@=!r#iYLhac?;q^*xN8lzp*%nRbODeAA00OCJhWd+Ea=P0tZq?9C~O zC`HnX%NL~7%^)>h&!tcX&ROgi_6Z+f2Sgzs%f%$3V^797@hr~3cx)u9gf_o^iJHRx zIAWT9<`DUG=8N{9M!yxL zQ)+{_!TO}6N7{W4UI9$0v$3UL7S15b9KIB z0eXbZeJKs%$((wIcXRVziLe)J!yQFE^Ify zMDYuUgf(I!jFqtd1f#;WD4Rq|>^d-!W4G@YQhRVUcL*L~7(Ep{}Nb8M6?^((t?D=0XxFhhSZ(eCG>t(UjsLQpddl!jO8UXBs4cfBzRsA+WZTMK zq1<0RDYK~C(Kk}yhp@gB{5}!y*K4Hmac;^iv7tPwX`7HkGnHf1eU5#&IU=SkPS4w1 zS{J!hHqC7x!g^_r_9AwGeJVaD{c?_aDaYRBFa_fVwAU!5mHWiZ)0b&$!=^~gm!Q&o zchY$!echxR6nX_W5C5^#^5z#mE-aq#0VrXcdZ1%@Cv7}?z>W7@kK6f=xjqKW*aTP6MqumrwQg-B7#roJpUhE@p}R+T zf2|o{!X~W#321@!3RdhNjSC_U#}TtAU)LBJ1K}Qw^fyjPU#rI=Z4~BYPaiOV?@(%yp1ZuMs*v2OLEo2J%`Mw`DR8gA?^8bi@=3iAnf(kUf_`&(bh z;O;&Jh)1C+&&_TMI;dk4*YMXV1J7LCIpt0gdclUWp#9~OD37X(j^K#>>7a3d+E8Q$ z8IlECeDRgC@1A=bjI^s=`rtUvX6OMo)demb{?DzA1)LKAXK7CQ375UgHnL7^SJ^f} z42LvOfW|pVCtQ=^_yc+N>F=OjTyQV0&r(l87PSahDa9^tUL5VYxyohF+K1+NV>zC` zdh-%(_&B5XNW7wT!-zG2ZKKhN@#2}6v4d{$bKR&DC}J$NIESDo75*J^$9wh|az6!+ zrXXRanUbcUnjWMI;x4Xf!W~lcf}g&ps{GB7s|W23TfTcI#@SrUr=}T@!%=1_fCvR08UB%3k0=YU5Io zDV!-&4E-nFc3`LCqU>b1IwsMrUXT`wx%55QtUBJl=!JwjYIdeLa}>_o+a(bWYgM9> z-Z;TtP|Pjta;sO!EE-^dD8OOFes`sBx4*uU<`lDvV^$XRNvLBlmPHn z@!`t0S$7vFmucWWB`w~zcPoVQ~0>8E9#d@kJ z5lzvbI{sQ9t;I=%|1w4vIfjB+h!_rU1wrMEzp?oH*yZ4ss8gXL;%h`{F&No}OMB5F zJ{*Rk2$P>h$&}=aBlEh6%|&!9$Qz7zE^y6nqn=)inu)yXjPoejtas+;dDs)M8$Ay%L6z$9p?l)U>fnxAOV zIRoUJXAfO^GcpDlbDnollA`!(L~{UB$o#(O$EZSm&ZAKoUz2G?#+>I%CPX`lhvz&4 zK)7no)9FtdAk zuLI&$K9&oW=sY{f!x z*n}|u;cLu)_=x!r(dGPy&M^Ohdg=2YNGSS48ZzaM$lj^uD(63_!94$=wB6U_aP10z z)Q%Tl)XVS%FMS~0(ROHtoR2o4b$#4n|@@$uB+ zq=?24Ev02=wDO#O?-|?^?nCTu3R(YnWo#kh6piNAK{To-mtwa;D)j(LiTm~H7STQ3 z=e+d?_{rzYA;zlKSdt+iYPvyh->Ek=k}HdD-lr0u(?sXVW}d5j&MTMEwy*AYsL}8_ zGv=|+dGC7oobF{6>!w$)v-Cn)-gG&bY|#9w()E^mW1yEN{{#2akloL5aur(i&%LGl z*-Mw+j34?L?xzU~l1*hJijezZeqZ#TwG1n;7tkKv(1_~`4EOUD6QWlV54)fKAYA2s zRvoy?{S1X;rp89V6VP!#La5fZ zF0Law8>bCtV0>->s)fSdRz}ss{lxJJxu1GC18YN3D80{9H4WV1eg2|y-i-QvX|V2s z_ZdrfEAu{2AQJBFcCHcYH@ptBrVLMo)|4%(@I=?q*}L>- zCbhN`HdMCM$cL=@9YeZ?g}6*Q@`56-CL%9O1XTeQs@@ovZLx5bjJDl4k4NOp0zH{c z;38KMy|IThfik-EW_%BekgJY2bEzYu6C5F#0Q38z4@DV6fzLfr8DEo_$%YBg7uV3> z3gTfC7!CrNz<&4`T6HYOQ55ern*fsr!_QHlA3GwCdk_^26DR?@ZUXP2I8=u6=`^uq z3I?oz(qF7AX3BNN`T5cWhRSut>pznwu=gNT#`jJ_K9%>yUi_5EYz3>yIA8@>j^(Ar z)dz?(c17a~E0_lk5^cku^4JNYkrK3{zy&2}&DR0ZoR8(=cA`TG(nK82!1!ukR0(}b zXM-d4zDGZEh-NqgZ)5Qe7BHz)yrBImaFQ%kos=j7Kn0|>VjPit(T_wLV*qnFNY#5Y zYV@LkON2QLqq~z=lZrs@;3U9504Zw4{75nc?;7iocL<12>yd5A9_GWP`0>j;vWMCn zYs~g=pKkK^a9rId?&9l!Xv)WOaTC!Yc$%n7XWop#Jq>$URs;4>Dx;V9f^v1Jebx4` z9{E5xdpJ)63(Zd^1tf{@hbjozchx+-lTQGA<+LCPoh0~<(|Ht_x=lt&oo zA#I@60%-%g_L1&9oG=#ZeSzmsYyhjsG++RjRk8uB+DmM)KQyW^fcL>c@~l53k50%% z29VD4t$iYeuLB~9kLBVvqGQw(#Z5Q^YwgyLk51)`FG{YHKnR) zXdp?Ak*`Wpya;e;iXLGzV29e5QKjCD>$}rf-3GNEMRzB!CQY!a{V*gtwEj+auGaT9 zhaoNLyF&W@E&PZ7eyQ(`kYbTmn*2Xv1^a)B8RY-@8vdV;@c%^To;RU0`2PnDeg84g z8vdVag#V}Pv|4@NiRe|OzWbv4p;pWDBxrU#>3AIJI6d#Q7aSyg)S?e{lREwjU3xQq zfyzrAZ;d)=cprkdA{}RbU-Um$P_;hO%4d~s5EXxJt)! z`$-*|1UE~Ko<&47bbKe+E7S2UFJNHaA(s-=@#W8>d{D>l_(f4xXy0W6ZK$>bZ~0(|lHD{!cS5zN z)7{Ec`z2(D`nq~J{qB7bl9GPANxy%CZ}8Jhi{jCKsf9uPegeLqdi@B+0O)srz7B}) zd@L7TiO#*wpfhiV?*T)9rlOL*cYU#$KxP9K?bl0TKEfyE#q4e04SS z%9vxdoCR@x86B?NWfNt4C>cPtkxJwMp*-P5PO?_zLyWaxX# zRZe|VA)E0+$PKy>f9YO)Bx+oW?Qu!?$L34nf79>faBEl1d*7fm$XE9s46`vNvtQ#e z`Q#GDr2p^1`3gNsv%FvM5X$=DW#oEF<@4Px7XYPczI)Yr+ny{L1@!f{pSl`Rpe0Ju z2=;+HqbQ)Sx1BvtnkU~e&@-Kzb3x*F4D|K3EyQEVbcz8=#XAODx0<8Cd$=W@hJ&NV z#={TO@gz_)qQEa;uWZ7*aU9&&8{~+BZxMXwLHXc>x5;}l3Y^-8q1Gq7cBXL@*twH5 zAUNUO`5Upt{)$yj{Vjs;z(Mlt+a-_vAs6|>?mVjdL|48Jh>mN051XME3h2~(>ttm#)bT^4lC{#4n&m3abC6X!n#c~67go6k?dxo#Q ztqYA6&3E(ZZe{b`@yHUZo9}jpj&VHT^|m$R5fAkBwxnHzygA?L4;RDzXIF#%^ELX< zNA#cQdOX9KH)B$^5f6Sphj?&=Ydk47QASv8Jn+McP4R%&+j3D&CH^LMhV(a&bHL#@ zKt83mD)l#?V075e@^dn+)i4NY#DnYSO1o{MN3K~4;h$PhC-;Msq{aQco7m;t^b6s^ zi~AjLheq>XR3PYb_Phg^vzc5UMqHtLy31*~1vClvVVYsD5u3?g4<%FmMO5NVuF!=#k-anoVbylX@O5=MQ*MiA$)zISNnU zN0MEYzuERTG_fjwGbYpGZw7ZZ{LM0yBvbnX?%CvT3aLWt`u@VPAesHmFydiTOPvaDlmrffs3+VR9oO@+$w?vCL-vU!d>s&9@v&Si zpmh?q#&>ZBt%=J-)b@n5O)b{Y~FzgZ^d-MPYb_;QLKSU{vI9_OWs86WjSZAU5%_T$B=> zd$^p=ycu;_LVCaH$hzQIo6kf1&0nwq!{59;TUPWr&*x8yW?8``XO4dFRooL#Ze))$pY@OP&ka01 zDix0y^3-T84x91MHPKnBT|1!F&wYZgMc|Mx%Vt!QB0( zbTAP=ljo2R5aXG~4(8})8oOY+bM!}Ii#=Sc!ojQq2g!2^u7{2z5JJiPhH}{6CkF6! zK=j~axlo8+ZMriLMusWV&U2=L|GouJ80h9W=Vn!{L#t>+3tWP}SD;oy?ISv8wCqJLSiSK&oEp`p)^a zW>x1k%vtbf)Y#lj@)(Og8mfK)?3JzW{51-yz6@!pX?uZ>ud43rXH*O>y zmTQ=)Ok-6K{6snyT*C~kC$`v&Q5CAb2OK0g-{wA}t=JpE<-(oPihXJG4B{`jI0^2|_+ki2l6HKpQHad_UN{ z89mz35YhV17j(C>^_`E9cUH5$^Xz6wTCu)!7B0eA-xI`?`ooq01phf+!Xt^*OpO%R8IUx2ga>h!x2>IkRb*5_B|_4?rBt2nG< z;ytH=gdXH)Y2lt0^y&E)<$b(}k866s)%~b}uDzgr4a%>h|4xe)J~~HY(5ik1Nop*<*(*u$B1w{xMZV6JC~l-G ze9?Kr7*Egr$V%>-f=Sgznu2*S+-PzITp8E~=xp@Ur%a(`)uNvvjiV)|1{fc)o&@w} z`0u5mr+KqN{FOZz>xfJ#IBzE1ygH6t{}b9IJHx9K0pWvx@?(O8V)FfXtYg)_57qlp z7r!D?yqnorN<}9U!VUW+cFzr6ck}1n~;>2Ia@mVg^F^H}r>p$gqUY z_=gO5H=cjUFcUSDEelyM)8p%nsO%c!>jx>8`1%@9lJWKQVd+qA#(-Qjs#Mk}9 zKr+YIH;E^Fe4V|5P%>t+9A8rrhR9koVEJ_X7T(`*D09GGS$utUI286_cpg)Hoiq&P zgYosy%hI7NT17f0+URCyFyT1LKqTqDq){Lkiuv5hJeC&m6*rGmzp%|I_kjoH&mD zgOnh$h~$gT`NKdP@pUuR~>^>Bn-5JrGN0X7lWnZz-cs>4MZ z&L`j;r&)k~+d%_%d%?{z@J_tDwJnQ&#&(^IyrW<@FcihtYCSQdcYh&oCqro@BkxR8 z9m}X0Uz6{KfRhb{*QtHcPZ19rid=;LEa4O!l<~k(JiUx?ruWemRsJ|l)ZyrKQZ!rx zT|lER!+jfuG8XK*p^#DOkyjBThQd(V&~h~*Zx8t}z0VM7C}U;hU8+h$@fDNWy(3qA zeX$Fe%(n6@nGkG6;pgc`#Iq}iGxn*AWGf`1=t&$nKDSyP|3dU3+ws$U9a?jMuLEKy zAIrrSqC;yGQHrxHle=s;6{Rw%WZz=gLqMbX2a|$SB*THaWA6MRpVW;L8e}$LVc?>D|iIvC9PUoQvG$ zV8Bn<;%I+oO7(s9-Q^e^*B6eZ!~YX>DTotO;{PcO((+RJ)0dtNhwS9s|s z@Cv=b7S*hez8nRQrH{V!N8n(DKB&6=tA*ah9s5@+Ax_vLTA?Ious4V*iIZdh`oTeY zccJk&Kkafv32}1lU(6%KsXs8BM5zQ22`Pluy-$pFcJb**Qn#h+U2+tu2ox&JPy5jt z{yO#}`Jnx%Csv3)f@1$Rii=UNV?1!+b0HS(v_`AS4E*FUF+r( zrL?+em&6I(n!k{J39F0d&ttZPIeS8T{1eDQ5G@8p<8LM=n!8<^O!!9CLcS|h6ZtJy zr!rnBkQ*UnoNz9x1ldYm%%(uLnoEFWtFZ}%^wIZz?*JaOrh)~1S!bTZ*`hxBex}x> z6B|eq^Me3vbVL#>wd&s^F`>^W$JS>v7jkO^EWTW0*=&2*QgH~idw7Tcg_Ajzc;JIuWkn7Yku_- z)WPYy5ri#*Up<{&?3!`*!If(2v z@vA?>fYzbR;hj95* z9y6VyIwFLO3(i56z~yUY*#MWXkN|PH zrwPTYmHXKb?!j4zLm*jA*}|^4p5EX<8|a=aHB`PFBcS`)we*oVjDSBES_ zPec6bub=^rKFA|%Pb9xON`%icb(?I88`bslU7@a$-*VND@iOXe4EeI2Ztmds!Eb=y zb{4x~dHv-Wh` zNA5A;+JCmj{2)Ie|6?I&%(tY}7Bw8?h?p<=ZC5=+JD5L>W$eZm_9mk99tF*jy0(AK z2x9&X$Wcx8v*YbZ%r7D42hP)&^$6%FG3`WfGY;mLA-lo+>BwuSc!t{22blj3iAz}Z z^F=R|2j&mfR6KKx#{9Z-h({sSPl`kf^6#EYqzkKlcH{nTApiEV5c01<4t8lDRu6xN zFVV<948KJF!SY?9`pa**%40mxAVXb>kiRU~J?C0TV;`iTVl08HWwjCW`V{A* zs&4u%JHr*w4l%L<-k}{rkSfJwPgT$CWglJRzj9^*tKx(fi1TH&Y|80N!m98ywI=mV z0eP7t`7`&Lk3_DA3l9Uh>p@3?c&SDF-@rtXDo6OgVQ(N6xQcrO0MSprq5qd(=>Hin zfXHG9`u}8SJ#1T#^-wM~LjO;WMIE7j}G!=}eGOxh`^U+sERn9G*$a1dg8 z>|u(GLJ>qc*2kUqfVtdEdIOkU!8F5Mc9?}YGMC5nuUe0_ioVT7O|0ZMP8Lw=B&p1G zJyWaN9haCqTbr@LYW(E|WOnViM)!yL%k*1?zwGoi_{%@$9Era?0IG0A|0>EZHHyn`>H-04n`9CD{*Fjbp3A}NMLCLb&s4r`95~q{<`y!@lff%C+%f!Js??vqI#JO;qb3Vfd1QvRR`|_br zyA1RU_urA8-5~r_Bt3gv}Twj%kLd-8cgs zBvCu&dC4er5JYYBNZq%3rlCx!%=N(OM2#xW6x%tgn8O6gQ;n!yN%qT*n*=q3qhKF= zgAldh>p;}b1gUoH7uEbm&qCQ_o|iQG@Z&y5->S;b!f0vI6>*;6k<%*47rw?0t@`;h zO{-48UP4-B?9DR}?U1{%npUmpf~ZLOVm$K*t?F)Q6$uh))hyDg39m-dDv4@}O@IWU zHHZp-U&0RT&?-N&*Cbzz^gAbS&04-#E^$JrCcQ

k-NN!k@GZhSlKwQ5(Sd$&bl|7z$ajUR5S2)|D(A|; zm{QbshH(C0dPsfvv`;{PULhX=U`!$ddQAHB8tMqspUU!cW%(k)-kf5j3)#N0d()g8 zg|;2(B8>OuyyR02HQt-^k^w9OEnRH=SmS+tkU`?TIWPGxq8+?{T;u&Wor&g@F3fq! zNz5a7f33m$O$P5v@T-bnio|<~YJIlGtMoVZ?;D^W4&F~j_L`&%zXy2V8{AWbbTOhc z%7>+k@9xle|K@8zn6PxQTA~H@r*K6?NEcIHWzK|2n?tC72XYYQpL|3A)<@Tf`X>m9 z+o)>EcZE8D&4u@??B*r|B*;(-A!NL|5vm00A1|v6s2?Q(qW)eCmwDsW&0BRSQT=S< zlGFqvZl|cv5Ql7SR438XyUtzhOafNJ+pOQ0wKkD6N4sz;Q)?0|nu8N|=<1Q=i{Ft) z)`Ogv905AwoR{1%Q)6vdzNjNZhW~`@)EiYfen|z&jZk;iO20mdaE+^g`j z6A(ia5$so`b(J$K?!xw(1I}t-tVhOg zqZL-0wjKqT8QAeIXb6{=_<6wo9Z|jlX%GdUi=4lAtE zp64t$)}x(Vai0nGEmL2;PE;&Y-QNu_uk(@JEHCa(z*ItDm}+?`me(FqHn70Mwe{$f zTrRH#VkXk^`&}Z*VgGpQs>H0{Y}Yi+~29=ES0OX^;Yv2=&1fG&14&_ zUilbtwySuBg9lihC!dNq`2Qtv;#G8 z-^O}OlK5?4@R_f1BCFV!t`$wr7Bx^*G#gcK`Nn+7Z@J24yuh+8L%ysBfw7up4lc(M z{X;4(Q{Rh}T4jmWWMBFndtBJQRD?QelK-#L{PIZIVnzO+&xZaIzkEA-=iAk z)>2WKdZ}TUUq02O)kB)v_Kfh$O$FJ7U+yC04Cmia1lZ>&0ZMNIzx*SKAn>X$(+t1d zb~@tz62H9WWX!Og{w``_B|mY-NdKiW*SAcq$}fLt^89)V8?44JpG!8&j(Z$}zr!!5 zUMc)?_Db-}WiN;6dNqD|Hwerz`Q=0s5|Fbz{*qyK&YS-weEZ}3W zXQpXknp<-k(fq{upZY=yv0oJ+udH`aC6YqPZ@WAZRm@<&?8ditK&?Uwzmy19Q|1v; zI2sWS2@GiinmtWQ;@GN4-qh05^fvx6$PgRth^clsjpoQ+lQ!VY94xi1q&{J7z=<75 z3Paj}+eHGbP`S@x0>j#X!4fTWu;q)KTE~!Hrdm#C&V;7lg*c5^XCKRvkAdy0;L^ayP zC8_RYvJsb}t~GI~s;!C3P)c1IPz)Lpt>V1776pMDpX~v4qKrjgh4c|4;db|EK)I z|C8|opg|15{}U*viCbOtQZ*FL68wv>a#e_1HT~wPsN;zIM+)%~>wt=~>I;agqq0Jc ze2V7Dv0#J&5d;n^)KC|h6z;_qE1qCJ@-PACl{gdNF6^Zj*Ow<6Mx&!%T}w}r)rI}$ zEM^9fx_~fqb(JxL?J8XquHz5ZZ8wf@k0@DPr|3K@nMYRFV#zTxISRjywLqxr^i*_aDeF?mu8W@Tb3Oj1U=(N8?#?rOJ8%zg%H$B)}Ec(uCmOW%%|) zb&82gQrq^i09RNo6PK#KF>x7c2f>BZY_-h9S?XKH*{+TYoq58Y!MLWcAGW7S#9KIz z=CLaea7(jYr<;70oJVh<^Qa4RhWB<*n=fl-U82QVK#LQZf9x{B+e&OmEz~FXJ2R>J z`uu{;k^lIf{70XQu|C%!1YgVzs2e?;aIN0Smd-LVHLcJ@$~34hX&ONM;z7 zze^{d7Z|GKG76VFar+sFN=iQnUomFE3n<~>U(x%Gviv%jdAOMmT5}-)G zrb-n?{F-h)s)UBgsIgh<)upU9GUFX|cmlCoVc z0aCU+6N*>O{$L_`hxR58_dA)m6qRD)Qq|$#b-oPMz{F*%ttQS=Q6?@=eP!bMt8D}; zY96eXFwS;${lLKlFd3h*bH1z{bvX5S45M{7rq(1x<${G1e=D6>oqnARK|tu&Ued2e zGeN($A%v0de@d^UO8$Atpgsg-BcVbYRRj61P<7?ET*WY60D0gAgnU_Dq>of_yfzoh zboMk>TBfFnL{Wvss7Zc$7uAI2r%tHD$WIaXGyc|7i%%DU78`$MVFjyLPvw5bkhQ^_ zy9u;TLk}JK={rgh=-&3{bT_X%fxu7y(L^@`WOz*)g@xnutsq;ylPY zbo!l=l^yr})nVGaCr@azYaVFxY%nD?`{&I=!6W+T8T-P^bAX0&T^$Uc^zb16CS!l--Hn|6OR~#t zR8Pw{)~o!ME1U6Hb}7n-5HcP-4pm|izepmA1lT`KC|(sKgs3D{XNFEpRQKs9_%Bh) zv0XpRcAyPvGZ;JrR&qgYP7&>!8<|>@dEu+65%$fR?F%oE>kZi#nx=!^nEQ(S;D9R2 zGw)+janx_g;@YTQk?#uito)X%#~Cl9wi)te{Q#uW@=SYlQFTUlxSGkovgV`v+j~$) zRe8qoUo!Z;;#~|p62C=>nhTjkdnn2MaRFDqiZprY#oRa7S$f5nUS39dPUmMJYQ$~H zZ@X?|wFb9EuCW_WIS)~?L!0~Nx-yU8wsS0b4R=h(cILIK;dT(@hK=odRDQkoY|&Gy zt3mM{9PcE>@Os+{MSotEK%xzV1zLj%v-|^rQEBI)JaL=X-`nYrU#@Zc#>vDKjoW^S z6Ws0vl;=LKZ=35=%uES+ABQme0!hdFBf3}W3v5uFcH`PS%oiaS`-n8@4fuV)S7U7_oGH0s2RVPK8Ai1zvaHUPM{0UeRHn~SG2tJJfb3~ z;uiHaHbaj6bJ-L(s+ICxp%(F5@cKQ8DOYbW#+P*nh^6s+AiAfnM^}j7J;)Is6Tfdj z9bx>YKN8<4v77Fibv~}I(sy!o4nGbyxr^Qke+I1OrUbM!VPLY`0@ZV?PY_%EeuPsg zU(F`5^y!C5Lhn^T*7yjW2mXwP#Kum4E6aVQs#QCzq8w?`Zbj|N^Pp_94**4xpD6l@ zDe`$O6mjl9HbvT@2&;V;X`w3;9t$9nyX@2G(-E%d3Uw7-Y^J+-ys7gd)81966Ye|N ze_{YtHI*luJnf|2>enRr$Pn3aGqFM(S*XY(`|YFeV86`;AE5W!D))4CMY*5{!kXq& zs>&xKr$USvERsWne3FF7VTi=e8#@0}Nx35aOB7(_01)*lqHdu8Bc>jdCk;ZpScXDE z3*srWAig&i&w@9d#p5m%IV0e@`aqgK8I+<0le|MjR-O!ci|LY_5ySWY4kfL?I!ha_KXHE65Q{Her_4ZWksCjU6EA!S5Z|a2#^i z7un60UV^-4OYg6`w*u`u6}^j4xwLIbvKOgxdAg6Le8VTA=CI0TqC^Yv>pO{v5>~nN z4KQay&lMrTqz!YRR|8G&zQh(qQt*jvRU6eZ`Nny9`7Kwo84ps>U%ieH1QYk1n_;JE zT)`X8SE}VC!jw)HNPzqNI|!jb19kj-rcpR~R!60%y>$9VRFayAD0E}bpE@E{-D4`q zP`f_SaoOs6T`o^8H03PSTSxU)GZvp{RKEO{tD6}w zaJ+^gU)DRoR!vIlp_8hSFneVxhU%QEq_ifv^!j*$D*W zYd`&S3SjXCt{uuhE62SsKe;34-&@39EQ=k4SQ9j(k8HEG{-aALnP=#|--{M>dG@oN9Q?E;gvOubeC-aFXU-5Pq z&S|55SE&9OtW(CHe{;C*9;WVhKF5jO+ z+~a6pCs#LkUTgNuzBzfgZv~zd#Z2A|twXCvIH%uwYeNNXeXw*-%D_oW_M}*gx7M=! zYpn90*el=92d%}yT2}OGzV%}*-c-wKu@w8{t9yxc-=ZJxIo`Zz_ner#oC)1)5@cx0tmS2;OQqEYf^Q_vr#g6{-u0C*ganE?ZG3$?xK$YbN8Gn$%Nm8 z-pQ%LW8%7q6*0B&xG(08|2kNih{6jz++eWUV>RPqr+;)`vnZvAcHmfHGQbnh;BB+{ z+;iqyci|3BD0WOlSV-}5>$7l1!OLTw@l-7jmM4<&CRMg&UVom;2b;ZMNnwtFHQ$rD zf!m3@6BuQWT^CPC?;ly;%G`mNT-?c=x!67KRknhmV|aKiZ@KD^{?zbZv%By%WUTf` zt@HXcJHoMrI$~vR)Vwjq1>U$8$s=jJH?v&FgM~)?R>3q(xRqI!4>Klv#rSoIFHQ8I zU-3D3?k65C$0U1JVp1?ZQg32AUUG{d(YV*C8tT*vq0TOn(tzvvKhmNEecW?;_XiR* z>Yp>AFWwRY5$C;7LX;0w8sl%&WVEKL#R=77|2AtvAO7;C2>-O;p zt-VWQ+(n-vQ1o5?nIYVW-@CL{e!Ty?9QXUZ8y_C(@11y9?x7;wF;Pju<>-Naf7{&x zOimE5vdg#gJa_ORM94gO{U7Ofy`l73uATt7t!cW7dLlpG%g*C_-q3jj`O>2m(5Q;{ zqJZ2xEZ>%Wz$E{-o`5$2A#eOXtHnOMZf&c@3jfE8OKbZ#{BFGz>2PZ+6#{+1=kJ%sp^56^#$q~PA z;M>_hFkzWbVY9{~bhRor$$DBkG^`#kMtZ$tq;GgqmyfB~g!j-(B8&5VYS-H){Ydru zBg;pY*8H*S>SLs59wXgzjP{!xBR%@4>2^YNuclGOV2Pf40dN4zn%@qC_LikZ1@PG1 zm~(|au+zQJRi=Tz^Aks0MNep$C8Y^BP_ZduK5j5+b<-*;Hj!6=FcpRWvQDrQ?Z<OYbNbCaoTT;20q!57Uj!`9)mX{({~`>A}l$)7lS8f@J?LBqtP%5 z1fOTW+ePL7igHt=T+Emai(*g!wQu~i8F`V1MOT>q8h+Hi<49%O(bn{i`jZSz$X{hI z-i(gUpQf%WH}^}Xl@w%cK?70wF7flufe?{!gRX2CekhGDEAaS#;m+OTK0GSMj`HLD zae}q7nLdQ=3li%vZvHEKd4tI^Wk6|B)n{V}Du~Km3^KymnP--Aot1mBrr)7jI~aKkF19 zsf)kw6ql!t1Fg4Am$B!t_?_Y6->?|QKG-SFH;mEw;ZE^~`5kEesxID;#oL67KVgbD zaf(xrK=G@c;=Oe78+7qtcNE`4;;6msE;q%0=6=bsN9*FJImH{`dxh(Kl#b?WhuaFc z13K$3Z7*?iB(px7f z4efI0iH!fv#E-5L|Cxz@wo3dQ6ThNL{4*wgdnn#o>1zBemM{Lv<`67J68BX*;eBjM zAP@^b67tjf`DcJTzWcD!Kehsmy<0*5YWw!pc2DBDibYsUSk*s)8cpV2_MV_89{L3h znWo+!i>VMX1w7YfN{GmaE73ITh~7apc-m+7eYB#p_c3h42#i7mT9E)DU7QR@Gcb*D_m)e=6&_`)ca)W!L++4Qjam> zWE6@ug$6n2cODU$CSjuP3igB6lb?0~@;L}=yC4a2?J-LQ6zKH*gu~NR2k^mTz~MFZ zRzY<*mDZbj||6p`vtA6h95ku#wg|{(}{3@a8HUfL(_k){&!d z2()62Z(l|JEnFkZVy`ggctB{Mm&+J@SH-J)yXq)r|Q*rDg9nYeDK zzh^G^d^=$kfqC9B}jv5ua3onq(($yXv&25+Do_IFDeOc#VeSqWMBYLv&QX2LS zs4Yp6T*o7i?aE`cF%LY=Vs_&Z4fWvN{@U2ek*5{&h@NaHa;U5kpmR|8QxJFV%yDj@ zfKxtoVBn`yRl+W^h~?_j`-p!Fbbh-~{F;~p53rgi;i+~LdExm7poK0GjhZ?R&EU~n zkRs3GGDw_1K;l%E?+_%-{p^?T5G2hw2ol!VLtC))-Q&*CAMWP-IK({ut@BZJl(n$y zfN>dLEx)BrX-m?TvHLq*;zpiFIN-7S$2>L_A1~{VicNc5Xn`LPMj?ro|K|V3w=@Rg z>50hu?6~NtQ42ZT5>$MN-KL$9aTjQJY%NJpg2HV=vyeqy3`xveTPOQU@l@=gAtUkD zZrqQUEo-48{R$uIhn#POV5l9x)ZphPhbnUXEAdqK;<7W#e*i!Qp6_C` z0?ye8IMDnSVgJ^#hcr0n5+ETk3RFu|48Q0*fSKrkCdMAn6VX+|y5K7a9~qJ$EV+;x zX#o;A=Gbk{wEVC&5XBL(A z1pJ!bwENl?JN-NS>;2zGm)N7JBf$UmnK={MH?(_c7{xRkdstw!6fhzT#*<_MM3in* za^|AbQ4kXCI9E0Z+FrFEfO8bKl<>Xi<8Vj97sUtUc|=gcpO{>L(iHMVoJPWE%gFT< z_`~{yb8?Y_O@}ZT&aqnVapTbPJhl$%J*fk?oRw-~KFCH$CrtH%xjf2f815w#iDrv+ zv(km>kzIg_NYapJD&zg}-hjzoS>XURyp)@gJQu$qwZnqs=@LC#Fxt^TG_=}5v0}M9 z>9rtgh})$rWopBn?DEXyO)MuG5q)OZ0oi`;&FIb=saHcy@``F?V)8eP2e3@{1dw6C zWfn>XccB*o1ZOPO(ZzIp3%b35Y#e$Oyn#$$8A@euV)1eEu*GGL98H=lL0{qBB?SWrmi-rG7C_tNa}Pp!_=9QO84f>3Y}Eo zBuzF+c^2Bt&?*-!7Ze(0s+`5FNKDctOPrGZke=f^=mKVQ#CF1E(A{on#die=un4>^0a^s6n^3%Zj3L`qF@+mS z3Yi+nsGSh5qPBem-Eq{yyU~1Dbvxx&z!3OecQk%|SvPOS_T?_5-U6J?O4h4goxvuB z`y5<|+@{|F*9V)@qN2CkeMl7Xgm+9z&V+u^!DO(yr27Ha4L^fs%;`OhL}8eu{d$0D z1so^zEZOny7KO?D3bsQbU9akT7dk|{YuP?9b)PnXz2H}b9QdG|g>n;Rl?2Cy%8A~_ z-C~ODctLnPnfeglANi-r>Ifbminsf_g4@s?{yw=sT)*A_xZs!4O+6p{zB?jaG)2QGd=&9^ecGd=d z{}TRQ!tXD`-!u5VEc`u%-?Pm(rJH^C8a~WUXbe9Y(XtymguAc|8IehB5y7AF0gSwj zHQa%)>^;G|0e>Buhn~&{PDKT2d)J|XOpRgOWuef+Oa*z03SP`O3Ehu4Alyx0HB{gG z3An7JOz>^1(GbE77+%P*e`#qPIFZthWN7X+i!zmP=8{%7GDbUpUS$$3)yITVR96$q zRyhp$vL*vfwSj2oWat_GMEm6ZH;ayXxqknA8Jnty{H4&kFE3rhK8)p`$M`ud%rO>g z?N6MY15*dM9xV3s#xMb308b)HWnue>V84g*K03{R%iXufwkI9Dk)00NlWswMLO(c< zsrTr4)DsAA40;dNU{B(FJL|>zpV~jr0ZP?Jw12b&FAi`f6RiJ@_K&+c-T%=3@xwp0 ze+Y5?U$K8&OZ&%77?b^9WdA^aYEr2G5A7cm0Bf>;2&UCw|3Lh|YyTL<4!EBG?q9Kg z_*mJ0hy4S@x2Ea(Puf2&0IghmGx>Z@q&8YswSQp#Yqo!UrZvey=XVXh9eU>*6I*LU z?8?ru+>w^%DKGZe2!dQ3=p5@)&^|?vVkT~7OY?C*sjL>>?*jhB7=v$c>90fvO z9P!=xw$Qi#eR91^i=FWX##jD!^cl2rTlQ_Esr^aBE*RLrT@W04nK~79Z5=X-Cx)%?H#u_4&%tIca6zbpQ%Yj8dd1UFFyC?|7DB#gc;9)m@#81TxE`uoinh60{ z+x4OVbWd7|Zw;LsL>FWlF9gi12+SQ|5U}j9Hf$^-h01f2#imZHysr)=qpZCK>QQ<2A%L71@{b(8qsk@$KlaHf_yNi)W<$Fo=9Nyv6){uYlC=cr{9Q7SR1Et zZQJvw1B~j7>oFs!`BbuWs9mpw;3xr70dk-==vrZq$QiU05b6%@56B)&LAUk#!6HtW z2eg8|GamIjy=G^koz9#EY@E5ybS5D;&?6Q`MRaIKhIHs7Tng;FC$^Tm=uI{lxF=qH z1yy)qNq&8{4*Q`fy|uifJ|4`b%Ss}ARs4&^D`r34Sm31s&zLpVIlfJ-%)frO@Cs8X9;e-1!lQwde!E*wnx zKHwU|YGBNEPwF88e|j%nRT+qGu)RdZJ(3Qv_mp0ww*$Pfz-J*!T>+F1Z*RpBrf1o| z=r2%7zpn2~>{AHKVfFjC_cYej=~7{s<-UXfrZr3`1F%2iu@Jd0u{QQALRIX}Fze)C z{W<4-N+E`DZ##4gOM|p%O-R^5Zj9ONNH?j732QZx^$a1X+HG}-DmYT(wIUk-0w4`H9%mXa8j8m2X=vw|#?y{e-Mj3+ zIODks7gVZl;Xpl>3sIeOLh14=5oV{aW~Yz%qNUNxkOZ#6{t@Y?rw+m$RLhy}!jHIT zIr@SH_|SBU<%+A6n-y8^B%oEOTr@ty<@#4CH#)K$d?v%?5{a9E)}66vougDuTj-gu zjY^0C0a$n(NWKMxW!x6-S@^vTX~3=YqYYW%L1d4e4j$ zNMam`*5)N`;;64bw2fmI^HjGrf#wuoDTM7!K913`H$A35w7n_FkAKJB^w|vnSq=84 zTR;8J*_#eP(xJWSEC>lT*qdI!Xa%G%BH-AYRwEp?H@!-L9L?Tz9*iW8y{Vmq^;|rT z@R1?;SL{tT5Tho0)1cM=roHKX?5{Q0n;vb74Ro*a18_&QH!VO>F35kw-ZT>6nuq^b zpXq0!ZSEkAuo{kLZ@O99HwGkQ@|w;n9Fy07&favjbOrYb3}Ba!Y;Ou;xBD0DP3?i# zmF!JlOaU?8)*p=@$=;;>#3pL%w*l5)us2P;GJ=rRU~d`?Ve!cJrprxgF=wTky{WyV z)@W~PVv?%co9dV`hz1c4&LkTZFZp@N?_GVQ;#nL8QH@>s6%Y*gx<~aL1}l z6N* z^#jY|(DQ(+=Zc!_Os&L{f_}N8S5>t$Z5IPh0iajK&eRcwG~b~%lP#j1>33Kt)OC1% zEf_?ovVG~XQ2xsHr5O-tbv>2sOQ(k7X;(TZ_8nL7byz+e{(<(SU!;4QpWyd{5$Toe zOJy_$9C@V`v3r&6OH&0Zx!S&Tue4t$*fO$yJ8NitSa)KCVaXrva?FgfWUGiDTbXj zo8c=Nu4G?oWENrAzH|a(w0)@p1LK5PYL5w}s8SQkRzET1%Sr=!YWq_0DA<>tLi^-3 zedOL@JaX}m*q7c${$tvg%=<-6QB@7{((-sMFP(BVD;IfbK37=CU-xM8QayCkk(cH} z@M14Ng;4W1<)zE>*!D`b4%>huFO4(R-H+rOR1PpvmO%iL+c^pzK}U_ zdO6eqE!V4|8~astHOPG-F6>dFJ+^7DY{-8@Y6v28}(l@*w zMw;qwMRm%93|J2jU|CevAN&Yh3$KUlBQ<{H_3)`zH{OYjoAnTF8sEh!tZ6JqUJv)1 z>h|_w(Q_>OzF2iycZC1edYFKQBiF;L+y2^m$g5Ircx1VwtcS!Zrpt`x39!40Y8;tx0Iui!fiH^CKVctfG%zO2}(fV(5ys4V1;vB;=u) zBWMz8Q)M7xZ^KAULQ142p$x3A6kzPEt-fmNAp`{)=mO9M2snC# zpAio05lRT1qv;VkqX|ck&`ZKvkMI`4$Iv4Tw`eJ@VgdA+k)FX%>D1NI8k_#}QjvwY)l#cLNg)KHD)*J8D ziOCa~zh(#4LY*i+tcAK_486a5+!#R5Q7f#1Y{$)LxrZdlxpPgsu}+WZ%LvmK9jARl zMcRx|D@Ypp_$te3H&%(N>c%SRIPJI!`6Ap{b#=1^rz^R!rivRYmxj2p-Y8uuQ}w0G z`o&nwxUp_xCgV)H8yh%5rsH&%cS<@>_)f(2^U_TRdez-nnZaGy$*2`F95>c`spEar z;)a(GieubZwc0?RDjsZFHmU@fI3Y-3H&&jlt>Qzga=J%QHAwL(+G{jK%9?;dCe@Px zIc}^nA`-gVCUrW8<){?|rcC|yGF`R+sb0sEwU}9%x>8c-o9Z z(%gl;wTj`;4XC%Ki!1&>ZjpBbu3hidq+e(tk~BKydhY$I`i1p1=obk5U|L9DpnPPT zs9*R25~^}-g?`}+ghKiSPG!&zh#tY`AsbiGFYILg_)t9c3)Cai0FNTe{z(7TYmI)Peq{Z2)^W8U-T#4}8hyg4 z{EpBk)Z+J-;q=mId^`FC;L(@-o^8^pU&sJb8vVkcpR4K@_9J6RzpxD-sNpTva0kL# zt8fQ(1ORJP@E!D2>la=Pg?ckp^b1`=A!=l_R^dX%fkH(EM0E9n;&$by4EIrTWxQIC3^FSZHI^Z~e*yH= z`i0c%p`>7Vy8plC zA19ok`NyITpf3Nn_{Vh@v&%=^%nJXv_{a8lgMaM9#{XshF*-Mbs@1?h{vk@&}@ zCY5_mb^h@slUjh(>ipw)Nv(;0yv39&VXZarkKK@7iGOSWf#fgpkL&j*gMXZlQImgs zS4L0%@ih~QR~wbXKR${$;UB**<&N*#a}_t4f5bmNn8}S4_ZO0n^krT1W+eakA?vM) zf1HinhJSo}#?kr5tKax1{A0&lbSK0=F5mdy$UpX=Dd5OU?jQ1xE6S5A@sAt$9l<{? z;dcc8ID_92{NogUNAi#Rz?B*PvGF&5g@3$_HQe#P!#~~xrbG1=SvM;Q5|dh;MIdH1 zV0a(Rc2`)sPCT zz)kqr4$S~Qyn*YG?H709Vi34)ft!=@g`^$wH3A=d-Gu{?&l9*5g-Y@-w@|O;k4aX% zcFqdm#w~cu2D0NlfxD7Cc2C^(_jUg1>`$U6kOLzlWbhUwH0WxgH&8cup@piw{?DZj zx1_}2`h=1ZFQW<6a(@z2JocriX=Q#KB6TIdT!O20blGzCH9jof(4hSRy@58#!ONvT z_a#|4bd6Er9y1h&IY1YG$tg}$n2HbHaM;=F|1}6hIDm}--kXd8KvPL5Na>S2=(H|A z)G5ws93aKF=TGkD-xgej;&3rWvmH|bS*KZiaOmec<#zP5xOiK#dX=;IiV5b{S|!3WKhoU=HC;%66HOCF(}(P71QgK?X1hr374%b%^k6CVJC)Y-(;8L#WCZ|a=GI^%=qp-%ci{}0daebSzT#Y#BB z{e@rbPL}g~*OK!57oOj{nMm>v&+n<1ApQK4`wKghXkpD}gBJh0_ZJ@D8t3;?+Ms&- zzvukk)C)j|ZQ!d%Zal#iD^M8oI>rCd{e_nZOAIPf<^IB!CVp_0`wQzM{$D-6m&Tng z;QIN6f8+dKGA*P39q0EpaNDe5y8eUb_pbjlIZD+_r@VT^^Ly`LK5IU|ca?ZuEDt)r zSK~Xhzk|Q9Z_ASd8`zp|Ar}m0C*Y&L)CxTEDt|JU02mlA#5vAs*e5` z6ucFIh|?yLze;=axrf{Lj8;FVB7inf%N2uyg=m-Zf;Z43-WsxkmtrpVl<&gvK(Hn; zYdrpS-M~&{cmh%I#K_#mvnd(8$mqPlDC|=u$UkHS@_RDZjc8=~_hs%H@ng3DPK1@@ z$8-a`;q{jQ1i3tbQo?Zfd|>C8C(1kQ^mUGj_ODqwv{?8iY<5?IZTc?%{9^3U?4jzt zQpT(9#jgySk!}+?iob!=QDVgB25b(z19gf@?!Shos(9isZM)nyCHw=(C%A(^n^#pV zSrJfDbhfeA9tQPunVLenPB6{KM#qRD!YD3}&dF?*JZ7vDcn!Q5i1d-FeoTjg8F!J+}_^6{QpJqb=O;JV~#bJFT0xYYdWk~27SE)t;?r+?H_ zSQYGj=%!UYFIJ#yk~aWupyxhb|J>a2l>qJ?<9Av<>1i}!a8p&sy{y^>1bgcrh6^k`mP8Bh9|2t%}JjUV*_hL4#>nCLaH#K!J{_gkzwi6@d{5I~ajuB)zhO zQ-!StUEsK)FfL&Ag|#(SFYbOm$i;T8cZYon=;gZZNdOSX;oOrpFv3o6ip)4Z%|Z zTL7&PaTJ{D^sw8U=k?!{;`IZBL|vCb;v`StI7DQGBC>;Z2wAy5r)ZrV6ol<~32vOO zRm+2R#uuQ*E_VAptXYla>fw|?0;2#ZpxkGzRbIP2WHJM&%-#7XvYY5wo-p7Y0n2ul z-DbH|GEpj#(syEw)ed$=4=@yW;Ux%o;1FfC_}Uv?p-x8O;JJ)jydw*D=J&$-RA-z+ z2xq+y3zyp68pAHm=>zkKCXW8~z5E}8UM2btKn{HY&0*pAcc>r?OHe?OJPvTr`2x2L ztG+O^6_$*sFL&{o^V5co;I`E-&yVu8t#$t|{xVSeG+b>gNID@G&v|_6I~jNGAVdt; z=p8C|J9~wgFgToV5A7e=tFo;j>jJG% zNkWXN>|RruyYM_@M}=pzLL5g==9!2S>rUrl4 z^}kX&*`k^WLoWWVH*s67>fu-8`M@S129Ce$#}IS41b&d|?F3Gu$_4sIJ|B2vQ#1(u z;LqoV{res>)jfpj)D6f0|Gwu_xH2oB4?GMy7WVHOe5A&Y?BBONSvP(i8?OhH0XUnO z#>s#EP5-`UOm(NAI>*1SZ8L;PumAG-z*j+)sZVqCHmjC}^fpI5A2_^9x#GxjCjl`q z)%qTy%I5r^))2VjKYS3xRoaDOr!y~ zs-6#=K#9eUyS*YgbUtw6X4Hy1f4tEBds;=%H$5TY^MBE*3rZi&zmM{e_V3HaggW{y z$3Dxms#voL*mEn{XGQ5{&Iit#Qu%z~vyVgL=U8R`v{o{7PVuQy&KIO!7BTI?tI{z zX_SGg-$&W~(f^!X);S+o3lc~TcG>^#^MSVjF(T};q5CMa9{xA&vPU={IAVJ;?Xouj zaR2f1ffd_GwpOZxO-OsDB~KTMr5*W-88%*VH)E%ca3mDpG|3y`$S3*XAvcxf{`c;q zbj}BQq|5*L^MUUU1Tp?33Gjj;w#NG?|Ka(-(aj3}Fs?37p$T!_dZ6v8Ro)3&RN!8B>ZfU6-oW)wup{n;$u0(pJ^MMEUB}ZCeDG%s# zcM%ehmTR!7b^AU!;y%iAnsZ;q{()c7fU8qYD0Dt>^d;O&j$(X0^7+8HMi>duyogMe zFYDK0>|CMqf!VCLrt^Upfn^Dw4@`TgCi`pneBe)$s@h-w%K5;hWQ#)Q13NAGZ#*CP z`T6K0?5~>yn@Aig-Te9w&j()mEv%n0koAoJ-T;38A?Ao|GCh~@`BwA6YNN>Lx1P_|mkkT0tq&{NxAhj)Pe z^`5h(xEez4y^{TPGV&kW{%Z6$heQQ7c3TGdLtKtKoWJs-DZKdNb3u(pON?0TTwh&` zm4s95iD3D7G9-x)nq$F24(&>({ebJ{2gyUGxF@#bw=e4oo4w|vfAgelnaDq6AT#u_ z5Feur1Nk}2*o|L>v%O{@`7Q~#)~lFD7)Y|1YIve%AjJb3M;~?y+Uno%u@Fne!cCYL zOhh%&bXR*!7bYi}5oLsqg-8sE?0V1-hk?vQGZe&lnfbQLmzlSU<=}Xkc{W4NF@~P{ zLmx&+-6ANpKKi({V);ey4vkh4SgnakFpElyOZ12~LP zw>BsL_@aD7o(nlC@bB`E?L+sOx36}ed0VK!b0)yTy%=&1o+sdi=G!7JH0K!*0qJH0 z9Ectd7=#aoY$15691Ll$;VJi---affb0POgSWm^*2wO+IsRQ>*VBf?o=8X&(3zG`~ zG;^{BMXvn3|6&@I$7B#f^uit0hAatL3gR1wLmw^c* zh{U;?FHPygA&?o*hn%QVpb6qjm($rh*w(!M7tQ_Q`h3B@WAShf?{=hvA;Q?1gCWHN zg52a`xMd&Ua}I{Q^|R(DXEp@c0Y6z{`ojCoXEAK}$!Vr9I!>Rmkh~H6q@4v{uC7uVMbI^{ZyEX!Mu?cjl7V&vXNRAZ5s}nw6%JR+ zlp)8y62gP2n*Y^@ki3~&bj{P9)HkIpRt>qv{yMS1Nt|pdUc(5aXY2G$PWtUg&+#3? zE$16JZaZPY4&f?aH@BP@AS3xTZb>!qm3!9GzwbL4JpKCCnozu2X+nwW(|0wOnWWw| zaVcs8UHmXHsp?t8PC-ANLnFVVSK&h=kJbZ-!FR@;j$dEa zE#rjm>;N4UcDz*=pZ1mxw1Q#K9nD6|+SB>xNog5wf9dGW0uRz1rdUa7H{*!rT z;^c&;e>h&D??Imq-~~@O=)|jz z%s2VZeP@RF&&IQ=@}E19F~ooVgb%cE8*6}noZ&ya@C*pR7bQ1!=<_25fQb&ZVk&4y zRPd}&=o+SiEJX!RVw{A!BMumM6Sx!AS48BjBuH9nbpnBy)qvrJ3|Hbm?=>qHmYtdU zjguQ0WBmV2;xN_6gz{8Z6B?{?7=r&F(A4<De+rewazSprxFthW%&p-$E+8%~S8xL5%1F>U3(rJFFb2;cj&%&_d}1OYn{^8m7eI}ugAZ; ztDRrJme=kMq7_r#CC~t`MNQBno4}EI0}p5@J)pE6na8&sZ*k&ITh+lEtpGDCb0>V_?A!~Ztw003)zg5_|G=o3woVPDu`Y5X&|8(x z6?pho4i7em%n`m%czCcJo0|Ei1$emewxDfFWC*nvLJ~}Au~xe~xxtfF2D){*G0fuyMi+y4}&0OOyJOv98<_g)QJ^sCTn+IIOnzX&x zgkXToc0arVR!IvM%%bN2Y#KI-Rw0n~9Za3w{F|&mbT`|Z5ZkTAPLDq~A*zR+9Bmb? z8`B)F6k{%jhv*12cni?&I`n!_eAtYp&pH-+{fD6qp$rB4V%=m_7lH>Lk3~=GCbN!H zEO;);6~%{Dhf}elW(i(-f$M&}HTSt{2^gWB{Hdku;U{6u2Z7+fF#r-pG&I{FS-r*_5aB6neL3&EHE5!izc z-Jcf4J7E(BAO~znAFjbqAS10ror6`c9@9mj7lQxGr$C3_Wx>LJjnbJPTkcE00Fd&J zSA*QNB8WEUGhbrr{CEAC4}t)R zwfba{L1rcwfa1X8!+DRr_6o|mWnMffkg6udbCf4iPcS(0Wp+p(bX-glmSn%Y`40Xh z{5bpK!}YBecnM~wyx_jmTr001XkVuvX#Yz6{2Hhaw}P9KlT^Y9Xi4jDjK?q;M(_xD z@%#ydLa$oOi|2S2{zxyLFUGJO0rdN*W}tf&YF`~xZr9{5Ovevy8rk|aH1pm$Uu4f_ zv<2y$!s|bJ^t_=w%TW2{^IOp#HFHDJqncb$3$u`++KcDx1)q3uu4a%I(B*yxU|=?7 z*po;x^F)9>5mb?w3Af?0$Y;-gr^H6#gBF%F<{vKkze9X!lhA(0BMX1${c~Xu`pdAk z2CoyPH!%wCW`JSZI&S3ty{efo)zx3`;Dze)diiby;7{2kG|%#Sd42zP;m6ChJjRY= zwt6Qg1)c@xq=xw9a z0!mhXI2?*YmAh~XBCVD9gS6>8-BCII<#_tEo;NTg^$OG`m1()*o>cnVp0H4=DI%G% zUC%U!CSYa9R2Dbq(>c6=D+_Jn6;$^mK2xEtkEVjp^~ADdJV*+Ur-Wz95Q0c!r@MYk zj*=%#)z2`SsZa43MDRiZkt>Ili*}qoET~l7VJc0K3<(*i1y#KBgHuJ1I8^Zx}_RFf*SU{e7FLSWC@>EsXr;~ zPixOg7#z?NjEYq|mJ-o1vp(!GDGO8Bugi45PC~y@O6NQB0y=TL)4wI?-|X9U|K>>l zx<~YH1_kQ-9!5?5*}q3k{j_;pg!L{D1w4*C+Br}BmW!eMnbDM^zYij_ynlk~<-&a& z2XbRB?nVLl#~p_^knt$;Mfo^dV7JaV14Xd<8+hywr=x21K6Y~o9_uj^ zRQMg%ESabafMJl3U@}4(z7ZiyrC3Vysfrh{1yFt=JUgI+IepQMDQF4{VFrF893OiT zuDy~SxHh3Ya+`r`18)GtpP;=@cXR$U0qys|JFlJoL!%IA7Yb+xf~z2C*9mCHIiT&R zLAy{u3t=1t;h1n8S2J97J73D4oA4xTnGtZkl->bp?&6=@{`P~_Hl5Q1yh;~>37=no0s&JKJZDi!$FhBCh@ ze1AVH624F0>cAJk_4s$C0ZG!^p~LE_=>p$-f!KiWeWzD}??G(8gzvZi%ka&|Fo7^_ zVd;&4?{Bw6z;_zb0N=}TeBcTJj{`9c-w@tvsGf}qA-O}LgZuuWSS0SoJ9sOTQh*^v zh2Xq7CXBx!_;%ka@O@!Zb@)EgBoe+^>?j}NXb=J4KfeKd+dV7rZG;sF_%=SR3Vf%5 zUHMPIw}DIG`|a12;5+W-2>1>}cLCo6$NeSvE(N>*Unq#m)Oe^ej|E>}ZGmq{ofFI5 z^=`VGkBR4Y?JgXP=^$}&{P1Pnc{qx4^meQjJac|WBByG5 zenP03ouce;7cD{uJg~7FV&g8nRrc!(m{ADMDG}>c=#IM({_@z;BWOAv2_a1{{YkHP zuh8AdL0toYQ50+mg%Ae!BL)Xjx&uGdBygPZ7^mZ}zf^cR*LyeW33X3;2NB*tS8O7X zchXBx3&;(uok8cRFpNG|eeK3`enMdw}Z=Ix(Jr0vrc^|A>eIMKzu@4T%K4=|nAMBAd zvQMRLE4h}S#MUn>;rnAZMBw``P`UsnC&WM_Peky4VEPxc#$GZ z$B-ylABKCww2g@kbWR3u8V5{`zrx|uRM$QyVZ#~S4<~8BPbN(4-JED~6Dq_+#U0}Q z$kQ*YVbOkd7&?#{J!YY(Zh;Gn0QV@+!MeGD?#Y<7&g{kks0$&4)YZ+P$`7Ot@O$IH zPhHD8+Jdni2?Pc{k%!#_p!yf1)rWp*riYXh=$UjGioT5$?EC3Um?Jm2k%}A2<2CBH zX@@J=Mlcn%MC@k3KXd<-Ifq6pj3IUi7B;85zuo$U48g+2NzyUAMAsD1{rGxJWkylO zn8a?>wE7h_-`v%FXj>(`Ohjz`GB6cX_mu{EDT5)?n?tj@8WB$tL=15aog%r0I86`! zHs3IaL<9VoZfRP@L9X6Me-S)H-&>&XZuXszOf_QP0m#J{VHQpQzxV?E@ADGv2q2Dp zJ1X*Ak~c60_!!YZJ2U`yhTDdtm40XiwLOO#Kpt*~y&8Kd+MEkycxouxwfM@K3abE30_A(r9k28%y$gQ)JrjYf33=QMDOg+p zMEmnP^shcN@67@|8>LlT7U-EsOiDub%W?yrB(ERBHx6vIONvIJW%!1$wiMO4jz={( zN=MmZD}ehBD#F1#uDtKi$eZg#Xqtl`Eq9$31)-_WlUQ~Oc>c|yf4*(;fqqG24-{aK z?!qDVTJa`CAV5D8uzf=I7M z0L4h;BVc+Z^5`0Xf)j-Pb$P1AnHnNoz!d7jY!US2){xF{eWe)zQWr(pC=WZXdV9G* zu$<31F>M|Djjq-1n23&-!Yq&eq3=&Jgy$acVytVK>_X zKPLT(hyc2(sl;3qLw7N9^fZw@WgF_m(x|8bsN>4u9Aqz+qe_ct`BG_r9t1t*ftmbv z9{+K{H<=Egv_?go=O)~cxve+GEPpbD#5HJ=_96oAIsFn>_+CRO+P6EpU_Pf8k-PnOj&>Jag*kQ489!a3 z-sew=a%Gq7i1BTT_Wc$;!H4ZGDtp4aRQnWyN$!aJbED!xV}08Y1>H!eVbFbi0pp6- zj$45rkN*GwTZCgG==T;xxa)Q7k9^%myX$ow=AKhD9p%<2)L*y`Lw^Q2Ciq@QTsL>8 zwSd7iL==NLNx;_Xp+-F4i?zMz8cpc4efNxx4g^?-*WKy!+`tvr2JRU~qfKt0*Wi8v zqnut`R-;f)&Se#M_V0YM1C(4kDZnA&aQ-<;f&wZ`zDEPC&_bTcK z>ia-4_!u2~aXzLb6TJ|s*0kbXCh5bL=_s96k?WrG2#3)#*S}W9{!Us$JjMDA6cix7 zV00UhffWK!9QkzZISF$;cJ3@%%A=yA+(j>8Mqx~fjtWla+=ic&nB1EU%RdL$7nQ=z5G!-I*5porJ> z6__Mq=fyg5_TL)ztF@SQJTvPSCUzM{Q{Wyfs7!1B#s#ov6`kv6KYpb|#Rns7`m^vl@r-ovuM zjyWd|gT*cp(mlyXbv8GDAaTK=p&6 zp)%Dcp?W{7CmVY*>i+6esr%6W!`i+m93i*gFjvUCZHp^4yr}$OMcQ|z-(b^xaW9*Q zYlhx-gt%*k~ztorM4X}3Mu!4=ZEU#^57 zZXmuBHbx3Ccj<2SMK^Ie*s|L7%FFKyMj>r`$PcOgR$|W?ivB8c$~DklsYkJ=OM#U! zThTkrdDpxg`<7^re>-Qq#Tvc8Ex%(CF8aui!CB!vbntYvW&p;%^q0QGb^^%Qmj=2o ztM{=lI6@D)orywm;X*|Av!zf}Cro2~v>K0sE?sa}B0GrJN3A)H&>1aJ(f%~nEU=j)GG$T z1A|Jr;5W$T@NYUr>*`1!xf`lc+C5|8XpDGJ@HJ$|W?9JLLv4o}6#}hq!P?-~X}7-V z`19qJS=@V--@q~o&EFubkeuYeI^_+#L_wJBmu1$ zYsLXyo9GJl%HTZlR;#rT^rnLUMfcqwBzfk?Saei`4;z}}pOVb|9t#6k-ONs&j<5&r z@~MbO^sFothgQT%WCkLWJbqs2B{w?RY>yA>3}OR&#-$+vPTgagqs2aKnEg-axH7C( zIJgR1&DJZTqtpo4_5?pqLPt5@ui_VXifmEs%0->D4_UQvNMZW^{$}12vCu$ov6ZE7 zMvk0;!LH8{uwozp4+Kx4_!_O{ zuN4?Sm)(F9cOmZw!O@UDb%}MT3hZk_6k4ZEDO+|yC^0Z3jBx~vH$5@JtHp#*F6m1o zU|(|m?u&s;WQtxa*3J5)ox!qbS(G*aW}+2hT%K@6Lvdd z&V6;6ol*+%kc&NzRm1Z(qCEPyc)4_U#dhI0k3-+Et{UHYq8TBC$hb55aThN%V}7#O%sff7(~GG3d%DyM&Fwxr1u*(6TqqYniLVm*N9y9=))M%xLW)kY)!{gAuI z&I|L({edV2izu5!u315z4qpdms9lG*_tQSduK z0}yHCJz;O)iEoh9%}&njmbuyez$~QY_4_eQVoW?L1WqP6a#GUQ^R$@s;| zkWSG3-Q}_KkhsoWbP0NuvjBg9Bwy!WjcLp~fftV8foxEpp1{I=eKhUpgtXHEM&Dhd zqx(T{vX|;<58xMr_TxuHd9SH1fg2ya@^dM)uwnaJlFX zJVmHheiHu1x(oYa1fh;m_@nf86*3j;9wJvv{zBhxvH2e`TM#!@IP#>(cR{!f8~g(O z!w%^T<3S7~O%KC8>28$5P?|s?#i3k=p)6UVhf;!Hbp76on}>&jp}mP{AjS@0l)3~< z7U-Z}_rt!+%QQ4TL#PP12lq#|5paFjTR`WY1kE*log7{Bd=1g+dz1dF%UvdrEAQeQR! z)#M{bc)g*%0g?6f)%6|fW%_?9zS(i)o3@xRikpO=&~$4G;TnZ@@&Lc~S)BTWQOE+Y z^+c?i0eY1)Am?&*2OFnPg#)*r>O_p=N3uWxSCP~1XZ)sjBWNqCLEY!zCkJi zKbLLx)1w;-E(e@dl8R#^4@)DOe28mWj(BCGZxTbS!t%m|GMs(XZKlH!1wp>`}+CF z&OCFvXXc*kKFmDxWB`w>^9Jyh0ox`dMCCUrTq){B0aS{NBpg_7O6|<_qT9-o*^7K! z)vx77M)ESKF;j617LKpt2)R9XKAj*}V7+5LZpRPVvDHZ&H$Vn^xo%Kxy}Sw8?Y-PG zDPk|x(SygTdPlb`r=l!9#DNl<{~!AD9?RxOPk#fCOmKUrl)%_cfKy{W)e`4o$1}%L z1o@8Z=zS&%7ebVK2{8{ngmB3&YZwL7&zt><&v66t;0dK>lsEeYbY_HpLRrZ?8!EEP z>Hk3Wi%orZvOb?EKG!SE4_o6Tx4)pQYBQWSC521GfmJXp&v#!2#?GUc{1f=0 zZTW2@%eJIxRx;2G-sySXBih6+L`JaP71vUsuW}ai8r_xrP?1`*g%gHmvr90`ZfGl= zLCngnOnX_<3Q2da-}TT@_#j~G4}w1rx>gaszE*`k9K>U;j{8vpjqk?RIr{Jeo}v%V zq6TC+97M)qtJ;j>Zm(k?($v>K!kAg?I9Hc0rc;o7gLYct5!(s;rQ3M~NfnO9czUBA zwL)E{XahQd7O!WE7_K-pdk2y*JeQ%h70fM7s=LruAQ#ny@Ct*LF7519(@Z;)kO9?o z*VQ?TGT9-&>tEOcV>P(@%y9~esCKMvfT0(S{Tq#O60U;K)=mx@)eSGBYLJ!<`<6!a zCCG#cCa&P<-$ zRd;x3oM)G;FBAn3-nJ*uTaH3woPy$6ZMScD3C=aE7Cm|FC*Q3b$b?!pnhiiLOC5++ z_Ygq_TZ!-%Vl8G4r@|XYz_r@E4q^4}hqB#s_e`M0`#c_ldBUs$+QmXEU- zU;*AbtnQf7DypP-4CtqZFsrGV0A~>nU6Bd0L5Q6DdK~ekEb6@#fP!@Pa?bH(rv}>L8sJqcvu1{$bt0-{(1FJ^8H@*E4)u!IXK}) zQs!bWUsh66sHxz`nGneqKi-ET>Y?4>N7&M4{dBzE)bpyT=N2TPo~x~T-h(EMdivSw z>B)L>SkHx_dRm%#uD9sXeLKyn=Nnzm-`Kve=-GD|^+XFjB0DppQpy9XP$hn%@RJQe zg^6=6E~L}gyE?n*mx36A2j?r79P4+b9TTH#=GFKCeEH+jmx-JxTLIuNe2>74(Q5tz zqF54-EyWM?MZT!yZ~ibI8pl=+IDP7+T!XEkuTH&?wOhqAjn~@k%&MSr!0in0XLJ;g zWFuF?jDzz$fNgU~4|ol-OLBboB;@!8Bsmu^p$K&Q`{Hymj&Yv`&dDgk8g7C>9xm+` znU|BkITtby`$f^^IfoDAM&oUo;tAja-Nm^1J;jsVM7rQO1wZJ}Y4Q_yru?|Rd%u&_ zlfE!C7F~jcLC1Da(C#A%Rf||5Nd9d(*M}xLb8u$WJqekE;G#z$X&}CLEq%zy_05*- zSiHEI0fcn^tZ=1X6Ga7l(cd?Ipc}XHrEf+D5OwxleX;-aSnqUNdfrvu$0@vcRLy%v zu5V}wpu&%4(fXGyI+2+kL=1i4!yMnkoXyPj_Y<06VBKHNU;N9dxL>3qg6;}nH-7wa z*DSH7OphiyyCDY)0hD5oJJTl=OzkxgA<}@|&CEf$K0kZIXXSXNH$Vn*{^CJ^iv3qK zJkU~5&tG1N1pq}8V$iBD2PdZeT>aU2p~$nGl>tT01>j?c(_4Hy;>IrXNhB-!fH%7k z+{%;6*(II{6QZ3(6CJE-D0nvYzP1crsD4b2gMoziLJIIS?x*)TM2_DU^QZZqE6LZc zCkFG5%QlH^u!*ZN8Sh;+-{v;+d!BRgOs)+am%|{xjWXEDp_6Xva5UGy4^Q<7%@S8Pn3#yIz+c^`bcTWMSp!(<)9cj*|UXLn3@nB7HD{awh ziUU|KXe1`OdsJZ>Xmnucg|YO^f{cE8@UF&BmM^<7*SDPWg>f7x38_Qn$CV?5wOOz< zxLo=`_B_xZ!`TO-w|gcA>xxX@f5DFkqJq zPOxuiq1(4e8pMr%1NR=Im?)C#Bamv8F=z35NE0*6e1|%_B+EApZYz9n0KOV)q`!Zq zwT$$K-866b;~JB6xJ`+oqMbB%)d6e7DY$?aLO`!#OJhadzMg^a(xs;PQ@IvhvwImvJ!SMoOnp z|GfwdRIfXAj{;Gw3ckgA56bnk#rFz)LC*W*o`b8vEGnvCg=o#T$1)Xi1S@CoOioQ` z7K<(iAhN$j@nkTh_$Ex?s^S%vqU{{eEfqmr<3V1D^eNZZ1P}lZHM(`C)veKpvkQG% zO1BOUv32XY0n)9HKqJr4rsjj3fokh1*!oNi;SC!E_bmngfJ(!Hebk%hatmS#7;I>v zw|JDSgt!ineYrj(Sf0_#!_k=n(ck8fE8 z&nwB4b5&hrHsTJz7z5GEQ1ePGxF~g58FbquWDVIT98XJV6|W$W+IJZ1_Vr8P zebe60Z;oE?EcybuobPT}!3z0~l*Z*8T$=6);6>VBoyBe$h63mU&DYMCL0*F&2#El! z6ijpRY`CiKn}G8~ZC;Tr`{u9VC&!s}#O?hXQ}QxmW-cxVuWZRAuS8FEi}2KBvAEk8 zBrWqwE$OMO8L45c^6?km%NH$?Z|m?hXy|o52t8CRbIarvhX^?C&}$sJVKMoa8Lpg;mPL zyc>BCLh=TBlJ%oEV4n(SZGwtlpaG^33Z$iX1Uv$Wz)$!aeEoXUOX6L{MHuDmyFt?t zy}>IkWUnYb-hRCU)5r&azNxss6br979o!=(4tN&!h#pO6QOiHcgpO$$7W~0|$VdLv zw=i6Qz{|Ygx8H;U;vkQ?fOlhXn%W41!(fe-Gf=yFVGSM{-ik%37sV(6M#^wH7nf4W zaQnm%^KO=*rOJ3{RU>E7sT6|#ao7PmoZF#~vp8CW;*^rYT@Bp6l^k(r5w3Wxa(B4E zS+xH*;}L zM8K2R0|#ZvfoI~pu)#1UcOp?We^;Ecfq5tZBPDRXZlM!?G(XPN46?WoWVn4j-3{?- znkb=qJ#2Co|AvtPBLs9A=mLf#P@Ng3Kr2*ddmLzrxB-syH02vFGL*NKcwR|%$_JqP zAm$AeKdvc$6clUVIOAyy%6{C#s)-au7WuA1c9bHDqW2>aGYbvxnK!?cO{7OnjR)XS zVG~UvH4m9o|E)N~b#0D!N1&5w9+k~Sqp0kz2|?M>3PYSIghq*PV?5{qS6%fOhbFs3 zWS4%oksnR+;r&c_OlW661}-%H?IT1xcDPJ`&y%>--v+wB<8^=2gZ=FUw`rhiANy+; z!w2PwqtvSGd&d2a@>7k%bZc&C+8t;17xD8t>@1PPul$E{IJYt6@YAv+M3vZzWb}IC z_^@7glNNNZA4WO!`o`I{^?KM&xnHL<&Uo1Uj?V*gxVcy#%tA!6h9h?bk0 z^fqQ^^gHPMmEbZngvaC-W5-igML$a%LrAOHu@dBA_KI``F4V4BW;b4G3cQc3rk2H0 zD(-UDLW%W~sYOeyiMp1HbS>8gYk7vX+!Ly0jIQMrtCkUAwe--n{0T)43+~5YEmyLZ zWM=g@?~BA`GsNYVI_fQEbWOk`wdFIMjqt7s{8ow63?cbg&3}8;J?-Zt7UqW6WwFl1 z7bp0Z67b!=u`xW=w>QSS{A1`T`HgVjdV9BLVlu$zWoDom-wjZ=ax9c#_09_IN5SKQ zUvT282r?HZja>?&*B|#HI)bG%1->P|gV44Y6eylRp@;8fq=6qE*+w5(3%bQ~rme6x z@7%uA))$KF0xt?BIE!6q&}iXHwao5uIY0tVM7Ba7oK zbmbJI|ELFdB4D_{wjgvqe(;V&vK|3^F99R4Sh^}FBF%u(?Y}7<1Ipc!B&orRZGzOv zC@lvK<@_VwolD5v9LV(SidJbZ*cbLO?i=eY-VMQ^Rd0ejN^=Cpi@WEI3w}&LZ#&Tu8FN0mkb3ab5PZ|3>c?XYK4z&&DaBShwdsa_jG$5^xr72@i-me;bj^TR~U0ChYrpiBX3xPQWHx z^9(!zt8~Fnjx+m+8RLua8ttt@&KW#;hAr$Kxi}MX`pGgTJC6rapQf8352WQBGH z;OZHJPe80WM_-W2eMaXj059qhBx#9!z_`0+qV27C9KvH9+ySnfu^YG|*a3>EH||6x z33?Z8XEl-rTmv(V7_r2pDAM9B-pmZ%VzDN@#Rr7I;uxZdxA;%Qa(oYLM^V%og@>pk zYP}@$NxXT2U_vOE6bdGrU`25nLRj%A+?&tDwf+c>W90eY+KlQe!`=@8gz9&@vU-h3 znEF!=Zs@_gU3+r;4=`^|`Z{OPl_;CtYh;3RMjk?$zHGh^3ZC)*jQ;3e!DpL|Td-zx z2#}aoQp~|a)(kx45b0j0l!wL>MJ{(_m7ET~#XA=+7%@==l{n#>#b*7B2I2?9^0OW! zj*h%`R=fn2snQR4Zgw{IvO!L9DNFe9t^!NU=I9`;P-1=#8z|*KAdSO?v=XFwWti|n zt9Ld>4)0Uo#skNrNU=!5wO9o|6)tB-qLy+ZD?CqNR2gy>_aTn@ohKmK0umEC%9g?1()7OJuRi)3iOL&u`;^8lG7^nLZ|A z@?LJigC)OL_x5cp`>-z(&6;@d=KqsyfV@UUq-@JD<9@~A7^oOArdp! z3qYf#sqra?P{p67ib$n)veXNoqX+(}8MwdyO8^Kcz2wtmY&uNej8vIPf80)36Chet z3csTpJnxz7`;Wn&>0DOWQdq*wh@OsUv?aMF#X5_APXs(HXAs9_fe$>3>i6Fc4)Ye1Pq4bO5{VFG zIwk`m=$2&m3_K=V!tIB@zzC5u#D_*T@u4VD1H?Ot1|hhW;l?>!{&*`e*J|uKqQj%| zMr$VCcGdVW!`v)Aw2WyQ9`c@W`}5v+dxyTlX95e^ONa?W7YH6Ss(}YsVqhRBB*o8C z8*sE{N^`L@WpF4@Ze(Eql z5=VDD=kMo7JHg`n5XLT{gj+;~OGGf?JHp@q;0cc({IxMwj*s1dM>)RBKu%l|Dge1@ z_+g*Q6*^@2CBGZ^#0lDrrq@;%Nlipv(Oz@XGRp%EL~kwZj+KTx;;K}?U)ct3-otrM z=uf(<@*dRMZqyX?dr-f=2>pPZs(OCFGq!l&_XADadOYNq`yJmR518@jUl=>T%Z->d zZVjn`HP1(V#HTFZsnq<=#V~YW5y>}(fYs@I7eXBm(Tj>eL*iq?ZR&I?oG0)|BZ02FT;(i_u#3*U_dTrMn z6qbhDTf6|$sIrBeBhir@?`D2Gv3rhh43^!51nf-YdVk9G76WXm)ZqmzEa4o;`5fHK zQCvQ8ZH{+CB|ehnP&+whi&!aJbEm^EN`(_w8^S)h0+r!bsK3?Qs0C-1?}7V}S#y1( z+!*N$o^@}5dpVDQDWC{80l;T^vSXl}yJoRs?`)xA3nZx9Ct*3D`6lxDE{^qzG)1+I z3+I)g&BLrNhVP9Z#Cym-AH_-FN%88rGEklJp`MTkuG~R1QunMSJvYM0!?AX=r!Yx2 z+|T6@`g&w8Az$H)km_=J158F1Ec=f$Q={X)aqZL{2N=bB13>2PRlg)+6qW| zErpF;&<3-N$sYfw@L(sz^1Q!oR^Y8fgo8`PS@awl&Gn`3?85QAG&b7@yJS!r_o`;W zd5g8>VV5b?#X!UsU7q(#u3~QHp@rSBb5v8@7a(dWx9B|+VZIe-!XYSp=qy?dojKEU z5gZyz5W-~cJlrX22&xb^9GEHkGuBP6xEfODvc@zFD&MG3PT*~z5amMp7{*FIx%sPV zfE&rc*&n@0p@Q+!>&$pEeU6jSDXljzBu{F+`QTj9o4*)`Ny97CRR@F< z&$00w;}vQkaVp($6G5V79_%BXrKm>Tb{%N^MjVJRG@V7Ca?SW0Gpq_$N&HgUYb78R z_5AuosGc<-NWF4D>gm9G9%W`)$5rtA1;i%{F3?7CaV4LPWey`p{H`fw?0kjlgvA+R zy1+2%q3E&n$z3sxVv_&x7OkdkUuV<34pLp*okCgaAyA{?VG-WBQKk6EcOY6fD5|aB z)eH?{eGBBg4Tzve=-`*3U%c;&Io^eOkVT+uFrtg2>T9TQiy^) z5a}$Q&X7Oui8p}iX#2o7po1qRQHx_vk`@%FyX6~ve>{(&WLMO!ce4Y<1PartxgTqN zF?G-AitHHJE0`PX%cDBl*}*%o19={tE^nI^74@FjnZ2PtXuYFwISZrI5R6aZa&c)n zi+iF9(}=TpAM4W%39;?e9v{J;Ph^_Ym!H$iHyuYFGEwXh0OTccAso{OUL z;iGn}KO2jPjZP)19T}s1{k>yPOUjCpU-MdmmJ0g zI?j>LAd+xiD-#|{N+mgJ>~kE%uDvMKvcKkceG4A9&PQ!R5w&YMMBMXODtex0bB6SL zFV2#UGIst2e8g8S;9Q1AFCpb=T<3V5x2Fv0f$3q}g7|~fYg(`;6@d=D9Uo3EV*6n;?G2~*<0){*? z8RIkr38LTl9i2nvUAp`%mWTV)IqO_|`I~k5r7YjVl*jhjXix-Via<2v9?!G;kddEv z=0#p@9^B3m$E!SiWjB>IbD5l~kFihERi1PQ&lCSpaO%o5EG{)3uT`0IQ}SLQfpbsr zJt!IxDOU0J(FSEU~^PbW+WD(Nv@@$Bs{AeByHsnu(k-a$kGlt% zbRAH|9j}=>@oKSH$bcz zm)-{7f3he7a})+{B2CiR{Ui(bzqHe9`<@)$#3T*QNaX6)jjg58;*aZCDyzGZ)uyc7 zzdB%bvlxL=o;03=)yyZs^?m3`y}l1Yz0It`tPfNvH=7k6U!CND8`N2y2=qcE&(w}H z+;E&6&Fc`Ke>S-!O*q6qxhvkA|6=S7WD>BN#V3I+1TnlF<#4BO8$VLBm1k-KUXvr! zDUchLp9w}w=6hXLQ*+Z-}oT$GR5V)Hy zfKv^ZR(@EG1aT_l`Ub}b`g7Tb?njYJB|&We7-IzIH!hr227(%Lm@$69g0A;%B^E%> z6x%c@At+b4@fC+mfTyQ$uoQMe;gSu~9l&i|V@wtpm*psH542@D*#xj&mHr9SfU<8T zar5gH6vVldU%5`|%MQy1_mD2Re)H#ll7Lg)lk5 zoJ&KsaD(X%)FSVk!+@iL%NK)EpOw1cuE0xsC76JyDs1k@s4sVOH=LB9Dnki({W`M_ zVj=06t?76MZy(BL%8l52?3a-3dqa2@HczH!PfXzo853s_ts7X5@qB$ajqp_fVxjz8 z;TK|`3pLaU4VC}PG=y6tp~!m=qP?Ed9`^Fm)K$}1S>IS|V^MEmHE)D9T8z_d-KAtsZ~|28m*++I{V>q|($+sfV8zZvzXWwLJ_3L&$zq@u0LCl( z$@?dL!GJ(|$_KinFz$t+;o!Kx-NrWV2e6L8I31T@+_69O%Pv$}(KnXmftqrId**Pt z4p7TC?o3kn5Q=!A0QdxrVCcX0$a5Ol;@=Cz820O&4mm1of5aNBv+9BSDLm3GW>0$?Q&)V*XX#bY( zCVVa&vy&f``AmLX_`Pzk@cUDbSd=@9_$DGo@y6DA6rHnD@qm0zG{8G`*qc1a4au=- z^GMR_cor-s${RI z^>sYh3Rf@SlwhN&*ALWg0Y}^Ya+lOco#niAToP3Bm1G*U+nP3#uZg+|cd_8b*D04_ z45g|>T}Kp_q& zsrZ+vI1T|EB*dWicozb7c4hNe)7h|IGq29P#;WiM>XkyrFQ}m{YM>sz%it55%GWgg zjl+MMroOc3SKxIitBRqh;^tD@t9W8hRge3o$6~?o($peyDEjHhY?dN7R=BY_;P&=c z?u!0@GD!`DTfps~l%e*nXW+duJiI2bY%LCq1m6co`Dm2qH5oO^$4dDr8R}&zzntaO zBov1ovV!|0!vn(?*((EH4TY=V&$Vv`>+J6SE`S4j{Y&RuEhY{L+u(Eo4=z=Hs@T*Nq;XQeOE3^?ed9cNgP2;#a`B zxD>JAQV4Cl#q7N@2KUeB^FBdb7Gmz1g@1vKRzVLz&JZ@$6=mA2Tk#Nn#rhhYD_s>nvgyyz@i<#@AWa?(G}KRvheE@aB};@aKPxIqpt<;_u$PHpk|K0Q9Osy z?Q7!ppPppncP}l}OFx!BI@kMQE>4WVYuyXvV=o$7WjW?0xAV@N z^sUY!`WyJUCXTHB`VBm7>N;?weEh~8y+d9f#ohpXyV;=Qj+i_zzE)Iygdt~##-w~5 zthwN|NE*m9e5{pW8(Poe^2@DNM!LYNb( z{cBk2;rCaPyJPviNt~2AA7B5$iLswKP(FSN5{aW?D&vE6_KVd%3@q=fxdrRH4?7Qc zCgi0b&+{J3bN1Uqm(^+9X~DJpkhTY3CM*=R#S4-+^b%D_&Pd-drG;?JR1k)nwl?4Q zGPVNd<@owxTNLb2@KT=lKt|D_g4UmU{3(`P9=akQi%X6LXgSpO} z)tn@7H_XP>=E@ye3>shaI`79}Y5bcy^(Hwr9aT8_#w_ojmCFIaS=5xczA@~%>0{#a zQ!shz2pk=57_A^B*Eb=_?HiSV{^t5dBV)_F^!<6>pV8gDfvZq!DKdd$0}~LI`oOz^ z+YsTy8}W2ev@o$ppi=X;=4{+5fgCcXg}(LeIMhtb4w z@?_Cd7`$BXCSmWt_}yFVmS8jsPFe@esf3^qYzHn`Xcxgy7(J8X zdA99a{9n(mO{ZdJ=?hv+$t`UB+L_<+9vp}m*H~G-#85n&j%S(gvlqEO_;@B@d4t1| zFq7U!KbG~WR(*NCd*V?vKR3sBEr#eX+)IZqmmIaenAHqDQAsbz)U*U@!y`Q<&P}|T zivPST@4n^U?O?EXbG?6{E|O934q8eSzb1hiM~R?fVm5}eejMnoR{wsrVV>0AI?wxO zPUr18(}<)~r{b6?)u6)3ld`mQb!>mQNe=4q*62^u!={=5$wKOAP!2i1T_F(wt+87PFRTy0SeFpOVdd1o=il6O5I zfSflGZ8TsTBFZ-BcjmAGb1wnQOhLti@xLHRo%cvp)hgB2TfxIy8qZ`81f|!0AypG= z{q7hw`&p9bcneS6o{XeuYpja5f_aEZJg+V5gY~B$<)X`mD+6C#y_!9PLdc$C64fP$ z2WbDS9DpZk(!&TbP2G(U&RQt%^T$HpsyYj~Re!KB21V^hCsCE^zmylc6{3()tH`f# z$V~g0GYZx5q%|C0TrdUkDE9+p)4AbuymU%RRIhmFjGl~oT#uca!qNW&qn3|rhg0{j zW~UFUGtnL)?iMS$N|3wI z%8K-(e?11f0uA)T^_~2J?Pej@T$v4iND6+rd#9ve_*z4(uH;@AzC||`HR79wZohWS z$C`d& z1`-{zuZ2=$)!2EYQEqa}PlOkxN{xAr`QvWmO}^4EH2`_opL$gjt%KECboA5v&3)7Bj@e1Fv9s;8X

z4?tcoVriNAU^YWG-cY+%_1%?i(9DWj^7X!SCLZ$3pmO z*$sYI>eVooRclNwj~ld*-@WQ&{`yABeSlf|?GAkQ09omczY~*7>BR7VfP%to{6c4j z@?|wncm=jQc0;3HaX5=df*`eN7M6&|^)1*KTu1E-9GPAYX4hn4E<%(Al2Ie*0WhSW zLt#_cvJy+ptu36Ul^}D=`pC5|f#CT#TehuTNhvI`7Z-hAN8p`mW zSlm|qFyNPhTCm=zn{}T*gj&F5-hh4ar`~2BFT`UU6IH#QJXVEwhx29ez_wejo-_qM zohbz_HU;iCkC*YWZ#bHOBgFp{Du)6G+fr6O?t<|(t^#;gWMdqmvGM{$p2}!AO!>wE zX}|MqYNRT#-YYkPrhR}OP}~?4FN;HV(6?u#CVLGygVS^=np>8n(^kTR%V#f}wDW|N z>?rYIx$y#C!;2NWdJFN(-#qytysB|f7acu}J_y&uRh{ttbF>P0t90-W?jb*{ULu=& zT!&zJ>rc}TT>%4k#9ZdvuiWpDl*6hJxwtMTm_-q*?lhqob(0AtsH;sVUJXR3@)b6+ zhkx+J*>#lwiglIC_~%XjdC(l@lijMg{n#xi1?<1OoUo6Lb9$q1Xky%Gr(<+}M-II9 zbq`*F)B3JWbrHE2(kJZrd^0PIfX^qPZW}%yIyoGlFGDeQeEgfW<8$Bi6UFD~$2ojq z_`j8n8lO*lj$;H=sRN(8JqUF1xGn-4hw%ByWwqdQDU>SEW5?&?;FRk4 z{P_@Istun5jN9;eE#o$Pevfe*KL3YtgU^c?u7=MoK`oZ@h7r2Y=Li~As2jWjw;!3u zE%2E5Jm(R?=dECM3?uRRNEx}lLZ#>eb4`Ko&Er;lY~k}Sk0S4Xjn8MlW$<|brGl^H zEioZ{&Nj_;0B3N@UM~SY#|jgr-X-4Hy{fTEn}sy`@T%i;1@Hv;oQC}z3!gt2EcpE8 zd%)+CIqaYvpHCuRcwARBw(xn;65w;WsAv1tDWI{1&tqCQl zWhNA_79dm~K8t1MZ_^R&<@!3%i_u#v74*-ht{bH1@C=a@`#2t5NIZ`r#zO6fRuK!W zqTp0&6ss^u)E4Bu7+eQ?Dtfc5r5?HWt|bobR~v;H_N$@OF{+Jq+ESDDHqz9LhlCy0 zVP1Knp5{}4*}xC&ghgnL!ZW5krlylo6CN!)Racge%G50;ZT|zDpDx%Wj!|nK2HmWV zx-Tx|;@!?cVGh0A&DA<8yr`XB`z?ZhNm7sXfB?N7nyfZ(2AYIqH3ipzQGh~3%DVxnyZ%ka z74s)e&BqmZY`v6q!N$R5=W**p88Xz&$4KVou)C0&!8JSMVHSy-zL7GNT~oIr4}TxV zm1dNY(k0k9Zf(5;`!SZQ-;%LtbSE3NWT-^g+gy`NNJ6eMdoGDES0~9;r=)FYvP6`$ zKgy!7Po9?}mk3i_a*A1si!Z_0g^Zm-kVeCTJQ=boLiSE}9_48l%rtSPgUopEMAZrb zfL$~7(5oCU!d_$MF)}v8vVmHnI1Ap2`RDK_F!CmJGQDJMaOEui9F!2U3P~ucj92eq zHnO1mo-2)LUEiVJx*q`Iajn1_fc(wCA_GUaT!_V_yMcKO^&}9B#?(>#$w|+Sa{5oD zfixMM7QhDxE&l>^^eb}1<>_d~DNn`U;dfoi`0rx#WMCLw7c>4tD4xhT{Uk_BWf({K zgZKey_9UnUcDrFZaR^=mx)8sAQ#v4Ftb!L6!i!4Pnyayp=5QT2_>mygzA;Q!S8d4JtJ>a_#KZe zAh2>*BQ1+KEr6UN-Xll%W65IEv}e@gYEPQA&&loGn12oo_z6<_uquPbL|D!sEMwmm zk9kuM!F?DCBj?TMTE@*}*5-G#VIH1!F6t;b-bvhvp{EO~9KY&c4{`)76GtA+@n{og z4S^1DwG;V>kpgQJFG0+bCq$zsutY2q=a`pcEGAAFOKPZ%SHE`!La&4_s}VZGBqXS> zyAV+6q5;k(fGPT18ARwL)qEyWt?i{g?k@NY0bH()oDU?jf0(JHWq1J(1g4&XV(Jty zzuP}U1G*o3v>0r7yUbxlT;Y}esk11DVk`K}jZCHh-mBtQwP7;zQHhWbn4ycSA|nP- z8Hhr84$nBwlBg*&!stscO5A{C+~|!qEFin4g0iAY-R&cD@nZ-$aJG}RfFKe{qJAK9 zp;i4{6D0!-qQIj}QY?Z`fg4&#s%rC)ZI&Q(Vztl-PR(($JZ7<+WigAJ`D+OsiEskH zFu4kuidvF&Eu~Tj>F-K9za1{3)N-7S5y#n6CNYDF16jGa+#q*Qa*CZr3R!s{NH`@OUpyrwip>#;zZ0kpP^BzWoi+iE`Lf_{IA>IKW zc;wcIdI}G+uk}rb#~S|L|`cdgZ6W%HBfxTuXYd4WvFbhf8ch6kl&5`Gh{sl{slDE`GNhXfc`-5 zklbj;__?8YQ^wB<#ed62yjdvz4dchO9QlRe13LT{OcnKltPIyahMz!~`nM=k>nh`j zo!EgptS-YsCa3ntuZBUF2_>l>CX}E$n^3%J%aF%)*Iyhie1F8X>2<*Dms0P3wMw-1 zb$I0q_2c}(x=QTLt*d;NfB1|o?tl$Y`F?0S%eFsk^9MPuK)n{!wUU+ZIC@CK=E;nD zT$M*aLpW?^q7d5{4e3JIY^hZbcNY|g-kBx-1RM1E`0?X;Nw1{g3FYOY6xH624SYDE%I(+i)aMomDOXs)s9 z#ZF{i;~0ts{57FHYJu$+B}ffJO?>f&sQEXckNS~?n%iLzs_hS;b)aUUkfu>HfzS!9 zSwm(gmeUV3G)Y!FUgjoFAT|Ns;7hf@l6p5N2T~@fA=pN=(FCOAPO7tLJgT;kGG(Yb<&P6`sIwqZGQ+BlcQ z$#VW$QzjASnlHJib^|06bQOin$;5|EVnl_zz$7Mf(lUY|3Cu*vVW#m?sj4=ezdLdX zJa*OaxNNcw9)tU{0IS;e9~Na2ALl?~5g#9s-@VF535IwN+zbuQ|M_KWr2!77ju$wb zg{6j%m|&soV``+WgguaL;?E7@A;%@~We5)!0(1lqq0U#SR4{e`o}v&Q?qvQ8?0EQh z1~4o)gm0&Uemg$?#dI4!?q=MEj~_Emd;~DR>{#s-+3VC?`W6*L8nzyoiS@UIHF|AocE7Z&Q&p z*jF1KZiLjR3lEJx*$?#^eNs+jhz{6U1LOC&9CpSJ|o23Z)}eex2M2yCpW zPj)pmm$7Ex^aB1`I4uzZYGdRQsN^?v;JA2sd^l8Q;c4x9q`!A!=zcJD8{`)8@<#dH ztFECOLww8294Y9Nm+%3=Ax0he6d`>7Wv;c30HM9d3WVljQAXuI2nc~(6g{)+lj8tVA${_X_Vw$ND|!L*dWZ1yQ^sw0xr}ieUe05jcxn6=GZ;7etM`b7i=mW!Q}{@bgnqV(j=?1oZSyT7Ucr1gx$Cv ztNFQ|F$@P5BT5`@JV;_9|Q<#15(J$bsa52~pg=in-z+SQ0 z2R}U|31P8fQ{XbvxO&SA6yJPu%zHis4$X! z@a$QTf}>|zQZQs66t^N2+3bS=48ov&@a|-!hNMiFti;;vgC!`YmVjsf&+UUA_)LtA zrik{zskmpGcycxg`e*Hfty69DQqw+IL~N_qKA0uBYOxQ-n#73q!BCSJ(LP8sjZ-90 z=#}x;5_%G$&^rye?Dj#^yD{UIxBf)zgW0LF|6Qo%-8lKh{x^P!YzuLO11s(0Io9fc zaJvpCjcNa5scHLQ6H_DE2kU@sb=wDz6x!{BI52j7_QAL3Lnh^hjN9bh z8pdt%?hVE%?*LWH88-I8hp;nLKH(G!Jj0_920s4^%nr8?+G2^4AI}tfmG(h%6N*<2 zO(<3!5s5+tVLwA2SDygKi}LN+ry$>6y^ruUA(S2%S(jJo5 zYRI<_xh3LnzU7XPeEYaNO8Q;j%z=FKfjJ_|w}(-#F8MZ==_e@Pu6V*)bwT-dba$A1 ztNal>6)xX0QAqq>C1LWdsjV){|8;sb`S#=Eb;`HBch`__HvtOR*o=E^I0~%VNv!fl z^nU>oEcvz`6-JV8E8^(?qIn*6a25Wq7HGyU-7z_X)OnsVU#K5!>pOZ}TNrE%NPQlNeFH6_~_`@@<%D zyl(l{9l7lC?SWe{phLz|n_8 zRT(%;a9VJ91zl=>#}~{~ySl&q_8M?F^kxl*Q;0-ZSDOigb;98g=(H9bzKaSY!QuQ^ zz~Q~LwyVM6W2c}QI~@K+3(SJU4P%fR2@ZK*FXuJ59q<8)sSoZ%>ve7ioc;fQJ0R<> zFq(pJIKj3Z(Ec?IhiN3J7C8Kv9v*Ct$^iRLcspRvINQ9`gv0f;x9Ww%GRaj79C}P* zL^!95AeX>lH|^t^HPQ};q4&dT-w$}PGx5*|xkUe#M}GIJ zN%%$dQN10oW0ti#0Ec6)6F4lyN{h;W3BIiFm>LNVKZgL*`0O%`o`5j$FnTN=h2i0OSfe5Pllp!eu|#>`sD%l|swO5BqpE=Uz{AUSaKNbV zzcmwhxK!%hubvmByly;PjvB)8Q2Vp8QBeeaf6v)k-|tBl()#`+wsu1LehSF6^!=}4 z4^b-qVz9elcu3#>(xiQgH1)W4eO5}$wbYigzNx$poS9zTe7Lml1G%a6UTBpLNJrr+_;=vW9@m2Ntlgr|+}@X`KRYEHJ?maG#^XNCIwC z69~8`X>L~&aEltF8M}aM3ClJp;P#FV6DD11_h%_sZc2e?>lSeTz<&3Qqrzwk3OM_I zcji1T;I1S=wFtQX$Nla`ci85orhwZ+gR5Qvw^DM|BH-ql#E1f}*d#_2aHCA)bqlzQ zk;|^{H@yxs{@>{P>)KPky^evPe48h~d(|8c4C2P0b*#i%X%KL;hKYcC?hE2I_q+dQ zY9s;o2e7SfeSggzc6~n^j9s6;e+uZe%eQun_YV2Dnlf&aZ@;xe+$P_?Vcf{KUl=y> z?Jw93>IK57-?fk7ClH2wYj+zSg~_+eutX`}`iuQZ`Q|dAc-6y%VpV4oicxJDg8%Px zOTKNI4*B+_)Qj^!H0$c|XYGJ=3YTx;`o7ukz5?~uw%>j5GYyPpzx(@bHGnZqN*`7u z0Q}VaGqmO(jmMS|VfMQ_HMD@y?04^YzyijI``zD;umfW`6TRxhj}?rdX2NcoR~? zRR7xcyEmbj+H?b2|6lHRyKW4l4=7pl{ABBAHA<$CxPN%Rd&e!dS&FdVy_}X9X0hDN z;%5F@y0}E>dVk#HDr9Pe^ONHxy_Ws%t4(5tmT#!sc7D=jYA$2V5U&gPYqc*Cwtpsa z2~?W>?!!3ZZHLOb_q(5IW8d$d1i3}L94Ei<|5J`3?&0?rx!-*?AIN@p)Ix-C6`;pj zM}W}WAp)WQ#-h~w-S06q(th`UAoS|k@Ad$sLi^nguz!8$CpVo1%(LO;F2-$m`61&r zyj;jQ@zU&fKh3z=?|zeEv){c8c80p?My?FkTMQ3F82GtMloN|!!uJiC^4Q(IHydU`aQG30UW|H#760aJjVS6z>%81YPMr}gNc!%@Qt;OFO)Ysb&A z8^ZAO1`-pFpG%}P-uH!=w&CYAJg$bHFa22!KZi3&rBLHY9SL7=CUC zt62JHZ`2qGKhOUQ_*n(bzB+!k#tm>``sdURHvG)H8dRJRehxq}HDDN8|6k%KzeZ-G zFCu=W`vgj*-*n zUzx;+__%-5-k;{&sFJJcG;Afi_cKkew5g~s5Cck@CB}WMHhLr|Czmg&2af*cP zc;t7aPqfw%@bhE0;O93L7Jl|(Y9##Z4q06Xel`S1h48cZNd5RZ;51;K4L`4E+=ic* zFmA)o9*o=Y^DM>@~SjfcB>G;+7ImLvM z)HoALP@_#KUR}qK$2EVwg`cNP0DiWlo`4aLrWRWdezrjk;rOZj(=Uz(VAi~UAp2D9 zpMH#NrTx=ivll1ipMD5rTK?%?|02ljS9wy=ezmP%$UmKK(o&G7nhg^FboS+#&1&Z@ zpC8K6vi#ExO-(-3gqp2GBEQ2pQhP;G?N@g(&G@JL4hG#PUC2NEE~+ElvrUa{ zNVhqQnL@1tX%kIaw6s>kKYbzHD>!e7^Xb;*1HEHW((lTh2>w^82hCumCK1crI#;Bo7nuS$ehqrke8bIe}v~T>5utPhK%xX=Waa0_iM&l>j?7j{Y*UbxIQkoRNp zU`ht@^LSnuKGlJrf1d%)`1?|{{=c**?#Kg*>U&zZy zFQ@dwENMjskzLwzrfzUMA&|R1L z{M>kw9Y0^kh!8*L$uIW*I6{ao{MO*-gEC~q&kVY_{f@xx);a=yP6mJh5@x)YZ2U2m zOpSz}-$NYMfu9QjQX%|I1^d_M&;Hv1%(LO=spyv-KmTI74L^4?Zo|)y88`U3gJFZ8 zKf$(8kLGe^xV~k$1YzLksiNxG?TJ2E$i&YJ#PTJ6b~T|S)xm@kR7(?zS5Ag-{%;uv zOWuFI4fy$i)Qj_fqG8vKpBo`%>cUU!{2%JIpw7JSQ@L2frnwK`>!qL}95z!>h??M4 z&<+Tj=01SGZVlCC&PTM}Yr&?u58!j=5!gJA^Jz8i1Nb7#4x40Sb@@daHYXFXu;4Zu zhTq9wZ>00kgJDousJR#w8q_S60&=i9M!ltgniHX2XfI6YeV^GsYSbL40mYws1eTUT z&3IMe4nrlNW^M2LY(O!!p&xnU|M)(DzWu{!0#YtPPs8s6Xm`Ix$_q%)KYKpnhf8hq zQuBPoI?-+GyAR+w$yLkwi2F@q#Pbm&O=86J5pL7COg%ulj4WV*v_uG!?U74B(%c8I z8b{gfN@fvCp(IdY&|3?Xicn|uk{f=*Lu~rAb@U9C445wnL>GKia zGBwiqh;5K|ADdVJ0Gzx3K*6f+OLZS{dRo(iRm`|atq@&e0-mA z;v;ZxBg5ADzvkfiqW$ngGZTtjwKm@Cq18e1SZdy9Pfyg&1+LOgB8_+K6aRtM_to3Ob#VN0VWTSWx?{+eSir;z7O7` zcTQdiCugEYgOdwbQlFMcQV;9~P7Z<=p>cAcNk~?A?9w=in@#k6fS&a zAMi96s3e6hP_gcDU(XqJE9b>w^Z_%sqa|n2JhWlmq4LXQjhPKe96Fi6OH^c7ZI`GV z;+bI(s-J73WPn4rO^Kwfc8SV-eB&!POR&z(6)3@}nI#%+HDPA~*G>)!fortMC8LB| zGW10%GAK;Xk#wRe7@?4*tSThJES*f2h}hc1)W3j5QAN4E3W>0a-B^VJp944+{!4brkZocaU{X?voW>e(Bu*N3#xEE+`L zNJuN!=siI=&{tK}jTFhm|52D4(nG$Ia*I`5*?0{$}tebn{*4zP*u$ z1^>WL#J#@cEAUq@;V<|l5ALx5Fi9Q}0RLq|@#=JhxYXaD!GU%Z47ZpbKp4|ifG{4* z2g2=MXlz&med$g zYRvn1r-EaX~2d0$@(Y4%FnrbkukeSTuZBigydn}O-%k_J; z-&Oi4ZdbF>7xYaQqYX=YoIh4;kL!AZxY~S^+l}_P(?*mGc}RPVbXV!!#8hjRfO*yL zDjg&mYkj`SE+$tY8%HhG?TjLJJ#wBM zGfM$cTtkuYGW8(wvb9Ugkrwic@BiSJD|gLK3oeg{>~Y*M%vv&l#6Qj!NOWNRMdi+@Be@~3fvCj(Zx9E`ErE?8y|4=qNc6%734?Fqjl4jiz@YXQpq%Y~(sP3NN!{&N zU|R2x{XLCw8(!YZxD79dFmA)k-i#A3QCA+r#vgh0-yNbfX z`c_~j^@-}3dGyn2n0ejt4ghCyXyQJ_^TRNyOYQsN-B3(*>yFmz!_0s3e&=VphtU_r zO#A)LlkU)%`A`aos|_>%AMbZ|5wq*S%r;bvkzP(T#4K*+uVpSvgtqQsay)VsGBpBb zej(|#VCFKD7!fm{F*TR5X0*S6zgGJaVf*8eOEA;CpD_L$J7!vXW^K56{O1m~`}n@b zh)}cHBENgpM;sx7o6ckz0VHw*yDR@iXjx=WghS9X~S}x8dhGjN9-jSJXVRg z!O!MQGx*u+2v){gSsAWV7+!)f@H11?8#{j9g@sJ~yoFk*;OB4?!u`A^l%R4np z$m5z-#?c~v?i&RBJRi-}U!7HSlv1zNAEbeO?dS%B&kdCqTAY`1uWL zjD(+CHvvDNgKkkBKi~Vf8h*C@(}thFbORNUbj}+0sjgGk&zjGxC-Y_k+W=iDKBZhiRquE|wMbc=wWk4t(j_<65MjEJAZP0eMjxmNtV z0J-e=d0EH*20xeYwd3a;NHpT-Bl3&;Zz$mq@B6vI&wKd*;DGx~2P5Qne3@shBLL{_ zZ3I9kKTSyBeWqVCH4=b+260%&e)v3qR0uyig8l2m&wW1v^KANOH2P)7&!3oX!_O^@ z+wk*!#tnXMWZ2;6SHEFp6m{jwaBX6E0>Z%0Xi;_S_<0@{GV$|lDyxE@ZA>UhwJ@Os z)x?D2RTWJ4aS_4uU(=EJHZaGcP(j!LZGu^x}Dx?(i6R^r69hF1BmiQh4o zc|7*ZEMpb1g+Ch zV@(%jhMM>Rpfw9BNVtpAtwvPXT$FCSI=dDYT5zlA;m+j#(8r;$RU7weC_|dM`&^QF zIgCkuI*NR8R}!9t&^Wk1^B4xevas`R)M$6(+2o;IbV|NcV(rD~`}RLK7PgFlG5e*@ zAqzXw{*04oYYiN5%6w)wI9mHfL#@v@`GLt*YKFgzzm`rX5$bgFBv+jt%0iPRqKEQE z)5-$VO1ZriiLezHatZQfa76rZcO=-5Pxc*Z|Nhjv?`dzpjxizL&68i8|KS)RKIBv4 z9bwKZqel1SR1=C<1tyfBD)W%v@7U_LI36H)OT2*Kcq|_{C~?6#KePK8b65^a`)Ci4wSQ{;v|hl;+Mq7oDZwMSXt!hUij5mmtsQ6 z>TDBoE3QALW~dend0aO>hA|Ocadm%S-A1;7(OyJN5?Ci6k(Ft$}y^oYLvmM$CC=(t;(k-@Wx=4RL0_d+ltH7p^_FLLoMOF`$+Z zXZE{y_Y2i^vxc~sH5SB~{qB{_BM`^dYCv3hLJf#>wbBqblHg*kR2#%41Q%Lx(O%ds z1aZ%z#+nd^@87Kj#9a?9AspiH{kzpRhy#M9?)oJNarpjSBB%)ARhQcLyBDCCTF@S? zLwhXaQZ-*!f^+o$Zoj*2hcNnrcxvD8K0aLIX$ukuG*0*j_q$h~ZJQDotVk*nAO)>QvlKSEd)fn zV}VBHmjFN?VrnD+ErF=CzNZ<)Pcor>zk3J}Oz>0oySJ?Ye%7fuLYw{lHsdz^ z@hQe_`lE+&>W^l>`*z07e$Nz!&3^ZT0j!ntJ8-SI?qfI!Vc_lCqMz9H$?t&q#Mm#W zd}5&7YNH9IsWm2)td^QklA6zu$5mCzA)`Hh?Zv>@(Vg%VGcbsHC!n-0f94&i;l%aH zMv3}sb+VOWQzv=0XicUym(HRKs1^Dgqx>3clNj~5hLOy0tbGfGh_# z^xy=~7A#@d(90&%rr?O*?Iy6cekwpogRwLL^%t`BRQn_Q)} zVC^qlD;VrC)a(nH$x>`3LY4DFlO-b7zA1_IoeQ0gT(>2elIp_{{GUDxZ};`4|5NIP|C27)dhqr*`0>Q?mS>BC=Qj=B z0(%oNg_omcOSRp=W$$wwnXch>DWe`&;K3Sj+Xsb+fVV(HAlz1HD2=hz)kMHFwd)cK zZbfhQJAUY8!R=?LzJ_YMC$0wE-r&@5`yia&k>ECh^?n@$qXoBXP-9KF%~0>b=dK=r z@)8cWZZ-E^8{E=*KWTRmZj;s4mY|}V^5e>IK1U%W~DrMssfHMACASV%m+@5x% zzfK%nZL&nf!51a5J{+8iTz0?ZVZNt)!sm+|TLk|wDuRFV3;g3K0skIZMf{`v{(+1e zf$zK5^s{)i2+xq1sLnkP+5L{VbZhwl0bhv`1YCmk6Fgs(+JZSEpNk~5q;-TPM zXn$O7K{mm|mBhoL;M%|W0!^OP|j4S41}<)6hM z)pnk8kQBrF^T1r9ojFh03Xd)1H0LS%EF{|T!}VTsp7M{L7TiTVPkAVogBf<7a$Hlw z-F`KPKx3_1tT(aS0ooDHQ;zvp2=2C`#+q=Kq&|KJaQ8U$hj6${Rtx`QgS%wF-I?D8 z(JVpjIUQ7lu&YbZlCN=|@<&*4>c`X2dVSjEKY5;VXbUdGxPb!*pK_kE$C-LvUqjTj z#t*1h{XAta3U;J#Hh8wvj%N}fp2eA5rA&=rWB(xQ;H?rBzQ{Du=t#+RB zqK&{Ro4z-Qahtw(A>%fEuLI*YeXkkgM&E10usKgT`V2C!tHW1d-A|E9KpS&J%D?0lu`a_c&BSz8r_@XU7kelm!Be6sta8CoN6C?t_v`f(31Qp*wzC&NJ+9_efRf3ubtfN|BE^#GRW%jO1u4=V=-PE+BeZ zqX={xq0gKLhwe;Df21D}QjH9MYvJPy=2?Pjbv_4^FYlF_XUVGPwfb3_nv7=@>xpo{yMA6OAbh(H&R~nQPk*FUOz+wuS8JM~GzU z*-=ivj|$}J;Pk*WghJ=j_f>@BWi4 zr;^cKTegDfr<{VYca7E~&qfE_-W@6pE0ZEA8NVF4QL2*(4OC~DkXxN*LK!NCA^86$ zV_XDM-|Y%WUCm}NvaeCm)R4NS5?eRxD&;`>0)|%d&(o&aRp9E%cSE8`&WY8rA5^P8 z8IR`mK2iAlIZGyl>65Qa0=+hUG8)Cm3Z0=_5HUZ{VEEy=77I9wn&J`OP1yfRP@gDHnL$^idy3rL7%Lo>WlQc!D*ezRZ8fJpijOi>2;#u{U%F9eR8C! ze*x=<+#(tTu~s64$Uewrx1X!<#%gr0{{tIUa%@(6VgJz{%8Cw6t{TDA%|AXS7(Ja{{#H!iw zOzU?#;L?kQ@^=Krlu5!y$pU#`XD}f8hHd zeQ~3?jV5>-sU%jr|DuofHeNu2{^9#C;F=H4ON9F`sQhBu7RV6PhELB)E}|eH(rk|F zK?8W*ZxSQppGi#Sq-7BKrwEq~k`(La< zpD$|2KJWd6;Ry(H{o~X(poRx}H}rK?w)@`~(B^sL10Jde8Y{arEYAF+5FiYKzQI z#fb4NxKSgsoY8>y<(p7Vjm+GVm3&1z>+jYYnI{9+MCO;;x?7E8Th?(JncJSR$du=~ zA;p?8+5+^eE1z*JKswATKMXT7Q$3Qv{%<|%acwbDQ~nhZ$W}KW%4)g~P{v}9 z{b;0ph3iTxavvdIaJEL;h`&+WU@Z?&zBiWQ4i5Z-e}Ixqq}ql9kz$uW?x2+#tBWjG zDtIm$U2BX~sU*}!pBF@`P6KeV5s3@H5#}s&%~{I%YwIEr*5w>XIS-Qiv0Xwb>3jpg zlFs^vwcCM97DlcAMkA4TkH|09f8&>rkB4)W1k&%6M&#sT=a;SXe2qy#2(CAK?!RQx~m}Vc(l4fPG7N4z%(tT8k*Z z?&m2>p(Fl>=P9xKQ>5a|@t&tFxHj7Vy&hF{{a-l@{x29z_?hP^YmT?~KB>q&PpO&_ z_J7UulvxxK`o(>o^5SmNFY0+po8NT5>__g{LF~{k&hwNsPlSF&D6uB}($!s0(*K32 z5KX^KHGGCcKfo<(^@=e4;Q#KALRrVK|6AjE%40Z8J+>ETuh0MeC!eQyupK}B->iuL zi|?3lTpvjY+xCm+|B5YHum5YLN{OX-{;%ZMiNAY{NL>6~ZOWg^@^P1ics1~ME~MP& zDSdZ3;M3n1t;_$NC;l(mL;PR13)<&NX&?B%7thpqga0c@MBXzGSmg10F&yr>eFS(L zTG&nx;EmcMz?*>K1K^qcDL$u!1)e+aw+5On;?#woAD7|E-RCKffH=B&j@QFCx_CC`D@f0ec&xM%&~Z$bO` zesKK#DblF{Vc8Xkg^W6i0A8bp(S+zpdKz`#3dH5Z5_k_V2f8VftO5gesjcz zqYYSryRKgT-KC!-wZnbk+4_?^xEeiaU!;;zC)gmWBbCsiy6Mfa5Y3wUs?4w$0NpT&f~+6GS6moO?Cgq@}CD z2oa6zTL>B#rPvVxH1_{l&^QcZ3uwGXY{85Ll$gAN^~2qXRI&1Ps7*7@!(5z;CaA>j zxYi!L6GYNnoJoW5z@y;e3^51`A&KVje)$?$=GcFgj63$9V!-!$Eto6VU5CM2t>vo&2)m4|5|&yC4;P=TclV4r~)O)x_Bevo6C zYfVhor@jWNHgabcR+{bLSn*!Ya3aFs?Nl*h-1)|(U_Uj@d|IVwF~54%gtFC4 z6UtOGOekGF#8ANd{V=u|=Nr#S0%LP_A{BR_Gc8jvwyycc{wSfY`NnAb(^=0$i&KnE zSf7OwHp_Wvmjb_Cad%6PCP~d=9$E7f#B0O37?Q=+NkwbKs`9iMqJg}a(SWz9TniWQ z+>E1n8Bf3(AcyynK_O2!CY$HlXG&5=0ak*W1w6yF(6JN}5X)K@Y!^vNX`UoX7xoSyI3xkZHnpofYvz1YOR(VYSXmUDwhqb6^%rL zHc>>9t+BewmzpbK;AA(yinf2|3F&k1z?_A%utHAPFUUn#D7nj~gW+e4a27mkz3D6MTBke{&zV?Xq$A2NmpFC4)2B5iXU7AsMNZ(Do_rW~9oMNl@sqT;<)X#MHO7 zPd8HO%etLu1nXt!;Fb4B*{5f`0QNcdXb$6!J$gFhjy>9vaoVHCK5fYO7n+?Z41a(y zczGp_9jyO;0|;HY1!22xr>XSGZ&e`%B>VOR8n3wPK6RrB<*N}Ul&6N6kYD976!4bi zqj3bE)kgrIjc7QaIe(`C3w%aRSuS^9;Wno|0>x~dAK!oHS}r>1WBFS$4jW8jK_vY5 zIc5!H@3xu9EtOoj?{w@*Q$VvjZsmoj4*{CS)sR!9C;@1?0Mz*PKMsuY>p#1cS3`hy z#?ibG+8YGuUd_gRiMD^37a2ntCt_u}0qA8~Xaj|!0Lp$4UIF>#k1jxWVC<;@Sb4>> z-O2CS;4&!BL7v86Ttj|%bV>?GXCCyR1?W7KXaKs7L)or?oO3S#dK+vN4baF6$VZBB z9+Y27X~AG9>koK-=EywtK0gr=p~Qid*I?)kG>p7s`8&u2iUXaEYf)N1%%yP zIfs4}-iC*U)BfL9Kz90>*O1a7jZBsmkc}&mf>z8T%55vcMl@>|!%dgMQHXptJzF7x zt!(ip5jJp@*uaq$kY*jFzCPrCYVxHGQA!z0v!zIcrMx0ib=sr%nu6A`02EZ=79dI%u`^gj8mR##+dfZm2UlJoc|9Q*%x>;M5kuiqd5y$gd30KHrT^xu?-x90H^ zXjMH=8}{$Z(G->6NBsLINiN~%qvU5R^zTZpfHeF7;C4L&<~jU40@v;G^LOSu{M^X6 z!_O6r8-8wJ*zoftSUo6y<7{;G;-3+={Iu&HeHf4AXEtqB@N<+p&4lt)TNCoD7AE9V z$qWU&1q0AF!q24*!Ot~34O;U}8mHRDuY29&hv>_-@zc*v5;ifz_9r$iWd^V!>&XR; zbo|N5xh6-}las8*1fA1%fyv2ciPI&A#wbehA>m~tAef6D@b5!y4@fH7D5&t;zJ_WkU`D&orlq%Y~^K3nzssd$*?S7zznxPnLu^LQ7JX zLs*Ud)}^c@{raV*YzpCq@t?*^!hp-nzDK7 zyvd+!6I_8dVGGe`4M+1;he?E#fdfDbLo_Q0*UtzPsKNZkL=@?4r?S-i1F5S_o#t6BxMIyXYJ|k6Vq)J^WiBPJAk*Y9KJ6tJ=Q0fniLb5hjSbK+5 zG-b@!Z4yep0&VZ{H&|C)A@u@9ZDU=_pUFN0Kw}wp=9;<6lV&)l zUc^ZFiz6YH!wWEC$>F(F6==x`>O~VOP*0gqzIxb%^3)WD0^YCsqgjN*XI5t>sGgfx zbd~BrEB9bH+ylk@H|x)1=UV}te1oAh+_{JU2JVcbZuVb0^L!0av;W#DtZ?+?>qH#H zUN8%$0%^KZgYrD5tVASX^7Xnq?BuK2f2}oT1g3HKUu*Lf8`ZAaWN%Pq>vfm=ph7cX zhZ#{Mt=27eh)N2F)zj!T7N!kQV$I1{pW1sTV7da%iZ)sCOlUPr^Q(&6ah{NweB}b9 z-tY`fZl*fsKg_iTtzLlCJ|d8$1fgOmt)!}Fo;{%dPf$h>N`>1)&$ z4nLj_61e}!{%a2rtJVqy_F@+xjiEt}e6}_(t%AR{O(nuM%`sA?Mykw}k_e^Rh*X_c zXo3-mJ1e@0!vS@fYtB;co<$-&%MwTlF@2htgT8RAQ^U*DT6o##QS!1QIurTTMt(P| zmh4>QTR@{SQ5_-OjqZN6v>(@>|7k*L>Z5kTy@C7f=mGaOuMzI;&dDVA%>HW^QzG8% zXbzZC|Nd)DE6n`pGUD%1^jW+A+O5;Ts;+>m;amyh&hw_58F%c{p^Q8JeQ(BTp8|4& z7&hyTo}=**@(z6t-1BTi7*LA5zr7qIi~V#lxeVxKt2az2Q@vzDei?tv^{Gdg7VvKJ zqfG>QJ@)~6{l8^vyi1CzQZGQu6M)+^ z0Q)f6z_f!TWsDw=B>mdrg<2?$LPEgbS#0dA=SiQt=41u>zj_Ahip{lZqaMhbb9K&o zK8b!~30VCZTRC>tGf(Zl6$E@A7KkQbLD-i3ZXC`75ESC%L>X<#bIZaI^r^=3#R+R{ zVqOzgTib|$Uv2xEH67SCj}Y`zOK#bKlqd-5Sx;^gVrM-+NY=BS-+h4!*EZ|Pkt3 zQhPWEFh~ltvcb8WSLSZ+mI3tO2-eST>WWH4svWn%&mys=q+{UJ6lTEqS@HQ zgp$?aCX}j{+^wmYrgowkQRh?D`DXEDrm8?vZ}iT5OobB->m?L6mn3_D_w#ksATVk#wR7sI`tEs zf>Oc6+)zgEvEju^XK70A+i5AO7plj+s6RT9&mwKe{Fr!aKJgy<~ zY)Dc#1jj?aSxSD55^LIt>1zE=pyX39IHK*uOtoMP&SULF=$EWkPlgehrnc|{6A|8Z z3_qm*iqJ=Q2*0Yh6%L%*`YFy1U%N~yUCT!s596V*2}>zt7NE-kVPE^;UsW8kj~0TVG^$FmuC z_}GSVhmS`wPClZn;~D1jbMWw5*eytE^Ei6*+I1XD?z*HPMjAcF04++ijbGhvLfHSp zgs}gG31R;WhOqy|IcOAtVWS;@VG0ccwEkbTDp9^&ubBbq`0JA5KkuP$KzlI{zv3V3 z_pkwpRNS3ORrc;A6`A!&ZM$jEne|A`SgmN6cr*^;1wIVjPu7|BNL`$=Mhfe)@~^Wl z@q-$5Nt6+TkY}s$PEPWNY`Q3yIP|`DiQgt<>`;Z#Vo{eCwp_xa_Wmy;sN4Pln@ z70Is?sP`I?xIn$ulrKF3eW{%1u?Db2i0xjG5}=y(NNrX+Ks~7SNGpr!f6qpnP+8BE zU+jO*HbVTZVHT$)NC7CCsfxX9K7#dbDaX4*Uf1In2(&PE#PiIBh zo1tu80sZl9l`N`CHG|dR_~UOg+4$of1-2RAT#ckCf4r1Jg5RCAuVVf2sms~AQLB)S zUV=V{vz>*6EKQxjus5F(@&fKYqSYrM03$Dg_FeD4nS*<_*I@~t{ zZl9VcpNxq1$EQUE{OYnbtf}jd4_Sqj2(-hikX(N}yMgw{FIdTrRm&=*|Ir`cCpD_w zAOD61G1|6**Nki5!C#9bi4aHgj8vJCn(InQgi;S0sX`-F>Pkt3Qlmtw7Js~-DWcpI zvCb_*A}pdEq+Eaec)Yw4erj&!C2RA?UoCX)%^-CapqHp7n-JE&n^3CC7^5kP_3tJv zUEQ9q(=yeCNTWmk64t?z3+GCFx0)|g*PgOp?4STXySyX#?1g~^;}h^jN6UDI67d}J zN1+{~-ye_l$A=SG5r6!rkv07B_a=dHj=i~_afgqK7p``^!g*2owW0prO1H2+MQ->A;Nkh z)7g&A2Tl3*Pc%yTG{Hbno{I-PgEBQomk@XXZ=Wu_L~`^69Kfsl7;2szZKxlU-@s&3 z#Ce*d4;LUwbCm1saWX%Jgri4GLddav=oYvmnxl3xQh_?G0OvvZrIZE@3*fY012@kc zIZ9>8cPY$+U(8&Ng3Fj25y(@`RnVs z^HNc`!5$Waw!S4u*Bhz1Y#FprIe#r}CBnu(&qzu8L8{D^k_e^JM5<0h^e+w~+;F*V zD5%0MNFprg-;ffT-YoqhW%DA3rs4N2Id077?|C09VF26t&O=Ey;VV~js-i2w*FuCM>yj?N159*ydK2Rg zPlqt>@U$1>~W`QS9Pi}3Z73h?#x6)d_+wV=6rFnsNd0{{Qw>!9!B^YzaT zQGES5gO^CY_QnCcy6a&mIDBo)O0J`_n&d{y5uB^!MxE?+Ab)ZpvLH#J`$B%=nwy+4|-hu`b)b;G+_U@phI;p;Z|O9sGsYTi=T z)aC1&i;+?fUrTpszP`AKJ@238>&4})QSE%?cxC<$UJ|Z7fvmFRln7CFl#!APhg3PG zt&~J4^$Ytx$|^NwmAO(9p;Wm@)ydbVO+o8SK^1O65@A8NLCWRpvwUwMyv9@PJcFos zeEn;@%h!$4Oyui&6G~RAO(<1O9AWwTmPt!jC5NGN0u!0)S)>VHcX3%QLO%5XlE~Me zkV3xRCGp*O9|95~&$k=xcmZF>&KABFV$4POx{(s``1;w>I{7-2WQ*{%ExLLPU;iEl zCOUj=f_8BEx{vt|UpF!C@bzQH4PU=y*zmPIt(lN_(`4{9v>4%7zWOmV$yXm$fbjJU z6B?yXHK794+Jy2|DnkM9sP8PHI_#F~=;es$HQfNKUUpXf<|Je4zuT|Y7jfJwZp zf5B%Ao4pg{%M+1F06eu%c_<>_QO zxJcD932>e%qTCd*&MiVBEFuk3kynvMvSmUkL+83|<@$M!nRr~CHJ0-;`p>dk3MwqlTb%$T4rK>!o30Ge-Yc$VA0(Z@vkLfBtqUeM;hDjox(_@%T z{n8E(u(a)q!qTo7Vqobd+E#st67i-3?uEXMSw~Orr4nSf_UZtVOnCY@?bRqnP@5N}q;2 z9m`*rr(~t9c|;}=%IVYa_UvG2R~|)%3Q#$PI^7(Rja&WV7coR#tBHDEnkMRdj0U`C zwBZ$!sE^_RUfdE`3M8sWPX}DikcT8q)KQwKXHlqjbM@@kT%zv4NK*4((nS59 zRKlniPZ;Al&0Io3cu-3U$J#t}FKe!*qQsi!D&Bv%7)0F&?_nc?ZrB|gk!{Bj*m zq)(4d$!u=CS?})bkIdyYq&&Elkd}9oZkmS_+_M>PdQiVL>Y(B_`___K8qR ztJw}#v42|~_Gn^fB8pA5EqZD`W4KYK6B*BxkB-1x4luUQS6 zt-eJPpJt^r=Wf~6YAxd2y{?bU%X>~+Z^sJ|yR1wQyZ*#XBDSAK?5UK9XRfw^)^+!# zD@U_bejb?**h#G{d@Uhg$6W-zPKx5|1*5@4hp$&M?(p?|#vQ(PVcg+sE5;39GZ;2} zy`2UO)<4~bZvQR2z2&QYPiZ>FCiz-Q6@UgCrS3JMJav}|`SJWt=lawrhOqwW1T>8B z^|*E5YwLL|8tb2E&4RCZ$HVABZL zGIK;Wj?kto=361z8^F!_)ZX}{q7OA|ziFXayGXNk&GEcivbH^CaiJH%d?0I&(5(Ia zlSmQ0g{&FJ^+S?o?e&_qYbhkGJxUT{rd~gJxdvh(;r*CA}|)a!9# zG1o`f-`K%Xid;Bah$B2qP>B$H9~r4q=GMyDSt3;@XYVlutuqBx@Ye!cB0Sw?kP^<` zraAlZtf*I#>U{t6YTB8E=lUGKF7jhlJ+{t(579EI7z!0zZh^UKC+_)q`mY>A?-C7aUgAuChhx_h)3Fm zuZuBTg!V{C2(J%dH>kvOG;7ZWNIKzdF?rh%{k`(eDBgZI0*rL{`Wxd8U%z48;p=k7 z$yYP~I*0Lh_5AA+hRyp(N6@?pd6(Y=-rg`9Var>)-ZUNKle|r%v5QvAQ^%UnD0P$x z6{tf@C|~Vi_Y8Rb&Cxu<+n3gWw{MCSh5bBe?H-Ih`v!`skGFpIB4e4l&$r%{*E#h| zJO-a;K|n1ph~gD{=LJz5LM(IfmQRR_1dC%BbDnoTw7nsz=o^mlpl4``#;<%ZBH-

^9*SL@%7_;x_?V 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

!P434sF$^X6-D{j0NJsJ#ePFlT>DYAZ=W1 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%0D#HKIsTh&n7m3+B##7JP+b9D4($FP7e@Zf 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

C%6249QvP>$Q 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

#Pv6;9r+-GAWKhS%J^qDzxmF490HKG}Ts_?|4n zZ7LQ-ZkUsrTu+gPC6S@CwV;M1&neyJiE^TG4UtjXfQ3H#P_VaO?Q}zl7_%wzuE+8e7{-EUwMkuH$a3M6vBe6*6PK z6tb0>k2uSxK7A8}&do=RYy)f&q&Fj`Ra2C{gKZnH)=6OULd4qF? zambAX=P0Y+@VrnD*-MotN0jT5sO%z2W*lFc@y%J}{K}Q_ibwou4L?jT_fQsUd3ks-EO@IUt0&e-= z_f*~PPH^U*`Tpnscr>?bJ*Q5cI(6#QsVZcUuX7tzc)0)5j07<~jQO4ZS`mX%A;tR3 z*70opTgW$8e$zM=R%J$^Ojj+a+&I4Q(u`-3j@u9Q)}=pkoD2w@*5bT4_}JroygBA2 zXkK1cf20QEh+HUH&M{dYg(elxqVJqES&r3N%6ZBiYV&?<=3)%C#HKZLdu#U#o^1S* zRCBCH_H*cCZ%^*+!Ym^lge5hn84@U+Ekeho@C$y)5-M{2f>tn6>YVDoPQOiu{qUbO<}w z{b9_1AE7AaxX}w@th&F&ai9dQ%FiB*jegZLS(v+gAo?QYcH9h6O@18poSBBM1}`S> z6<(Y+gibc3Cg{e^QCz2&rB;POKaZ=}6SZnSqNos?1sFh8O$7V2Tlgy|U8}}G9B^my zN)ZcYcw7}jYsn#?)!GDctzh$ItvUS4ucs#viaou&HNWi53XTORTeHazJ0)H(8#q98 zA{Rdh%r!Y*lrQyVuoC`2nO1vW766fUqUSK?BE$geF2Dq&f}$w+5Q#MuUvBoh+jwyU z><>q4>bfEb2za5pq3@*oW-b1J$HY?P%EA$ zLk;z)R|W$BhFYBfGWQ91OKqQE0g>_61DaEozl6r3!yx7HUgbY^clD>o0>Xb`A_wpq zRsD`8QZFV!!b$CNW19Nr16Hv>yG`*Z*-hf-pfOm|;#z;Tx^^mYg@ujwsuh9yQgF^x zXrrI=sffET1;Sh$;iW&y?^BK7?)kJCC^;A?-|g1=S~rg@Lb6)*k1{rVC#`jE?l$h% z7WPARKz_K(7Vc1m_>vxz*z`Y`VqdX!`bN_052jcb>G?}>SwlngY+Rav{SUNNrV3Qb zLb{3f-K{TwlZ{6-ae?R)(!`%tXNpCd7_xZnf-L+x@t4SKP?Jo-2DvYi(}?|BWDOF9 zCuzxL>~q~_$Xy2bk9r7a3H}S&^D@>+CY&Y5muZ_!nkp6rdoqOS8r5n8T(M)U~>!eXa}g2cGk;E9@!^w}u0^Fe61Gm&a;ejch+Xp4s$i+LS}s!$s@OvAi*Ai&IO#g?Ziyzq(WRXX#I2@NT zkD%mcKNQb%1@lmqV4laB2hy1JOo`{|fjmn(>*y;m?J;YI#BzU1C^tA>?iZ1iM!z%q z9?O2ucraTEiHtT(lo@HY`a5RN3S{6>%q-QK^1-#9pJSxaNJyi>Q7w%wi-|%OXPwuW znHMfj+f{R6SQx3%jt|Ee1C|O6&rMe@;wa_q( zV>wI;>kC9>fWS|UtQXd|WJ;GofKAfcA^TO<2=7DNLB&&nGr>+y%&$Hah0U5FQ0cPe zw7y$@=RwOF3|9A`Yfmg;UECv};$Vr1ntkV9-dL2!9*oYyXcqfLxp6Gx+K1AQoSI+B z8A02P2AGRGz4Zt4Ig+&C0D3imhCn80u=3K`?{{z-k)QkV zlfqvJZ9qYh$1OZ+#_g2;vh}zkSbqmhUY}!DQm2!{D8-9K2Q`xrW$ykiLZ}QjXctUu}Z-QJpFCT z%|ryPDaNEA011iz8p&fsZ)6-6?ku+nztvgjFpsUoPY0I%Q;>ia6fA$cOY-HC_K;mO zz9J}o{&=MzIq1SS1Ft)@#?nBaFPJnPVk-+(Q(YR10NL^bZl2@?oxT}`*j2=S1(y3E zTzb+v_P|jNa^kHMGl7Cp=L57{0iGV{gBJPAkHM&tlYZU=Y`B?|H0Kt%l3kAf1+nua z=Ppl#yGUmDkAvaWDS`UEgjyG}Gd8k&vKq}TO~@3ROT4j;^eTYhKbDJ4WoY93yV&22 zhXDBk7@x~~&)A_?K_!cx&Jg+^_Y?i2wJ)mRCV(|i8~B-2K$u=RTMJWv`JZ?Lo@4ob z5P|BSIfP+vxN`@nRxM>$QN@FPl)LCEsCd`)24+aP6+=3jjuOxs7a#$*bNznyDFUJX zZytn0;+bGQ`MrUl7;X$8ncV-27Yb%w^@dRXlrDh2d->KcQ z%B@vD;v02PIocV7uxC4OiD7Y<#v;wb;<_WT__Q>kohM~=iPfIj%BM}P+UhTz`pZH54~;wxf|6`I6XCW3wwTP>;u zLDM}0Ri0w1d?r@qJYD4_UX@QAS>@4*RYqCmg7Z-&cU4g3p=&gOiegn>sjIBtYOo9* zS>>B02?YA?N>n+9Rqms$11P)z z{%FE0&3BN=ceVM}oA|@#d$)=An{S2r-euCO&3C!^zGc1-n0zzkyC%99@d-CxRNy%C zkNS+dJT*EL8_>OF@o-v*_l?-IMjr-E?MQF=xOw;lsw0!|(IYrAIsUWE{0!y%;xGRz zwi-k3bIe(DLgIRLReBKHL}LQ>w-9TEP-I@J=jyNY$AIIqvViSQ( zouR-7+A4e&dT=srQ;A%T&KzEq9tf{UM_E<@0Hyy3ID%WinL```c0_8;S>-Q3gxLV7 zM)n2_rXMdOuRk3Pcf#un=-B1Sf$Gd}G$oA=CWC zd44Q@B3WLFyxnsThWA1OLP~EhBW_){BU!AvI+EvQhx7Ddt~wp-=Pd$a3rZ10$bDs# zu0WX>6sz-oiY^xs2#!^yOCItPt0O*OEqIE8=QUy-nu{H2T@RAHxfoso4 z>8mxL740@M8a0Z!89r7xk^K;38O_9XFL!R^$yxlJf1pyz1k}6v9^7SUUMpimW{f7Jrfc;_=x`KQ`s90kyc2@uocI$ z6^`zCr;?p)IGqfjT5DchD=<@+N2Lg<2F&X%fBjr6kkjnW$r_87HR^2#j$<<6ilDf(ICv5+4Hcq&I;UxL_>|(Cw3^+ z5B4aCA?V2q$#v-2V)00Dt>g;R!iwz$4yk@d48rNieMV=Ivn%I z=}_IkhniaIOrpTYu(Vy=7=5CM(EELEcH72yt=vnz)`D#|5*^{0EF!!f*0Mmjaua_0 z{E??PZX7*O+-~cKVfeTmho7kxl|eHN<`aPV;jc92BMs)Jp&TlU*gNhV@+V>mMVvik zT&Ty8SZE&-%P^=(HDxlusJ-WM(0`|bP}^8ZKE57nR0^i&A|`q?nh45Vv`yPsYw9$) zdps-T9ug;aOU&ccYaV;ZApHiA9$=7uK7riHKuDAObIj8~r(r12dE*>R*Co_v-0Y9H zYGC&mV2dhYv5lmoUG^$GLW?UvrH?_Wv(JEgzH5Dg8VI|+fsJWLG$U*Emqukc1K|W5 z%5R7f1w_i`@-wb(wZEKO z(rEc59^@AhPJnz2AnVrqbn9~obU`-&<)de4eOm*x%m7^s8?+ty6bt93t?zcaw7!jL zeTNthJv9z%H<{LFG{)h+>l0f4$q>`}&G@0d?hizEV>$yOL$>H{sNbVof6>!TTR*N? zxBj^Yz1H&;L$p5RLH;Mg39WAh$h!4iP!uG;hd>u~1<=VF=;rS<(0dKgB^WLcQGd|- zbJL~uLs0{J;Pe;{=W86+ePLS9#}^ZDm~mY~>r=hfrxTIQ{eVaNx2q3{0&hX+D_!SPzZltmqDkOz4l!U>R%17zL$tHf6#cjaIJU3@lx-lc*5{GSQ!?#>vDl<-7%KoH>UWiw)%_^20`b7!|1p(F@2-&H~)nT*%rr|t9P?tf0(frsECCQ@B ztd&ZrMi!gmYb6(InR5u))GvP~WNW~u)LK$qe4tu;`Z4M%CbLktb}oVaIwH6@);MN| zrig(jC_#%RhF&mHVbVxYT4#}vimMYgU^D}z@;4uCnd9-oGqL-uo7WT8e208@p0 z?6qJMf@U9jDA*An$gYkhXND`&$UR7&k2r(u;`q-h^V1)R(wEY$tU$!u@aw>qOTey7 zLumiY;Ii#P_)5X15y>_%p%HQ3(J^_zT9YABTPD`@l%T#(#6=t3s#VwkfIhzJSbpj9Tg(>@7-Sj68 zwo1|C`c!h5N)u$*QrSOEnoudDxlbiWxo)D2ZlwP%x<#$JUDm>LNM%r9Hb0#=;izbe zzx;6!J+5zFd5O#yKc?yV;@fg9;YvoMGwh9ez8L0dTafXEV<~w4g`$~-#3nK=`%=iX z867EVvKm&?i0>RIR+G~K$In6&)*_&*I~xR}Cf zRoc<#3{CPcx~-LiN4%3Voc_rxwsGY@$;d(fTOS8jY)wbZWW?~_iY-SK!Z|FZ;~`jB zjF@a$2mYN1WLm@BR z^m>9EmPlfQV+rY~k7(d0tm(QAyI+=av2yWrQDl_*)*%hC&Oq!IgV>vyZqmhpyYvh!5M4RZo3*`L$vID)YU#7oFZL0i?WZtan2l$NSL-TcV;0@ zo%>HF>;sV&1YjB<|EcS{aDz_|Vc5|`La`bS?~8ygr}wwm3f&9p*inqzfgKZ-x8SFS z=z5B?*z#xB#T>ug?kS`$ZJm~?hw(`UcYpaT$!#rr-zX{(5r%sF@;HEAA>MIKj3}r& z3$!F5#vpbuRF!pYPtmGMbSN65E$vePR~127E=JA~dN3=W5dS-M2xBjLIv{obco`OT zqQDFzRWVBK2nT!s+MmDtCj!!afys*OugxvU#1REKGanz-atx{A_9m5_g)A>yxLjCM9cn)Ypz*(H= zAU@2@NQBhPTd6Rf2r^kr$(ivA>ysob8kg^c25h*Yqg z9ofW4ZTDD0bRh%5Q_QLsa{?QRwua{dD;3^ zwo4S%7cz~^lAh=@i_lB1bWRBWd`8JYK2=k;Ohi?)6@i?+cl3;WT$=36VmbQ+TcheM zT#R6#&%!De?P4E|{!9wk5*xjMVh*?9Z-6`5Ac`k9w>y6yKbqK8O3NWBgaE&&U6`rl z2`*4vDs@DK;Nu~9QaXG%rKH#Lr-{5_hOW=CcGGN(tla)*f%QE~W?#@zUd?+HGtBhK zNz_E{Nnid&RPSF#Ezq||ym@EcY%Vgo7 zIY~0UBAXD-Le@#)e#{6U>dvXcs)oimk-}oD-OJ%?e+d~YGX-Xit^FWnFF8%ylAp!` zmgOJk*R8CgMTge_RlZ2|b=VasjD5VdSo&b|1533L?{>uFw}o>>$*nG!4XThVEQgGJ zkt)y7R~Nh}DYOPx7tEL6)dh>a+`y7fd00S^oU%46sM3jZ<}=EE!eUb(sMrW-OY6Ml znv<^r%{EaF*umwhV;urvAn!Ly%jng<!L2rV+iWY$PlSu%*ydcq4gHY0Rr7PWsg^={3=?5-U9yA?l z6|F`s2_33yA_J*4pk>WPwEMf(OOuVJgiETeVJJh|wFe0%LTd*XZ@;0V!q- zI4v5A((uxNGmF8+oDu8%EBYnZM2x+EPCDwwNRt6P8+p{+aBJ{)W@IM^foniY7f!Hp;J6Y8=vI z%uT0rHB@3`Fv!;L4wa9XLY`LGilYmEzA(n_sp}va(eGCxN_G9QUKsrcC~>Uj8+=v$ zLA>mSMG4#Xo+N-H=tQe3Mc31W`RF4M#;FtvJg4J@%ZmduH5FymsXA(| zj=F_WEg1!i+^?EZm(L{$V1YAX{46p*)u5}uHrl8G5s1w{1XwQMmPsjXx{`L%J)l9g zhj5i0z;HF3mt=}4{Q;cM%FUD!G6ODLlTIVSJ6wz8)Re;KZXtUHtxORJ0tiKAblR0w z!l{vU(R5o_ffW6wcY_+g+#FlJi{>XRP^Iv9>d6iqn3#lNUSFl= ziXfG}eB_bx9ESbVvAqg<+5Iz}NJxHkh2kwgvYf~;`O#AypY#h@!K-Unye>3Q!}BV_ zBJ$tY6>G$tWNG^1GIWXhh#HQa#!>X>)nvN{^$@-wBWZzXj7!xQgM(yDx{KQchJuE4 z$e`)<#Y0TgB!m?iFa&X(I07Zhs~{YtV|59Cq>PiMv(P|N!)H?>)v65+HfL7xS9mgt z;eZ=oEH@cV9fFyz`!p0YV#gzuSjg1ECv|vXA0@Kk5s$rM~F>dcW2 zwpSF|TX37dGfRl;ipNICbv4BnYUIB|i__6R;9<`c4W|V}2!rFxf8cNPD`dOu^?~HR&9vo1r%O%P-ceb4m)J6Y9KO-HJR> zE~?SK`zCer(30l&=jspdzb`eDR1b#T)P}w?aXi_}Qy3n)916qwx_u2%oFpcvo3Sl| z0bG90TInIsHj;~;j4>_yUAnOKl30dQnZfBlnmrL|BRXJeCrnYK|Mr^={VxPo55J@7 zf1X#Jo87H9Fak4DftGp?;N2}R*+iWIG*SBdWq;fQ?;$>+2cj-@GdJ}IG?^Iu*~4Hd z>hK#3=6fLA>UuoaF^;t#-1Ct_h!SzQHEncmAQV>aXJgrA*o>8g29?lbS2FS4X|ti%c!IAYJtA{L6!|^5apm z;X^}saz@UtZookF^t(cP7Y~Q>R(9Nf^mR#&cka@=e;o^dxMOR#B;%L82}()q9h~>5 zq3C#L{>@@G%5C5rxQi!w_I&B7HD~aX||%g}N{SZb!i7z3&6LnStBh^ZA=zdcORt zSH-ngyibJp!hXeLT+TII(v+MR_&4p|g2h9u-Ji%xLhifAjtKqH6Tm-zsdw$Xz-Mzc za6Bh=jz@akKf}Do%H+}v)fLrZ%D@#?xTxn++(Nb5o}3=wrB^%vP>3rrl50j{-59ht z>iaT^(sB+5{g-h?_Hk*nFlR+c*PO$7{(n^G;n`Y|PV0G7Mn(b0>6Spae`Ygz*39&? zjJ}#Lpfpo+$Gy+?Ivusz_-Wz3uR{BS{NaUoxEHkg3Fv-?x7FT*ZD|HHMm1#+pYlFm z?#*%aRnNloM$CoRaTJv@RtZ_N~E(83TK+adHC|c zWD&z?Pj4waPmUs~G8866W@4d$WNL)^C}u(Zvo85}sNVrKjSZ_p1?pr$WvRY>(Rt~XoJsc)Q>2@hbyFB*`8|U)B6Ha(u}h{j zKOy-;lUyaq5L^0i*hU6f{544jkH?;DnI!RlGv&&VG4}3mg;(lMrcPhY(Uou=O#lyX z4#V_D>U}YoXo31_gZY)NR+(RU>TUB2D)eSG&jgCq)8<#Enr(i;pV<5gsB->7)qQ1! zx~gU_K-IiWps=E>;kAKlYTjd<#XpZS>tGbAc@V+qU68>>o;0#Q+rL0cq>-3ZeC>tF zR3YtIa&MI_*8o6C`R6$32)28O`kaGXDI#)>6(51Ck~Nc+|9VGXpEUo2uQM3V?Y^KR z#ngu-UEqA=qAShln;&v-gbuX_wFc~h3iaMBEs(yym>fG5DrG@c06r5$*UXAl(y1#k3y~dB~<(G_cbVmwJo;t+(=3+kymbD6JGtc1;)L_SY(@P_Uoa1UEK;s zhGDdyx^5mz$jj31Mq*&QS&T97OJ7C`c~N{0T<6CXhkV2ursE=HriIjYdkg3ksB9Lh z_nw;uPEwz2G>V~eX#tx(i^z*PxmGR7M+`3KzWWqVo@7$9k%!-^frdnVDoGwXGJ{qe z2%HZ=yo!)pI+tUCDRU*|K}o43VgNpxA5fLMy7HTauhm%uu|Ab-w%+xXB1jMF^b}o1 zdO{WQn^knuStd!Af-WH7)+WHJ9WK3wa|3c2ddt zg}8tM+l9as3kfLW95d>6S-nlIC?3(6dV?+zy3P+ALGhkUajn8Xc>|%uQt1z%E#cg{ z`4~Vr97Ygs$4i+5NTTU+Jfj5zjsA$|n)C2nb0iPBqi}4z7D-q zJ+cjp%op&>(;wa3n|?|2MNdUJv1hrt(;03R4`0XduV}JKAIk8qc(^aa-yn=NM#=e0*Z?#QLg-lh;as&I1CQ*t0$((*4Vx$L8&4X8_l>7O@u5LyEH`*O`NfV_4@faoe>RSC<#_uTnu6dmG%!*D%Q~2u({`r=FATL+dEKSt#V*7Cr z8;~reRr$k3zPMB8iZ&&hRCw1!NJTPd(18XG2N8Q}nb_0{X2|^N5)^oEzG`m^J2J1Z zOzwyOnIOm)faQZ>p{gGGVVY#DqLkn|9rVpr*z(__F6t!USfxy0c13pw`=hhQy*pR2w(qX4%_xP@5O9K_|k_Fg!I;6_d- zKPynbKj&|xFwPR|Rb{4#fKed#I86AflTCl? zeJFT+1?-%FU6>L=1>qcsj!W%UtFgYSDc9>Pu@ZUfqmVlR=Y22EVoM6`ZP80G(nNl( zsL6$htpwkx85fXT)heYACl;QfK&!b%tG8F}S!i;Jo=3uwB`G81^xY`0=1xOw(CGl&1J0#cHD_>t z5i2cFaALq2gcosWY~_{42ZK2qOQB8f59Dkp{YI{l>@zf_^kV|#S^ba=tmQVRZ_t(y zU|`|70QY|fT=>r+0r!!4Xlv1bcE5tirHI!e zDkcm+j8UW{bBFAnAJI~Qo0bcFH8at@RFA7`+OugKf6%q$fjspbWe<9NGkRYg>J2*r z>4aqEAVn<_akEBUP1PUS79m@F{jJS6GP)c*RGv}CjrI{i=Tt}uTq5!t7$<0dfi547 zEg;?BxQ~0#X!iFv=xluxySPLY`3;@_za9UOL)i9VO{{}0ALrJnu2GycK&YR375 zhw+b*8z29|z8L=^2QdE8)s4r$o(LgGe?eE{&Nz<$z8UI)9%f^N7r)kXY+`2M-A+8* z(T#isu0+3MT<(@}32RwFV|E_^Kc9&lmmgqV5_B-TV6?$q1yK|uYrKI8LFEn11!X*` zR|^q54!qPK^YYL%f184U+~na-N!J6jx}ca zaSNLd4yN8X`VzMl9Bg=ndP$xLZj4?8ZQKprKdo6b2O>3Qj|#ZN6#82atTyq;GNu90 z00gLc!^m%(m9($N|5^lKV$1{MGgH9s`gwq7D(z-9&w+S)Z1xSfQ!`aT4(R4gMYBq? zf;qpMiK2ni5Qgp@dbEnMQSFpS=r1twtK4j3gXAdPh!ph;r&-ALXN<=13;H*4d?dbq zo{a72|BvH03&{P~MAPmM@T1y(wEnuJCd*%9^I~MFbDz3uO)DOc4Y`14Iu$NHTI}NFJ#|Idk@rat1IU z=o-tJ?kHXnlP`bej##36S@Pe=mse!1!@0kc$d_y*NxI<+QK2QtT+VV(IX0n-)c&jl zNpc@j)axR3)~G8*qSUI_k?nstzix+kOPpU%#2oS;@_*)kKfkV{F#X?|Uq@l6sZ4OJ z@IStB{+CG}{4dHr_#c{hQ~rk_IgmKNa;c!Ybp0d#mpgF|s!9%R@IT%ZN$*}oz3Vh+ zN4RNm!v*c0{=3?nW`mp;jRG9P7PL3N#`&Jt zWy$0@HJ42#Q)BJZqYyWjW+u#@{Y2k|s_rxk+37NSifezAL&LK_nfY_Ss9Xv2=W8+k z4%uU&!BXR|;=+>m9BD-(BQ}3NgDEaSx4j(W9GonhVQM|p98QPLz_;qubIcwY8T~b+ zsISBpx<=hgvjMVwg${~OkluQF_)swx>wO06(aW%CwR@sr7~E(8F3@Wm;wnI%XxXIg z!kz!F?ZWG|UAWzou=|AU4YUh)D@6rdXwCs}+Jy^YQiVC}Le^{S!Ve}PyW4H-d$bEr zg+2y&(KzQHoo>e+_hq0u`QN8_+5zz1;fdj|8O5-DRN`2!ev zqX*Jrwqcr(xfwQ>8R_s9;tk(ex~bXcve_kkqXtT8y_$WtScv~Ro)%&fO5Khe{63kL zKp^b51e#Fg9%wKm;1diwq^XMyh%Kgsk`nM(yb42wAfC{>s^_8v z*=E8y32ftSbjF5K5R+SsY0$mq0`EFj&hGDQ(yJJO^xnGrV?EZ=q|Y_!Svq|_gDfAV zx&@{zGwDs)XT7A8eNcH(BHO&i6xUjJi6?bnA^Q8R=$mlv^^ZYX`O90wzziX@mN|6K zqrLIYk5)pQ3SSsIe7Owr=*2L!YraqpC&8QopWnqxHVvxPd$7az!mqd;e*5>Zov#+t zeI8nrdzj$`@$fc=pN)s#WB8GHcmc!Z2&3#8{^ms!P(RyrL+kXku%@Of`{^PKBnp6D z^4+1%H3KVCbu_<<)hUwJpiW>+ICt!9&_S&AD}%7sZ;(1`)j~aK)NCezWB8{B|C~=K zUt)yStmdx|@r&@PWz2!2Ri*h=tlpHg2KBOhcc^FZt$7HQL`Pt9{G;zxI=<#PLVA&Z zUgn?q@ySZ`iJ<)%KRp|9M;P538{yQ4cSy@fk_BXHkmv@?A@K&l-{lIy zKWHDMOUH)%VTJZ;s6}w;n7)g;L%?}L?zL6V@L>_xhOq#&n!bu5Iigi#*ZQ>Vr(s6*5h&Vyv z(Sj`K>g|%s!2`g?tE9|JywVh{USFUN zPvx3l#i|E?0Z5H34*w&E5+91h9ZK~42H9lpXT*8N_!8j=f0B?hH7yYHDY?8q)qmNw zhq@29bndLn+Ce`)YwdnWuN^A&+F|p=fxQ7;zkAv)q~=8@GyJ?d7wPNfb%t^&pf*cz}0%y;DI4nijbzR+;} zZCb|(cO;+3{7bmoOyx4}L-D6Bu@!?_i&~rdmvDDnRaRl$Fav4_j=ZE`KI6)vR=u#S z@yekVD~IHrSULR8S)!3w33tEY9+Jhm(0G-MA&tDKBfLtG(wmuGUB+8EycUhG9N^ed zBy%g;?JgDo5!qS4=1jJE7BPpX1EVOLuI#{AaUsDHq;LdR5!+P{$t$tyiVQ=mK9!_X z0+DjDI0F^oXmTSQO?WG?=V)@Kr2Jb)6Q9l^ZSNy~0F50@wqSh*#7I{(Nt{cJuZsMp zOsUjaCP|j2jwW-F=*^Ih_yc*(G|na$UCSv{d?`T)n93_4K~-nOikHb%B3e?X`x6!o zP4?ZvW4XV5nc!d2u#k)v!s$Pu?pAo29KtW{a$+1!JTH?ia;>m-4M-%NI!lO3FOw$Z z{(vd2wc{dhTtLBHG6CcX=RSZD1_hT&6}(J-WR4@eOujpl+HDyGm#>kZ2~Sszz_cH()0#o~$>`-Gc08NLf;rt!Wea`i?*CaGh`OzNkRn$`p^+ate zugvKvL;h~3>yZ)ATL0#tP|YO0Rvp%CDC2oIe$(4-Rn5auVJiIkn!&igNmX3EgMRAC zOZu9G=w%}QCiytMFm66fU+-aSX)>HmCW1WrZk5t9`diTL!k#)qxGpl8iFCYhHOQ6X zdh+ym7KyMVWJ<_3t|zb_G~0{2B-Fh~2OL~tiyYc_p<$s^;0!PG{7+`6v;T$vNw_1a z+tmN$M#j4B@5?2F8C7_FI&=PC{7+Wndi7WrV9yNi?`Z3adYnTPoiqfp5ARJjSa;k8 zF_VFnI9BUpla_eSTiTun?tbO-G+)fVhw!6K!Y?%mmp2JdX%fDbVbpV{eC0@%wc&w| zKKn56m~tGCqGY?@KzusA;Y#=m6n{0oJ#dwEAlDq9CfG6Q_FZCei+^&k^DaKBkQ@yE z>c68G$b}!xN;~-%75HXg+X*R%gRL*Q-`b?JFh{LUp?bir`vLG}fNAslnhuz!z6-b| zbT&{=arJ5+#p%kS!P16Hx-4GQ7w7@6!kSkwY{qZHWHP-2?bV()PXLP_v`t-qGJ6YV z&@eZZw?ZYrQ;(y%AI!fhS_btDP1yjx+|T1)xR8X@$ayc|ANUE|)l!W@X>4hw2Rhd* z23t)F@DkI8Y191p0jW_&UA)X+xQexp9JPx6{KKUZ2e*slsgUz*3o74iU2%RH*8Z5u zek(a6-@mLR1KZ)X>eseF4~0jenLz2r)69CC12qfGNBi z=h=>ijs9hIHE*j!omfco3)-Xi!nyG%eG9|wMS+~PCF270W}(-6&W9zv12#=Wh_FE# zc_aZB9l^co+<@IDU|$L^nEuIt>Ra1_Jtb|Eev)#DWu${@HhS;_Ih#xR2o%uo1l;b@ ztmIU67J5eF=-z?CYm-jmaH@HHe1(5e|CAY^70^N=-bA46 zfL>|DZwJ2vzqP@jh`%3A?=iIDv_Q_cC3l6KULj{1wuyhruLKdxYEokKaZU;5d{crw z?d!ScloHIr@@r?%Kky4OTq~|hqbCW^eHOyer_Ku3^iF*@@HV*)|3fERch5WE$hX)l zRIw9vY{*|mH+sCg>HCS;&kVT}Qs6v>P5zL57KX0B{6W;ieSaDZ4yfKhKvvD%@ed#J z-*Ex{HY?5WFBMT0Z)n5+w&pAhYEOR2V5Y$Ph>J%1DCo5b z;~84UPQD?R1Y$~b$T<_I_TAjSehU)6dJ5!DoEgOaA;u3JCj$PNT=tS}{pC}sBtlGp z!}Fks4}iRY;#^*8qLV|;WIW=IjDExfooisp$6?oZsnM_}_`G`o0wHG{vf(`B3Q(jF zEEf4r#VMwOQhayG!#K+&x(i9QB=vd_oMHmJwQYB+0!;rU&3FYStW9127CP9Tjga;}uZFyZU|lAamIG9XE^V4yBH zRkY(nBFWLmSxIAC7>z^V#k){vKh!zGs}lhbLh7XaV4W$t&gQ1hMXWO=damf8zWiZJ zPC}PrO5X878ni1BGTqKEhc=3y`<*1D^O>G&GR<7$FFzJMs^=Sj`NJq5pKzSxPz2iL zQEB|vE@`1_e+sp$*HE2$Kr+o(Z4}J)nfi}zG|!T(oR04$@Cl3ukc0_qE{iWmS2wbIKuTCSEvri zgZnB{&qG)QuYLHFEiG5pZ#>iLfT+CkgZ_e*wsiuF$3>Q7HAe)ps_>R(&<~u{yI^Z? zQhoxWyz(RQyHWW|5Rq7Z$&uw>NGSjJrsW@KRGylC1FEY!-MWQ2!yT{1XG^U8;fB_C z;9i#0c`1Lak2=GnB_bL>H{^nS;pRcNLtY!ShzyB@#OS6(>yt5uT9YD~al7U|RRX^z>S$|l+<-f0( z^&6bi>eB@06TJF^E+l2pZi~%!KBm?O+wK1HRFv@I^7sf6a&S(kxTIYr!T)zbR2-%DHQu?XLuVN#<>_ags#L-w9H@rD1W%w z+xF|$4dJ@&2n$m4q+Rgs-GhLa*AbTwO21;YT zB|D@b!=vBm3_bCtlA6{7N6=|Pt5=U4XlP*fKY?k1(=zgcfA}gHF0+Eh0QSi`5iM2M z%Q_a6#1mB3?`=;88L5q@wnYX|cWqL0U-U7J z4^XM}@zDJa!Az|N{OD9kD+3r|vSc6>;l^Ir;|_#R0&jJ%BEv^oB73xbQw15I^9wzi|o_ z2r=l?Ol4g?rpoi27CFhR;k zVAdtaAQH?Pxki7d;v4TmGhg#)O8$!7m<4_vP9Hi<+S4&8TKfF=T@UKyhkqOEzi%dg zP5*5N<_`aTf6;-Iv%r+?4&s7S3rP$Wv}?!@S6d7IbRPs4_8d zQkDCjX~)ms1!;i^6bH4;0j@k*l-U@9(&89B|s+|}|$&+~%$%O(5(bE9u?-3+r~`Mi@l_MA2enjAzL6uIfUWPjT^E&%GmT(~Z<;_yX*`kjFlKc5`v{H{3isd>ku zM$Yb2fHHYt67G9iRt9{a)h${fUCA?aMXFybR~xt@?rhZ@1Oho>h!>h-;WP;#-W%x0>~4^uDZl*&{5*bJ^ebn+TJ`Z!D2E216N}K>!T_-CeS~xCYz^Gw zz!BUo!+e1s<_I>spIbY4d@%&R;da?h@AS30CW-r6!Xfoq#nK!yf$KV|UQIaUG811! zrX9^Cx9DY~g?-Lr;`G(*lcuT})(fJ;5=^2fG||iG6hkP2OCa)(?a3U?JG-Gd~3iKs?Hb;JxWOw*t)L20>H z6;k`edaV_mNG^w9K-s$pLO7oHrs8tde^OYxscn!|RwEoOSpoM}yn{`(5^^S!zp~VH z+~^o^%k_;QS`4MBR=&LrT-#6=^^pwhd357wp#EogT%cq+{}i#6#cU<78O`(gmksZa zZB#PuOEBss9Nx7`r_cbSWtb?mdOissf(khbqm+6w8iK1$oq0*(Jwa<-HB!o^_V$&+ zU8+`D!ifbyr*)Sn_cbgLi@BJ}*OkoB_H(^?{ONeK9HF0$AO1s}YshbLh;Mz?1O1E8 zFkb6{PD^mhkoFTk-3<5)j-mEsvW;_xT+TTeE3Bw~Da~i1#xZIU&0bD7w#R!Id?}WK z?2mC2p7`$G4%Li{t3Rmrbk@OZ)Ko9_9>o3LEA)3wqi=QeR})Sx*6F{PFuzUg+uXw# z$@zeX*f1KWz&g8G0SjO-H4tz{$}Wec77Y7|G3f!=8jXz-KWL-8t0nA=MWj6NzYziG ztfh-E5polxVpS7(3G$|qJ^EOV4KQvB7*`C$G6b=}LM)bRjf~W<7$%P!smCKG=-jOB z()GY4W|wvlh})%Km5{MZHH4p12)Jdvq3Q;}1a&rKyEOf5MIi zewlNiAF42?T(op8Y|dB`UTx^~ATq|zie97hU}+4vLHpa93Xm`>;EXbvukkXIbm!^J z*bTBbNBaU3kx<`YP@kB* z7t)H$y=pygzp3)`!<&%Xho1-fYUxH00qZP#l%ws6T;g~G#R@WIo z@B*c+cc>I%7bcb&CuRC(=pwyL5p?{i8PQ`|qN#OQI3ux!GY!-fUByq-CP4~Zd;?lV zUl(gI=FJ3to4#wduoJdgahw){dM)0L6M;APJ&oDs!~3}Sk; zI(r+iL*b1~frigFq4AUdD8~boQdJBf56!=fEN0{u1lHmZw88@$$=biIjII1REY=nP70G?!910%<+raw-g6Y$%h%2G)duWQ*9u$gU(IqI0ft!AbOs5XLOe)(WMSMEt&GN6sN-NSfd~U z2Vw_7H=n2d9YKh6nU+u?vKnZPwUuoJ&~y(de$%I35Rge-U)lwFEHYW?0w~GI+S~gb z=37#l3dri1ta)BCvIe~0a`Ae(amTbKfy&;rk%lbnx*~q{B%Y^UI1$X{SSdGfy5bc& zsH+$m(traCq6?`qp+I@ewUZHgVn^g?22f}sbK##_Lpd2b=~?0qr$~X&m{_)MRw7Yu*HL*yG==p!R-fyeG#+zxk@l#UCQ!ux z4XQJ;1||{~y@JhTNn)wTxgK?-Z{g< z(=al_{GCEE2u`dbW+36{xQDeYaVM%RkQD*vL6JX;K^ySfyP?iMdr!m!b3XLnf2;H| ze6010Fmeo>kNQAw-hvWp9yFwoQ!aI|t|~>xIynecGuN|U2e6jEo9LIJ zD7r&U0p=kGKHLavUDn`JE+s=?6=vm7O$&8C1lp&R93xM#sFZKuAvJxPepclec~(XJ z`ZeOh)9`}IG4g_ns?ia6JLQb!&!Hmq6(aPTmvfeL$&mZ-igvtXY#)YvVdvlEEC@WE zqB918N$}lgzMU?EdRK`+qQ+FAFB-wo1Ar9o0LF`7mlMc+EFn>c|bS!lajG}Jqt6<}_SBAIz9)7o3Sq@_Y zh~b7JB7Y0N+Z>Uyy|@_p)!%OWMK%LofIUIIJNQ@7-TEsNmJRu}!M2{@&o>$Ec6+}I zjk!0b*wzDxmFrjKyrOH}$`p4Tluq~u;9?XoOma<2T*gY5hmyfiqB7C#+>gh5@}5T& z98?afz=1m2icbr5{)H=)GQ9mcHC1dD(C1!mhQg&ENtRxT#*7+2E0< z-a`)Ep=*#P9ZHFY7UrYS5gnRh_C=bs^AG!V(*FOae%*`S`M3R=qU-;c{mMDZ^eZI~ zN0jN;&u9M(zJC8~P^GaV&HaIwOwS4jbLNJ;z!@mquLBZ_98~xH!iCW4=toeajr?}4 zhdXL|{hM-wOt}%5yJF?O?DT&vccLk0t`gyV;daXhp6J_?`N8_=)*BLf^}yfI@3!>; z#-utth$A<92*3yrY+&R7kCi!~Dru$)Hjt3B9>TjX)At<47}tIC}r*vHd%yB+6&_GfX=nF!n=W ze|qOmJ|}60_E#7Ruip7>*qlDTk^#VPbWn5{42ct@CdhVko-yav@r7@yI5MD#geAwA^cWLW})SvYP8wI`|!e|YqbSF z^3c1?e|Q{V0K$KUj5gtSu0@!BStk4%!vo^s!OY(?9)5)B8S${gu;)(?cx4PH#nbO$ z*z>1HdMU%6KRv?T7^Xix;S2rmC*g$t?L}6kwm}xV=e?l)xkCH3nzGmIX+(RCf9k2o zoJjw%+hAnHn-7R)H(cj8-H;2irjFFz&^@0@$46QTakE1x68-3IpA^XP3a}r37$IzT zWIw#PHQo=~@LQeti0OwrXYQjg()0CeT0iU_XT8^iMsT>2dm}c3?P8|I`)C zAE$q664T@KPyJ;A!g2bi)-fEXf9f8Fbv17q`ET&=f&3c(E^Q6|A_1ilkD^Qx8lmnHDDx52 zO*p^=X@b{(z@NLB$p@{iNYgbQf|&I$$~2}jiD zWS@`tk;@> zhGZ$yNPg?`YtKOWWGUZ*9gFRUE7DR@R3_ zsKzs~zOk|TzBJlk(U}y&ydscM#Lk(^$a(Zcc|y|KLP37C-U1L4Qi|A+o!Z4YFqef!V|K7vH~(>Oym-M?U~)fe~CA9iyG4a~M)KyoPkdC#(^H;tzY%471&}02oUfU;!({G zM5z50g4I-?uk=#tSN`%&Sc5_Ds~?KDW^mU{l7Hs294&5Z`)jn*OgBhBr6gibkfIm)L#HZ!`Lj?q>kA^7}?jN zUJ+sH&~6-3?ID#DxkbpP3(S)Ousnzp2CtX{SC)GxmhBx~?di%a?D zUW1w>=8AeX5nmO)pFRV%Y9s<&J`BY-zd9-7!4uGGZ0iB_Cbl_k7XoRR%|*5n+|g;> zHiS%)H0?c*y&gI~DANN#HD$it1T&rFnXoR88N zdgJ`o7=rKDaGbZdIJEjSp9T}3^%(MEockm5j|I)$ZbOl|B3{+;UR5+tx!L_ynpt)z&qb z`p*IGrKbKf$VwZLCX2V7(iu1x2Yg@Mgi-@9_?4*oAL@oV3J_9;Y6wrVL>$7|gz!LP z2qz>$xap4|j39&`atwr1Aj<(^rfEap#t_zn04lRFgx4?AG?F&7`XdNO6T-b7gq9FX zfY9)TZo^l58ns~pA*@AQ0+lXHgz!)1=Mp!OO3P81O7|etLz4l7#RkIU#tX^s@aF4OTZyy?1Z5zS5ItI(+SDzwd4AyNdI>f;GYF8ZALmsRMnzrod z7_1@|c-VvWB1**DwJ+qg%j8!R6Jd2>(d|%Z*{+)sV4dN?+DcfQYIVC>us}x-R^LXj z?u)@P`PHuhjMp#K1muHPpi!4ZD8pIq#Z*nb ztOO`OppdlaY(Nn&L=EUX7T5tLOj`8&&cqf444|{T{Aw98#<-#ti}p3JR->fXqRAet zi_yd45UF8Baa==9@nHR>5v*@6@wkHXBHJ}25!Nae-Pl&Qt2hBxD-YJ2;M`^CEz?tT zS-|hX>eL9e=${R&UD0^E=AxX?umfRnwV~T}1q(cbDujkhP$JIl zNikR^zq%_CR(BRXbb@YISpuw{9xMmaVi{K=8rE?v(9450s1dB$L63$ezd9}vmcq#v z^`L>(*1+lthFXVmXje(P2SU)K0pt12;>_bkrjpF%b7ed`R zbXe{tPh>S`&Q7AV(s;gINM*%UQ98 z3%(b`@twwsfbUyXz&8l+f^X*-zMs}>d{0Wiw+e9@-$hJyviG4o0Oo->7{T`wYT}x{ zX&T>&$dO3j*O4O;-={=(xANl^3BC_VMMB>Xw`qJ^5Z_(^FZkYhu}9yP2Q|JE&_s{E zuOd$4`z%wP?0y>GuO5k!Mesc{j_*W*ajnJ3k%(`zCiw2vZ1ZruBEk17%>?9!4hG*V zmIL3805ABiAL!xxxS{V`sM*8!z8HP)*7W@gx&zpBiGvY*Zxb-W4~w@7zR6AS9gG}_ z^v&1!ZvAVl;ev0MIKDTtBJjft%Yg519=>gWfQ$fWtIwh^a~#l|vxGthy{vvToOB~g zKJin0eSuZzN9Z4~{GX*f?)#JcwNf59s^@fAbz}Logz}!)Q*TzsL_}Jx77c z1J=o&C{|89U)>&^Z#MHSh24VrJaIoZo^PGWH;MT&O+H%pD2MvQ^UXE+0?hXahBxX% z`}U$gz4n#=h4jIBY3ccR`_|~NDy&5N-o{xoZ~cYxuP2lrV9L)jTVJt|_#w`Tbl za5gNV{4ELPlT7*HP0AOT@*9?-ylPZFyL&?U)er0bO_luhO9-F+Yw56ZS^oNj@}9z{ zPFNf3pUJy5-P6&j(aXU`q&t;R(z9kwEMJkycL@A0fYll4VrJp)+@*Hgr9i|5<4OXF9@d=DA?Jmv7xc)s~2UorFj4E(qdzV;lw z5WdBH?=;`(=4+ep!{+;#`95X7FPZP_=KHq!t}x&A=KGQPerdj2%{OYkd(HQ-`8LC4 zYQ(Rl`L@Bgg7-fr+}}_fZe7#5ldpvuZykg~gJXS*5T;S^dUzdN8t=|H)wbS696UZw zMStOZ<)D@@=&z=;^3NDKuz;O@tUj5mnsar4B0R_oKMNk)#SfHBXGy)u%RNxKNcU!x zD(e!ftRpIeVJE%&?(SdHev=V7I4v`}8MY;32f_Y*Mr6IeJOg|aUeheRs#%|_GSdC- z0%U;$%B(McMgvNe{Vk*s0AvV&%K`>K30BrH8{vH0`<-EaKa}Jz|0@cz8JE(2g-vT5 z)NSA40IY`atQexLC%q)eT9HS!1~xOAy_E!@<6=&KOirz5YJXG%Ik_xZC_-fUVsdIM(;u(x_!R_$5kx1*qv@20g& zeBP524}}c*hEhKDDC9$}ZSg^GuoQ4R4xls)xb?U85k^k)XD8O+OAz=*KHql$|@6kzxt!Bgxi*3r%01&9K|LbiL4P zU2?oHOAw_x4yFC`wuHWnSSS(w2_35Kdi0V4Kiz$n!Q(b06QooO2FOAaKHS%cpH9*^ z+~VQTLgTP^o!~Ga0f#z7si%ejhgJrMEa9imV*CUiml281zVl<@fb}S2%zoowYX@&7 z3!vuynZpq#f8p5LR_S+i`_lw*&q%bX7g9m|at;|^cuRfsC`5Q+w4x7n9 z&(R<+kAu7%TMhs@D_52P{+R<2jMnN9d%O5^mwI{i;3JuAu^?@(YcBBIMk3LI@Xql-T0s^wq8Q(HK-CV~vd zMa0pNeZte)1eH!#?Jb}RgbKr>=|4%wKL+5jRi07C0QzDgzC5}zNgPdQFob{b<7I9X z=iS76--rI?SQqs5e6SajF8D{^)O88JH+sK~pXwIir2Vj~h^k{PzX+s2p-o=Kgo968 zVsY9bb_)UU%mF>5C4hnok^F~K3OHxdpzhl&sQnGS7l3L;Gl{tA zE>cf@Din=(0XYahcj$#DbT2qo_X|)qu`?37TRjVk(CxU4w1@k!xdc|2k8a7sguuM6 z7>VYT)Fg38zJMt>_Xj>`ydh!yRC)4&UGX$frZu7bG2)IXCPhf7mXJ-s-+5>cF3RC0 z74YZXLOkRQSb5S$7C?fQNzGu4;Eb15Hkq}(j70ykqW-KA9)^3=1z60W0&b(e*xVoC z3%M^^{s`RlHB=Rpae?a>c=!x1Mk~}=P!xe<>3yuXcc2f(m;c^>5~^!W+09M@ZY}Q7rdy`6KpN@%Tg^m2a-?jI1&OyER z{k?y@d_J7LpFOO#hqcyTd+kYm!zM&{6T-RSIp6HR&r&VYxICcgrk(IXT=ZYE3Igho zTK&!<=neF(oU1tqU#=M|U6&hN3uaXM=)Zo8#O zWl}lIrw{TSf-u}_aILN&HnX9Ik-j3E^Ks+Hic?T+&VBwN?Z%@lIiMwtn{W)WSltKGT!l5cbTMo!}Bjp#zO z>a~BdF1q)#-;4KtJAM=wF1 z{u=IeWPg^4?$|6}IQasSyBLU!5X-)fNM9X;k^Tq(jqrLA!>7TFX;u!75Bcwuwc2h$ z@H(h?xaFGCp}y-_Z(N($O;$XqB|=U$Ay5_86FUzjBY8DLE`EU_?Ck}gve3&l>G{JP zjL{!QeBY%%4wM4>R%OTgW7Y_0OxLXxZRLT^^jICPLXg@~j5=I!1sWy}`2!BVXadtB zZ<56Ah#JBthEY zO@i|{I2z}%9|Fk;5UKhZIQ3NkZg!3&%ZuD2`}D_ri5Tq5UxQ0;xD|b~xXqCPN9g_f z51H>rj61}H&&4+TeGd0@y%s>})X9Md@vTZ-JY zRvbR4MI-&urW>iUKN{$tC$NF`n$-(E@i`Lc)vxpquv8Az`N;MdLd~Ai*>O~#E!LcZTQ#ox?$X@6IXA6sMXV)Hjw76F5UyGus~!;E``19dAIeQzk8JF>k%$YzfY+wE{5L*=8v^wM=HYX9=NeS2usLwK@5SgsLviz8f!>!3_y{JALg`nECKvGjg>L)2U8^GA9^=qRu;=3Nnn7x%QzB%A>Hpe5Hb?^%; z9!lXK!kXyH)QledA*_|Ig^TTmt8FVdm}TF2ENbldvfyA16{WFIO8)J78kZNh@sFrk za&!F!LcP(M@ccLv$<14w{fUcoJMqoGU^mSEaOpK?hbn|_Dse6i4Ewbh zBR0aH5|th5Lw6EL!g1VyIvZ)dBi$>DnoTLkg0xAM@#Y$8ZB*ftnnj z4W>f(1CWK-bW_x_I8b(WIX?;9gTw&V-C|%VKLB1LZJZg0+NXwrSe>Dt?*w#22_<3J zt@7lV}$qp^BxhH z`i&YaWAVUWn1qaT?G+>~C~MqKsVWf2s;(1y!wvN^5i3hM*wtNlgFE=xeN)`RDOG z7xsTvq3i|K*j?tYkrS&ZRjOeBTN=j{EnPJ>vdG5b!Fq@sxC*`Zq{N_WSsBD&<}TIA zQntj*)$hj8-0>kfC=(Z%t7{M?#rObCX7D#Bw4T<;QS2fljI|$EMcdTz1ncCzJS4t) zG-?K}+<8d!;k<_#exSh0K4Tda?%Nr@ht~dnxvo+|Yk$rl7;sC8KfngfJ`J^k>%yc$ zmAF)e#JJL?Zea*YI9+1$GJsY+^90pl+OW9f>$<116e#+R;6htJsSrJ2=XpI{sD z&`)4i=k?tcoU&D;3c*2Jc;B%Qjk8+I63QMCf1pR)ATbJ48Q6}s*a3yYgC4+{+Q@?d z5Z_N5YXQvqgvH!6g{cYj(LPKT){9)v>5Jtv#2@ zB%~&TlD>piUa@20WO7&51k+qH7+i$;qm~GzDD(YV{<@{p=oc~OmgXaAFElNKL|owx zDf&f#z@lSLnTwF2xo7Gs_LHyAAVP;Rf_F}N>D4qbXK?n8D9n>eaYUXg5Oz)P?Vw&B zdz6qsOsFG9usY)tRrO6V*=b>GoI1?l7s79K`cK<)h+$QR^uMvEq&6jcZxTk2GX zU^^^ildTf&xry6z?>A3w`P#MvgS%W`8~{w|C@cS1FET3xLNk+KxJ~yjO{zYHgDEvC zF!lQ=1!Q2&W|4u}R87?E$7B{)*pML9O1=UB5o%8ovg7;tC?nMFdr79IZ zqDWx~ST0FohW14#V?Q*6+26X%i%@1*>PY@Dltd87QkJ4Xpiuzes}EV~r)4bYBU&tJ zfwhsBmt?99CZ<+$K>lu2s}Yn~)l8P79)UzWYbxodlv{FeRpjpSe2&2DQuQhZb&)V1 z=diun)iL02(q*YSTzq*Sfw0uXN6A=iswcxx9-m2-ss0d3=QRFD<4ad<@I{`(!anae zFnkWH4~J-dw*a}#8~xNEu!Fu^K$sA?%W%N}$M$X(Zx@hk*j-7KIE468U##c|SEasw zEZdgb8)e)zn$-)BV0C>ELKEd3(YX@d8efhaYT8W1*d|{1n)?gsJ zIsw^jyCM6o5y%b$GG6$gs}*@q_EZQyk`UYF6X*u&!H3Z|FP4+XgiNwA|hHwTZWT#>&>zg8d~VuN~_{YhfuUw%0^9@dgR36SWyPV%%xGECSY> zyNr8SYrz)Xl*HQ!+SXI5B)^h1E+~uS0h0tVga>*Kn8R-?~5fo?6yC>KVtKWd?h9~UO&pIH<_WcBVev2<1zx-1# zzrzz`|G{U_z8a^<{Ptjupsuf7>3$4zN&Z*g6-bfl4<8Akg~){;n0$Q4D;JfdsQR*)kCI65z}m7icCQY$G0~MjrFPEufFF&m8k+XUDvDfWB_;< zIZ2Tpd}OL~1hCvBSbVekpdQTxEfg7D2GBNt3I`q`F5N+>5v<*YkZdUKV1ygo9 zBaTFbh5CJkX@Xqp4e(FHYDty|50|D*+qhWJ4n14Yl5@GmB-!BY3%nbULhurJ1yMhL z7FJ5}(Tsgc6n{B#11J}*_^?8C6qM|%+=+BngYt~?H(t$py_siB(kHJ%)m|W#O z2@L9=ZGRx7Lmew~8sBK4{k>)#2MAvQ0yT>x6Cs==5aeQxu`N354p6rG8ik^sxdk7Q z1}FfibUh52A_w*t5>0yu8W!4m=*8>V)~K|S z#Pd zgv)@OyzGe2!t;HT_02m47oOj2Ibjw~ZVf9-w?a*rI-6%67v{6QbDI4%{UNmn8)@^J&%+y(#ZaJf&ft{V6b7tVys63U_ zg77MZHnNBt?wDFp0>s3l|7s^U3_4_oR%zC7te-4X~YM{a-3KT$k1 z%4dg2qxk3Xf<-)`2X*tlGC;s{lGQ<*PvyO=)$Vp)hE#DcX@sE@=iuU(I!oU7Yy;3N z7D*m;tW#rZXl`4vR{@2$%qUUD_dF2*+j3tWZu;Wj6MJ{n-~a z%kj+`e3q!vtXn2UzQM&Wq(jYkPtA%0H9uco^zt9 zbt2W;)D!qDm{jPvBwutOE@K)GQ`J|C;+?n+es$MHNlE8mE^~p($0Uf-YB*g-)1}i$ zW>DD>aA+LO7{Vt0@Q;x4a=i7;R8X6`_XSBJqyr|eS=NhX&5pjS`(O$umv#qCB<1R8 z$bq2qG?NOy7TEtOu={0LQ@-LvWaXCbRx+J#>NLRA8w&{WRp3GX(qea1zGW{AAiHpB zp`Wd!A2fCH^LY`cV+GKk>Gr}NOk}%B;z;Kf=0yE-&qPDM`4PBV<<6rrC1g^IS%|#x zbsUr$_V0&(@8~Rap0v=rptob6!McR&%Y&2HOZxoh!2_|EC$%X2(X3wBqz0-y63L*& zT=hZ+Ks2%s@Tx_4ljUUZ%d~#0_023aTY)<|S@WA3h6x>COk-7hp{iC3;!#X((ao3j z&O&=eYN1`;+iJ;YFw*1)jGIYUEq;kWTC8O#a}xiH?a^5L@y%VH0q;JzAT6cDzE;bw zR#3i^pF(_}Qhjk^#1C26qSpVlqf>~wO4D=|NV)}0=8-gBH4NoV0bhcbE==)|XfREsLpWezd3FcYtf#5f46tfyuGbb7ur*LEgfoy^cF_6ySWZmckRJ zc06jhzkU!jcT`~JDD6c#=7HT%zN;7EkmH%dF>z|mah)wTZFfMyePx!ZqMeYNU242!+2h}b!7_EKcDSGjNT#B6uu~)%*D0StL}EGh#$c57(%wceZ6>9~ zAYEO}j1VQ39-ma7XV4gN(X;A9?p_S&r3?W5aOwzOx3;2 zCT&*>;5sr!*)ldqCPA|@c3UI2A|oXzpSnm>A2e49lz4x*5FCMi?2(LX+EUmSM%`ZBsWw2#~+t1j@+6DEjtLx8%qYdL(z`TzGZKW~Qsl zA(`c3FiFL`H^g(F=ShKQ8TzVoyMN{A9+7XLFcM6UFOsUwG4dF%{c@?K9~WhD zNi#0hE5N3(z^yR)Zo%R=;;J@bESG-B5g7iOuW+n1_YC0p2p(tBsm`c;=L|HOq+0oH z%F5PmkZbqCPUnC1qk+74)>`>ZVBdAtzH9lmC`4Ev8V+HWJ)=JrRJ4mIL6%(*aKa?g zLi_Sl?SkRz?tol`86E}RheEsrV15dprLS z-Go-XEif(--`D+!FNKv&7uBd3D{I&WxAuBGNNjcBo#{1RgSlyk^%Z@hyiSIMtHjBx zfMZWDx9rI?Kz1S{t#RCmds1AS9d!yKN6VIgIVGhKX#Q*6>pJeToOCF@XFk_n*Qj^uvxQsuyQQ z>wH3PSqLt4G9xo#hBW*BbYD8zN1(K#;;ad=0h84@+IpyLoJUf1OH*33P6HhV+75zj zE;p41@GZKGWrwN}tOhOmUGyTTD#Z?79k!dTL3nR@A-Bo)L2jlx)LEkpD152ab@zjLK74dc}TC=ICID+#o{;z7RvJ0pYk)Vg5uw|L*U zo`u?9?wp0a1XJOX=b(Am$gOB( zxeQ3FNSbU(y`&5_#~9~CHPY$6*d7UGN#u%UPY-~BKx)<102g%gp$CT3k(SflpdDs0 z0lezK=t$50Xyiv8Az)}LN7@x{ zl!XCT()nv>Y0{$EkuJlDXHzk?@*%XIBlQI+scR@dGr8C<%Phu`tzhmFY5A}X++ZAj z#ER>ZevAZxxh`dAF?LndvQMu3BPJ%&hNKC{=RYDGe-<3@_`-6wDh~PJ?QExK@BKB8 zA4wiBaC&6mL3+XDW@jROsgzxPc5YHq*|{?H#=wtz0ITY)L4T`G@~UY;(!fqyoSX(Z zPXdL$715DR2n*URD=5s+yR4>aL4>Jtq$dLOc$VX)!0*5Nd}t?;+4zAvnL8$s@4vSt zvI5lw^+ocb8(_F4Jpmp^UN!{1kte_fK`p_GDZwtnz=DL$>| zC-KqlqlYlsU2zyjyH8JpRgbxjVe+F?_5#$*O>05|Z@uSz_??uFFVq)!)?7V>3~`GO zxSx_qJ$imB=b)E0>N)7OPf!KBz@kC_Y`$=TcOuk&kDvdb9P|uwOXI1< z$RZkgo7(v}?<$oR#3-$bFG)?Zn^8%vY^c6ao$N2rgy*5Gi&;o-IpypWP6zZF!E65@ zk!QaPN3Rha{|dV4uT#0fI&Ub;Yf9*^DPuX^yxE_i=yU5pqoWb9#+Qk2?#X-*AYec8 z6?mvtVCJ!PAEHX0^%8Kn!~woeQWrddtEV0V3$TN%77=3zN9)EEE`QBN(yZfqP9R_{ z@k4&QX*bINoE=`^6}T6GsUQj*St2QXO>gMB`fKjhATIMj+^#|Fqd}~E&;#+o+tTsftl|0RUCM7a z?fXZi*vn!tzo|oIy?a8z3pe#r*N`jRya#Rtg^hR)qv}xMN-x108&Ms!mQ(F`KmPZGzvRjT~CFJ9%3b*|O1TqBT6%{&G4=gzECuM8)RYl9X= zjgMay(bn0CTaZaWM`5qa_z5;ZY0XuslxLAP<8uowkrI^oC`PYv1e+t2T>5i$I*Z=+%<8idD zL6SkkN4z?R<~6-Pq|mt}HBb=Rg!66J(x?hRNU zJMqDy@TlC%19%?SXNLA*PCxNp@5+a&jf#(Hr0UGgQ7aoWsT<68K zgcrrV^~M{t8*~BY`owJs;}$h3B%ZcHN4m8vB~G2DKFKnT3|Ow4j}$1C?JhtZkn!8< zW+8RBoFTBI%05df4`m2YpFkBsD9jjRaVY5NTBf(d6_OSNY`fD0kST)Wdk+;y$xBU1 z;4SmKnoy;vc>hMHEB7L?dgXa#BeFCDTJKh!uEL9K3D5AnvI|+)0Q&*a%H&QI&O!oE zL^U0u*%_?J!$Lj2?%k2jX;_CKXbK?w4e+5m;y_~{u&(5W>jX;Jl3IpYeKqc8fiGyB z1_lj#8?$CXwI~LSW^eT?v;<&dC=G&lQjcm8q8D0npH3xsP$TIUfAA(Dgx=R-QvkJX zq5bnhERkSlpw;C0Oo4_cP|V>irxRluhBByMFxExyr@cj&8tN5!GiZOS&V3X^4aZb7fA)Qo#HMUy0~jHc zMKA7|Vnml-T&hFz(L4D%jr40mf8{n>z*Bh`#EEY5`TUmExb-sM(cjqL(V0Q4>{H9u zfpIWuHCxy*^f`Z;6diA>xTIx~xc2>;S)hbS(0npUtXQPzxjq(=92jFTFOP4_UqBw` zGedCoNUtW(Bj!eFmN+5za6(pQp+HPMEnXmOGGp}3zso2 zPBZ9uRvo*OP^(3Zv%{mM1KNmZvVFr*YPXeN@snXJyp;X18 zHF&6GN7dI>sF8q^D*J#Ih?9Ly2NSr{kkAov?v^I&YEe14OiTzeyaflTP~K-)U`Y1g zF%8R9p}hC;(cOQ?WPDh8T=MbXaX$n;HD>>dq@;yX0qE$c5Oqt8hx2D$`w1$3nU76XwPStsTUAefQg;JD6u0Y_V$7aAO~iI8v3Z)H>tBhs-d~Cvq8$ME@yKz zO0UCmriMQ(Bq!*GXg~W&1>k3~)5UF9sX9(zbk}|YS3AL2oD*&rw^J!H8VlN~dZL7M zt7=*NRrJ1t*y7Ni=$1nvnk;vEfT5dQoiHc~VWS{HN+lnX^nW8gu7ZKlBm0Zr$+_e6 z_482N(V6}59Ih{QsJkDKj?`TMW3g1p252-2g^HI2X_0Fxa;eG4g3E7MhAfs__bxxj z{kMEWneRx+$AYSzWI|0S{OlXg2c7Q?5S@n>IQ#sCnZPr!KWHt1>0c8bZk!{XCN!z` zCb_{T#2{z>PB=&i%3i<#?o(LE+Nj5_qb5RaqtI@cfRI9a35Q8+?7**Ptf2igM?^b( z9)2Oxq}Rb1`YTH?RHVR+mFll~LDm$~pg!Vi<=Y|!@$=^#op%SHki-nBQy5nT2t zSejV^dsGItpNJ>Z5uElY> z{v(7KJ3$_a$bZL+5Hl1luPolPXt_g+mXe(iEh)J0XkHa%ifh>ZWlf14%IAQ*-6e+e zAq?6fXobn5caeC)hVvm4s2vO4u9p~>oKG&%(n46`Rf%axWsJxKEia~_iPXc0GjAr< zikF8~JY=^qqtig}XmMfQD+QL8Y+6brNVYQw!ALfzf$%BWhBFJybugh3M2Y>)FfE2E zB*FI}^T{??q!mWmGGsVceMY`?8X2$N(SAX`0)9%4rQ&v~f9W`>$P?Nx6@EbbS#EWg z_Dkd420!`!2D(mzu!l3AdsVzK*ExYZe{R6`NV3{CM=DOrrZmE49a5T5HAmAIpmb}| zv<93I2bh@%5Iq5i83y7bafn7>?FRK6s`4Qbw-92_k;fptAR1DCrD(v|CEL=oKMSGF z-n&OyY7S}&kwWq@)UX4MUNr1i8X<8oAvV87t7b{7|E}&46$=jMHWbsLYmaCmG<%X8kHL1vHI9~A>ZTAVj77Tw(QV$ ztcid=o4HYF90uCcf5{NLSW%JPiVI*s-s^xv%wo9l#d6cmtQK3!$9KTdb2t?`ii3e9 z^n#iO{RF^An$Uude`E6+mjHB*VP65$d^91dkPh%hchsW6cPk^bW^ZQJ7k5Yq)pE{! z)x|Z^(kZO{9im_RE%NG(v)T6j!VcXZ-1faclmam5;;?5LJLGQIi6&-Z zSMGA`TP0*6h$9JEx2!rDJuI_%7qo#^Z%5-ov#du6u>YWm4Pq2bSS(5gaT^3Hf|RQz zWkqVF6iwhvm*=t1c?2}r-cE!1rsyM<>nnREp{(5!%6idlQr6dNys}>7qO8wCkRxm4 zEGexS3uJ1aa8Ja~&`%=cbc%A81#RK4=_>)g$9|Ib@XyUF+6(%Po#}x zVDx**{gnjxF7k4}%WpSrkj`Bb%e{6kaz87PzFYsP>*lXnsB<6b<<@tlq}}2O?oD8R zZ8yG)xv!MOdTt@OFVwj=|7c2nrhreY(z)M?TtxEC7tOyizz++&Q(^fWL2 z$9z9x+!ljxtZ`2^;m3*F68X3Jo@L@M+$H^Fe1nT3HzOV4zaj2wEZ0R=h?iTXA|Dti z_n6!>jr+E7R~q*lq>DsN;{7-2COFZ!>%P(7O~zep+y!twdD|R68YFUHSW}mfq!pa+ zM~<4i-RL3uyHD(UqUBtR1->6D&%kOJo-Ws`VVRsv{RkZcfwIr%FxbqOfzpzyj@{E9 zADl&!1+nuZ%aMuue9t%Unk@rI=#4MY4;fx?cCn3Zl|}ZNf{6taitYDcQ2kUMh2UAJ z6g77ykYaCndLb2&cC3wqI9gB#Y~1O@`x)2(Vd1^j6P*1+za3F|1ouYlV-3QBX>VK) zS=Fu3J_d{TnF$9Ed2lF2`9%8A_b$b>-GcQ(Nv+00TaLG3t-U_9Ejjf2lpDqc9pC77 z93UQ0P2~1F*ywTjM+3sqan{Q32NquW&LxF|))v@r+w1M0lA8)K-^9&|-IGT9m-bFA zoYVVYcT#6)+g@|JA6zi|H~-N|NjEmS1zDlr_Pya?h_P+k@B;YT?zm*8Mz)kWXD83u z2M) zFFBHfksV5B4U3(`P{OsGA`Fe~ou%B_QZ>vel8ssuWusO@EHXX%tf{ZpZ$&B5d)RNW z?;g?j;?0HoMA3(TP8_c$+yQoQ&cktdENqS8+Ms3sM{S!$kvG$l#X(sZT>c5R_~A`c z%Po>+!JfdKC6oNyZL=JRVyY^9a5->kG1d?B@#t&Y`NcRqFKc<+(26xd9I9JRu0;TiT7G=~zq)k!XKgK6DM25m2}3)7O$bTg8% zfIce|r-WxshW=8Ok6j0tOHNI(?DJDWo9PL(iSp_(IEdOn%j}V%hQP+pGo&bKj|>8V zm7@xK2Reh`$P4Gd3ig8VdC-1KwDJ$t80Z01lpc(J%6@(WIu-wBiFqx^6Yae-)Tein zmwRL5KSH=kHn}-+8dB9-Dw_Mm3wN2t^?>D^MS`05n5H2Kmx*g&J1NGx66%G$?7hMs>tQ&70X^7g?70* z+8;kCnQAroQq*Vkp|S2JwIF7V`MwR`aqg7!7O$E9P405@Z)VWBRx^Xr%&@my^EQdw zZ^BLTs&_GOdiVv*uon9klGj@HkKDNs9P}Fo34eH%W*dKaUu1bBA8iX23ae7ZZg-e| zPqADJMMp=Cfhq4p?2l%08@+rpf@k1=KW9t;Uny%wU~$|EIAd_GY(xsc;41^qIU`ky zZDl%RhS(P7`(rTCKWn&UTUprQG(4E|x4-5Nq{V@3Y|9VYO~FA}QD})4*Al4%q&Dz7 zWAO4G_9=(n%E$LwXH2VYwK`)q+14g!jIu4|jM-{iTaj)%;31k*{gBPDdZj&3Z?=D3>79t^2hJZVPAF`5Yw|zlS?vEP%nSYd+6n$ zb8OJLA*B)C>Zo7aQ%am!cqhBFGFa?fi0L%mjh;pGaKgLM+f?9Yc~7}7-i@|$qPsqk z-6&6FzglAd30N2vJF8v^<^XNwX!D5jPYLjP$ffW0={6!cpFL}B0clq=;u&MT)xH^s(hk1IVX3L1w*d$Sb4RN!`sJP2*b>rhh` zlFu+SQx*71ZiXnb zcqlT31E??^ULXf~G)X`va3?V)K#xdO>57Q(@Krc4<6Iqx9<2MJ80WHNrzXTk<+(UH z!Tu<*e=c^eWq$ zem0C7=%9n)AvXV9jsxs^|C~7lz=mPjF;2Fq!`?I6NzSdfR5h-fY{3u+c`Lh>)EE2+ ztr{M*cMkg~L6i$WNwWrXW~5{HFu+qdpEDaH5Z?B6${=;iF$Hfa&cP)TUl#jEeHO_@ z=_oHsc)9rt$RQhXg4pAmifhPG5%2=GeQ#4!rjr-ZUHWMO?yO@WtS+}~Tw1%Mz<({M z!{4hYOD0}G9EVu>uVSYdr>w>WK*^#$u*q&ZkJE1WR;mGZOZ2XUdTE5 z+AaePClX|dGZh3~1e%?hMU8d8$XiHxX)T0F0f=2vr{|yz&tz>MTS+4MuIBBklXJej zbu0w~)TvH&#yjXw^cxI^N$PMQN0T9%fYnRlvbi@_8FIXnP2iL-k$d_l@LhGWWDS_k-AQSO{Ob_ZTrO4m>jqu8fu@iP!Ml{=^Tq8{ zuDBg4Or8c&4p+ArUzWNKJ|z9}Y^q`{>fW1(j8n)t#+RyY6Cc|Yw_Ui|4;+gT?i7r0 z5WYj0=U7^{v09*ahd70)fknywa4jmrE0DRDmJrj`Nd{s-4T(easpHN8>QLV4-?2{z zqQf4&A9OK$6{!SG9+y3l`4D@WZ*^=u%FM&n6pUNNIo&h-ZW`ECZ9-2(_7}!wyP_OJ zF9I4=A~hFhN>T6YZ($#{sOPY~5WxqT;K>LEajWmHMm2}4e&7Y6iZ!ahWVlIZ`2G|P zXRryrn8D65mOC>=opdc=L+E1SDvhU)3Sn~+jM*?(XiHfU3Kdt3yQ}Ls`}qJRT5tnf zb?A$re0h)rrJHAvT}|@=3jYf`&B?xoNho6&HqOL-A#vUG3nb{7ZX*=yc_6@JS?3Rs z*Xutqi<{khD390XWjt_5lKQxckXJ{2{3#{DkGl;ap}fbxVejyMi=_Lom2m$XbqRI= z98(>GRHV2g#qCswirb+MVs4?heT^?mb)tmP#Y6ym((33F{K1jV)zJ_5vywlr#8pq} z?_K1_PARx=(!G=)Ct|vX0b&Bg2&4uE63CB2_%agZ$9MnfB0oNEWo-t7){X}ZR^VJ{ zA(S5|KBWA{#q*Pp1v<~H>FsX;DHeAUj z@q~#4J&g$ukWd&{< zf=Y-EJQCAXjsw5qI(SY=DT4&^0nWS1U=F1?WHaWyGmdSZ98zcRr`BA9aH`O8IaY`TgKiP2<@+Sg<#&>3Db8Ga&{ zqppJ`*cY0|Cc$B$TT)cV6^MfPz%0#orG%3nD?KUV`X(_@TMZ+>ODVfq-O3ae4A5zz z54x*?m>xw}0($UzfO3XT{W>m7Mw$W~4v9&*@hrO#@5V7nst{ni@|if7ajtL6-2=^w zMm#JP6Dea)X#Rz(7`vV?c+) zM4&zg?FMtE1*VsA-)soCDhB;U&6dA#1JrP>5;kdyZ=Mc2_}KwWvn#J;&Y9GEa*^{e z$$1Mp&tJ3wxtowPx(fG^g=S?YRSnZXXjIa0B2UTCnh!C!3ih_`P&i?w(0A4v{Tf)D z5djX#H>}iEZi=VbZGM=jA3C_ll!DgoodIdyL(dBl$aD4-@=%;PslokUb1A~1*?R)} zSkVD}?VoFzKY*X1yp3Oih%f=A*dLlJdD_(!$S;chW3<@sj$jYUyF~8xAC!V1s*HBK z1o&DV25?<$0ZRgL-wF!it13-!)i+Z~+)&(Lcr!ZWzhD(4z25=BOZRWkg(vpEMe;rA zkYDZ#vHvuc3JCOkD4Ep(1VF9((_%hYEGMM?s-sN>1j^%uP2B3%Xwr!x)$UtwGFxFEj z4efFc6Dhn#uj81=-N%E2sKRkP=*ID2{(cw_e#1f^ivAl!JEhHW{0Xr6jwb)1*#?LX zwNV``-<`_OZxkE)zwu?MKQI)bh-0OQ)T*AdA=nzAZBno;8$NbrkKMVO& zOMI^aM)dWVepF(AU~JU|SZ@m2t38pYR@Tw1ao%#q{|j|2&aic+xQ zc%ym{$-L;7baZbMO>{F7qVLnu15I=xy6}tJBsbJ0_H`()LMP#XKm>xs?f>K)@Tzkp zCGZG6#dotu9YGRqQxAeRWQx{eSZAP&MusG~r1GFqC6h7#?Z}2pGhx&qKj=&%T zPemZz6OB8BE@TwK;(Z+HgHUbX0iW+1E15qGn|NpRIj%EM#>c0;F?qF})ro8YP3Zjk z`_-=BI&dGrs@2|4WARw;`r#mavVN+d@d5#&&t?U>+?5zNcSCSN4_#Qm4B zi6B|lsMkz}AID0Di%o_nOz@WoMnm&bffTjmVgQFG0a?7Ki3m>(=z0`8SYW_(B$(W0 zUXJ({A}G2R zd_O)9nHvzL;Sn23!&vA~954^(&q)64$DaZGIXc$&6Y-{G?88d@$W8n>Hu2+de6V~u zko>X!-1Ge6*D%CJ!u$ebOm98Va9WVAM;Uv)9%Z;f0J6X76Yy2gZkAEzQve|A`~|+} zD08$PWgaD5Gr4#Pvd;E(MZmv-evmdVV*2YNk!i0Yh!_jkzaAB5e5gOPy!IAK>F zjjl?nL992uNE9a>mvJzu26ivLtLP|1Uo=kxUFQ@f`Q5%?I#t*m1BxF$lTTmtF%lvJ z<$Lf_iiFkCO#V#a&lvt>^XEMN6!GU+{`BR~rM!_@w?}7Xt{T2{M`!dz62#q*32f#& z#O+kKQAS8JR~lcYxO}*~zJIVq8ezo^nDp-1C<3O8@ZR zkfoxdMK$xB$~3|}^MrYJnVRRF#|G&#HQ(=CGEbZO_7V^++EHi>hP_tyCW;JY+2}G7 z!gbD9A)^dmQTr2KJ4hho{^T_(Jqi5v9Vb7~;J{x-gUeK%fBmRu?^=VKI!H6m@N%+? zp1q$fVWPerPG+<97IxTIE)CNV2P=1Nnn_Qk%L{3^MI%mRMRg;(aStu2WshZB5wUg!l39xLer8{ugcO$~h`F3=LQN zoDZMH8B1Pnc{V*lb8sK^RaNTiOawAl8h7adlhKk!CeRNVuu&`C66N^`Q=3M zkY5JFSBMJkHJeeK=cG$WyV_o@Ljr1Vgdi$Q&7{R2zD%_PO-XJ0T_$pU6J~l{58i6S zHNK$Qj(6GFw4+aAtT*jRLs9hg_|OxZ|6p5FY_HCHSY*eOryw@7U5Bq!reI_hnkFPV!`rGX3)I^^g^gmqQRRLDjQ%Eck`4o zT{@C*<-b(*k?50(ok;=>Cp@o$1V$3>^$FrBoh-HEG!zW94N1W5Lsb2Bk&!}u#z>U< z*#BATR0=|XfVMUPceA_8MS=9}6-39a`Ph)H70cNMV=0rDF*ye|@>!j!XsRSPce0-) z$@S>R%i$MDqAtZe&J^=b@aunX+{;OEjxGcNE!!Q?mONeG)BY!*fB-VZ&gs;BC}k(_ z?qy=@0iI_Lq=%b`i?N%)7-Y1pU`~7DwygI|cxf=FO@~7;ApI*Qyh8Rs39M=l)&j=u zW@qLE<_c`~jP~JA1%G<;XK3_$I{nz6Uvr>ADN@xZ#urfU7+;ENGCoL_|EQPEN2cO< z$;=l~PX@DKpH4Gbsa?%O3^`}C#9;ixcl6~%4#IxI68l5$A}q02)9T3ms=vT~@G-b( z2F8#eI|i}V1OC80i8eF1$?HD{bU{#3HS$;H?*$9w^Vk)~4V zBCX!lMmdWN3{=UI!P@~>gB_$g$9A@>ZK#k4Xm~;rAd%x;huQ zNKYZu1IT6Js0+@%uxw3CgFN*nPc>bg2P(KWVyTOn2aS5gc_ijn%sUkKXUHlifV7(8 zu9FJh3Wn1V0)mwl3<%a&bQ6Hk(w0wVD;iUo(uiE$PcBUB)t#LWd7h-{V{R7*0y)nuzR*%nB)#q!FR zkg;R~rb285*7;JIuh8VHF!^RkKJ=KlxLj58VK?7${SXbR+Dob$k!dq#BpoX2Hx^kZ z2zv618AalZIG=R}12F(;?1+RtzNv(#BVq8r8<9-2Y>Tq)3^q|d5${Z#jiH;StdSR z=g;@zpJx2*Rg{m5*C9rl}>yH$y#X5>zw61LmWaAGZ0ZR;F zn@|+Eizu8bRc^u7IrY^KocAouLI|vIFuHSMN_h~F;4m=HlNON@j zCp>h3xssXq{Coz7>$G;5RL#WaBZ+TQzmL}wpXb=jFns_%^>gfjifJNHQ6#rjkCQ>Qvbe@X`e{4w}+q^tD-{Gk1tI{O4v zh6|mJ>HIHoEFW!gVMk{t#<7j(D)Jv^ca7q9s0MM{)e>>rl<=SHJFUX&P0WhcpGc^A z->e`Bz1GAI(4qMhEk=kffH%!Z~thESjkVk5Bx4u2iE0jkW_`R4r)#p%lH2Zt;Ih ziVpP&!?6A>h3AARbS)-KcaN7$>IPXmY>o~gu7lZYPYH~LWFfZGd;`W6w_SzB#r_kx z(Px|FT)1)ryDjvun_j_MZ0N&`PfN?~Tw5 zIpuY2kT^jzHb}e#7;L34A$`b@lHT>*LePdGztap^_r1rEduygWn`wk0IiBpc z|EA1hD|a#S4IHJJ^DlA_&UZuE6WMt6IdSeBC)v;`Yt*Ez;LgJ-7I(4W<$X^JUL_UK zFXizuFzBOcWY7+EU63rN&3LsEh9e;0r!$H2ce4fOys^TUXWtRy%TpvC_E%jr^`)3o z+SNzeKBC@{?+*1Aza5$amPrWi%aRc6TqpLAAzMIJJs>#9I;+MJs}$fh#8?h&5cLQ% z!s2NOqdDSXNhsS3YehV<-Beh-ZR&kfxFUl*U0q2aC`LdPJV+GnYLF?;;Y@=H_m%Gs z)r;S*@42hI4h2u<;ejELb;%o~0`B5m%-B6y0iP_TrNWC#7*zFom6|>d(8-ru$(O&N z!y?~mzC4El2i$lXe~#nNA^hPflj!lR+>EnHAML6FE(<(OzB^PozomsINeK4WG9;Au zC}>!l1OK`bT$qBQalG8lc^-gbXa^2LJ`CxjAJErZAfP`Cr0#?STz^g??hf@c+~`xx z_yvCS1=(=V7lvFN{WoJiEc`)Oer6h(v#>Dd!AX+WewQB3btS7GM$ z9fsn|HaT!ue5YKQ=G51gYECWIocio*9;c>At~Qkgc}7l^^saCH6<){sYkt$5`s)^t zQ^o%1`j#+_aOxVvsjbjLVy44?6((|O6BU$OMrckQUlQZgI)*nx4twM1Gm;JMxkfEk z;M5x-)yR2?yCv@1qB*tPa4Kws*+2KvoZ4cM31eF(zLQ|#l_g-$IJ3SmTA1~@+hfe? zN_?AY0I#!~hoV#@rGXqJ(7pZTyF;b%8>BQ`#t%y5ZW3ac^(crMT zff!-dZXCe%r7$~3YhWpAn>30r>vsq=Bl`yNwyA(A)B=oXM4qlzAU!-8Dw|eOA?@c8 zL|>MgeIK#5tILs`CA^5)P=|BmyF-oRx9j_Un%B+X-Vg`*I1OlYc)W|7J(Pzwc@O{Rd?eDF46m?=p;nEO@;c4HwCGhpOW@sy19bAR(Q4 zybR@i4a(O1n}^~m3q>RUW{KXL$iEjLpXT2Q0-;?64WvT2Y@Ac&yF;A__x~mT20Z@d zf&kf97`l{9gb!E-G((qMhQ}bdBH#^~!gr4EhnF-j_td=np9YVYPele2?j?{%i`BFftvCA(3 z1GWgncJ%_~HX#3RyZ_r5&$-*F8f5an$3Gb7!3(ge>g|D9z~zm0alLe~9_`+JL37BV znnT_I!^HLo9xNH#)#;FcWD>J`qjiec^!^$-AL{n^VLN%3_2=bGBLm(&!X&%w5p2w3 z%XynOnouEi7p#J8%!@~9as1^OaVA-TX|KaoU)& zf5L*)NGNap`3q<#q-s$;u};>m_JLSngLTTlvr%=>75?}EKDN$g6OyIA zqA!$pjFgfbbJs=SnE6G7iTyL8M*g4n2R;ZGyY3H6u`Ycd7s0!4yR z8kQry2B993OtG~*z4$;>Ns=pWxEIqu1Jz~7f@=y;T%OI>D-X=k$|_*-ql>|wfhwCh zka8VUAY~I>v_!c#Hd+qs&M2Y`9r0H9>j+}f8;WVQUWMtrnn+%9{EZI71lGn zr8V#f^F43!Ny`D>BFVQnBf#`7ma!xsPRqU`L1e`l$O5w*9(b2~aNE^`t;D@t=kbM-~ui7t%sAK%oOvrKrVeB=I8 zeuEH}p>paV`M|=k+SdeEGx$&85MzC7Hy?G3`PO_;BC1d2gOU|%A8XCW47I|fpg$5hPBATT`IPI9fo(TmNemuhIC>5l6tkZA9)e;4?c{+hXivQ87*h`n}mV~7jSQi ztg|DbWgfYqge$67OOPE<>nyjZ7Le-+nKP}DTFWWHEK*;~?hLb>aWV?eM0#)E3RW2^ zSWUO6T4b2Ma-V?13|HeMZEPS7>m>>OEGu!ii@bWc5@pMhjygn&BrhxAV)HC%$S{xC zgQNgj0vvfJCP6#cd?*VtAA$+3a6)XwWPY7jq4}v2h4p+~SE%u-dS-IMZ04Z5gzFJl zSV=-U=wz0?Py*sZ@9j*DMTio6r!2{~<7FLLU2I5OHXL(gB?q7u;Z|p!| zr2+}TN_RYbI+>tRij&*O@=3guoC4<-9WT|)ZDhUmotj?$$vVE2-?@!!LWwW;;&XL; zg^q7xJnwO+7UYLXe9mW<@2TNFo@-qw*gcj~1nE|W~#tDyo4{EPhPxX~< zSAPzV@e$(^_~={AwPJjPyUT@cgbl$*Q;|KUor0CfQlxPqTuJ0sYgDx=2WjO}E8dUe zPDIbR(p$K%Tav)6J6{60d*&<k!-u5FydvQ?v$8J8N|Gf%T5EsuVYeI9%mDVUnl|b;{9>3ygGu**^y9q z@yE^vvI#DBW=)vMX&?$!`#VEr-7L)FpkpEsCU!mh`86RiVDv1>eb|;0DngEN0uK;=#$-L7+sp9M?^m(+g6j)9gz&GQv2DWY8w0; zW6H(tRAoAj9iW2R&kj)e5|8npVPNa+nC^M}T5NyDJ(w8o#^VeO=9jW@#+ivLVWwi7 zX<#j}Twg~xnJ44%E^lX8QN8fCFcUjLGgB#jtYXYMaVtD~g}LrPE(|a1JMy2$dU)qR zGNLH++0T0WC(=*S>GKg5)NA!fQ6_1@4)cX(92uN~_CnU#a*hu=BT|Z!x8vNdI#_2H zQgcoSx`qSilZb-kz}RSpCY!_T!1--&7C>*010QW?us57x;9Qum)0u%yy)4OPe;x+E zbvkt`96k6+0HDrAvY@lDTH@z7G2RvKLLsI}YCOq(LJ8kswME(%C;y0Z&uRklakT6d zv4LB7FlKf(uoq-eqJwu`$vUw&TY*1@+JX~CTe{wscQ!Bm1i>OK;Ti>}uqMD_hK|l&(Set=~6F7v-CBL*`1|lkZF(P&j|hu;tx(Y%2I!G z^c4EAnkl;sI@EKgkbB$J6XN1N9Jpv?Y4E$XzYbW{?GoRqZq{M!7j=#HFQWfq?O#Cu zB>KVO2S7QFkIu9o$N3#+PGih2lS*f1mdEJMRJlY8B*R7m5ev4g6EOBd#Rcy}sjSDi z!6w%FXnnDBCUrL!)k?-SMDM5{dyyD5+k;oxT^OE%V0#FJOfxun5&)#U66xa%BCH>D z&xh`c_a7Ek2wd!rS;*c4INd&yB{twLWY2^7+2KL%%@7&`^T8)k_Cjf%v!!H4g>B4| z)M0ilMro)Y65tf!Ia`r4WZr?y;Yc%pcT)w8JV+0@j2zRDx7Znmo2wv|!i;97?eLgg zszJQ8MEI_}RFC%=(Wb+_DtTL?q>MbVE8+)d0L_v7uQ#%lRy6KnaPKK+gG5;>n3x^n(SCko-NLxiVQ zx6)6}Ez)t@`HeRZyu2~aAE@J5IK;C#1$K<{eL6l%$CrBX`TQpQ%_j)%QXQY~#gh;u zezlIT(D4$zV^%5rUSMPEN_@*6M)o-} zi{*wrLNY9GIp;$M3A6r~jbL`GNec=9LfPJy>#G|Bd%G=4ER=Oveuo><_Xv*r_zvyH zIkIoa0~tw$xvBoS`|~@Lcj!N8wI2#7HwzT(m0P7AgP7v_OdqCkeff+rTZi5d1C4L$ z8m`aa$_D#m9ngLhZnqbo63`)dJG9j5)#RtHMjHnpD)6SDdHc$V7t;AoFfu`D&X z2l3^d0)kJf3}6lSAB=@)K(i)nQ@rmOy`Q41%&1jY4k5^%w>E>&bCUgTI=547X~A;T z0eU;dn88Q@xiOkQB0TolwC5xI_!RSbC$ z>`uIqN+gNvH=kh&(L^05Zi1-ix|x=KXePYFZ8wneg1qk=h9o^*kOeJUhCoqQ1a{E5 znun)69`Ca+3Io+fYeJAdM!SLJ;iQJEa-I=GeUCkzPQ!el^qk*bbfJWB#qvY+pDf@QhOPtYsgBy=Mo#v-u z04W72INO`jh!D~8Lw&ZBrS;UCEDZO=)K$H?9Sn>#>sXszCpMSrIH~lW)SFQ{UfOd{ z>djF)Ui!>TGH8@!cZ&M5w~jC6cf!P}+>75rZp3>-I=+HskE=ItOXQx^n-_G<9@Lxp zjOi+>$ZC6<*pxEjVE)L&Ca&JBA4(a}uHJ@=!jTMAql97qoemSee^&cz8NX2CvHw|z zEn=9h{UV@d(hqTyjhUjHALYefH|G2A$FmahZ8>{e_CEZmfegf5jr$*mDNuY46mcML z6TTtMb4CnIf{pTz(D1z~EAag`T5%Y#_$tn&AeV1^U5_u7mr49B>Qm|unSigJKb9fg zc$3BDYQ;cSHMd|{Qa&}Bp2s3jvAxoA(=Gwf6+ULzZ+uG9WdG8pkV zg3eR>aA}IS^pq7;V=EoTh`%b2DDbbS%z$~RT`fKYCB)r07(-g{DnWnfJ_3iMLMu9* z_sHls!rZi^H=yY_`B`{}ppx%{^UbjB(bv=>G@;kNvHh&(jSQT9lq(`;QeAVn)6L0; zHpxXzXnHkOCKyX7Gk8C?zs8Rc+{uimJ-)&#%_5wy#K#Z*nj(C_`h;Y-9e*WjaRHm>F}fwGU0}2+<^mh-80k_@&YQu=6CWjm%9n~QjbGjKCe8Kr(N@>e&jC z`vBfZtg~-{-ej=jJ|}$e{iJ(J?5&Zt;2^wq5wP5mP}r~Z(BgyBrhj?)$WxEwgLm>+ zmK}}UfP8XKFviAWyoFJMR~}4_O_8tn@{-4=3Qly!1XQ!c{v~n&^7GE~Vs|tq(HDAo zM{B$%#q)NmL4x$c<20P^FX`Q1gwe28Ewxr#_=$%- zaGT0`87Yy62qe_yGI{Qh0xjMQm?Hr5Tn{Eb&=3OiaRW0|!@SqPTuPX!k>dc9``KTA z`Toz2QvV-yZysNDasB@%z}2AOjSGrZG_BZzRU53aq#8|x=#7RpiVLpAoz{(Nuviy@ zNs#OHEoen;l}g=f-4#R>2#W-Fz+J20QkiR%AS&QSzR%a0dEeY1{e0T*_xI25J|4*| z?^({AIdkUBnKLt6?!9$P`S!ku?kJ3pLT#0bbXJ`ASmu3oP-@-Bsd-=jAT{t=nRfSe zwLcW3jD*{vd)ZMpKp?5~ygBAZeTKiTg#zcs3BXS(sMP-@+Kf~xWTZ&UNK-BN|mrlKC#am9YO)W8L-2}fOpjGKN7IFd7J z>v&tHM_tv#Uv;aRct~O6g3_vqyU6|w3A$bvCbt{Ys7-TEk!uyxV$4=D%fJPb$tyn< zqktbKn|0Y=a>n)jg};eMDJN1I_JfOhbSp^Bgc|ibC{<2WvT3QYAIK)Y!7RNsZ_wS- zm*S%nITWJD4Cw936z>CmzScy&pu4Xw+9p-LiWn{$NR`h^PB4*_rqeu@#ZSAw zz*7@JuQloIxYUdJ0k8zl`QmixUc{yNRx5%|F>3SxLb_Ohq%xQj#(+pl$-Cxn{*Oda zm~ZItyv6&mcyEXwnd0O;R?31(yx}_H+xpf3SFyjRzebENzK}m>cef(X?11s{J<{ox zBb|q}&dwxGoycQqBA?`pqeegkJCCTEcub)g-)VeFAMhL6Nk3+PZcL~_SQTl|3v`{H zj9%pKC{32VQiH)ep8feyoI!D7xYLrzkmmhuxpMsiq|gaR$rWcyDItkQT;ZY znLeuT2GvJec$ zhj6y3?rJ`Q^psbp{Pbq_SIUnGPXnN(qOr)vt5S_C*VA`gwx6l(gRi!DeQMzPs8{#Y zz(wij=CyTCzxjFU&MeolbcBrQx6{SkFyHT68t`qlf)6aoRxaP6z+Jl|@|H$!7_@~p zf^+EKXE#0z@Ae)duN!3TJvR=mTs9V5=DFhtZ*qRe>@;!0FR)n845(%rZaz!HDN3v# zjGUDIjvG1=p*TxI^LT>i$Rn`c1)QC=4xBEziNFBV4ep-fiwc@xfhApkfPz}4N&xBogXg;bI$ zWE4)CM?_qUdL}CSB{{+C;BD4-WN+syI0; zV}&QSk6Z9WUfFpqSWa#?P%V(OFZn~nGlHT$`m^JS&XeBr&NoVeM-ooauu(M3DDg_e zX~p7Si4spoR)Tw#f)DOq=BR=^BG3|ub+9TfW^S{a^FER|w9lcQO21Yiw1i~mV4LoV zcvUJhs>m%rwx~cY(fWQss`1m2wdo}_<~gU^f$HVaN3josg=<{m}c1UT;=}6z{v%+XVB5yXMSMB zx8QLjKIC?doSy*yU&q)yEd5_TkZE1ho>^%FJn)G+}{0IxD4_83BBSHKF zKM$092F->nx1ws1C~s?UJ{1NoNm7_n(qUXBg@ap{0*qZVzUT`{mpo z!dBGh651yc*pX)Lx}#Ldc9G~0+>f@WxZF*xYkB(tX=+bcawoG}t|Vvy#O$h0tU5_I z@1Eq>otxs@SN;sBa}4KVYV-`}?Y@2(jNB(CD`W~|;F|%hn9arv`~>pCXkO~g0AP}& z(SzaPZtf6|UG^Q?Q}FOg6V?J}e&0TN^h_Mue^>W=7TU=f_%t{^0UJVMFPfAc&`D43 zggWuB_8PHlcQQ|W@i@9WlSrH4HZZ!~SVCa3k!HX?&zSC6^L2xKYa}xzDlYQ`wsXud z^O)Mnmgs9I~zTD|Mcr5)gl&fiuH_E>yEmPe;F9lOfb;(I> zM8vgtw%n5fz}DY-!IodJqAP7^7@>TlaYw~NsF+5~p%xl3?Xke0i}k>;vFLZLqQr$% zWRuK`dG+MAW)TIr36M$leiCrK?6ZumSvwf9m7VsiRxc~v1UR<8k+#zPDsx|n*GaH& zpGvx_hRZZ1ER;7nqk0HR1?Aah3y2NX%2nHn3$L8Dxi4}6MY{bc&uvWtK4ePWA6S|p zD5rFpeWe?gxg!xPJu1D@qrQTYhxYeHbKi1LU-Zu?8ctWRWQT%T&-mhBeg@VURlK(k zSJzJ7hFYFuf)_Y1BTZQoqTcKOE`>RF!BAZ(3 zPjwX{btbz3kjndgj8w)v0#lDhP1D5i*S!PH{}7t5`J4%cd4(DbT8KBC@%pFmgQcL(tWWry?+Gf`;NCaax$ zp5$$}cj7Nzg;(j7PnO^VU_k)-%JZF`!2koV&bIygzHo7Lp;UyZxrCIS!mK*x$N z6UhmMYCB2*Gyv;9O25&#pa*J!ElGRpgu;S9%t=N5IL*P)zWWE=Lg%@fQXLAZ6K-0l z-A#Z?*LL@x8{2qD?7P!0;*#9nKZfK|b7HN7( z-OBZ9^V)Y^_YNpEj6O-z4WUoriShY9{`AM=zw-!f5q5HjG`zMA2z;L>d|BsE#rUs% zR}445&-kE;BmWMQyl!Y~^jJqz745sL&{ruUV%fndC0C7zhjxd?71nkqp%7RD0{i?y zF9r`4l;ETDz2LLgoIY@MdR6+>^jn23(OBtb_&cDyYT^Mq@P>%tsK*ZDHyDlbr8aTtiD zG*nmn15}_afM*!(L|=K6B|yvGL)j6qVwKpXRZN9b65xyZf_XqHvB0_lvPOoQjh%&> zjUmx-#?G$x=f1jD?y9!T<7ynW+4!i;4~tc2IF*Mk${3v{c2h@n4_^)CXtwODb&-@+ z|4RD24J6N9y*4?{+iG8>8KK&gSALDQQtuD>T9lNJrM}!Han6YERgK>!l2=YwqoY2n zx7xAbu+w_n#`DV^E2KXfzfe<7-lD+IYseIR=Iu~0*?mK+B_e!otw(?5vcXsEZoL!* z1-S3)UJY?2?vi7`Qk2;DCz@q=`SH{G{n;hJU+LK0i3OcxlgwYdu#;?B2?U*6JkJz> z3uwMd0u}e4k6}(rHt`S;2EPo&lcz6qY;VhhkzmXIxIk9 zeM~fBv+VN*UK0SZJRy8R-glwDF6i^zBrWn7>8nZT3BSvbYZiC_FcJXn@BmCQtiVsB z5u0aExB55FZj)brRI%CI9SX8v0IAJaQN@l5f7luBrtmAB;kG%17j}kUQTVYCmS{Q{ zqV%F^pObF=%*&S0M=ASs$)>MKD9KcNb=gk|K#32kgbVQ79F)BPynEjxKq^ZsmLxgf zQThr~D99d`^IfH{@TG$6eu^{SMZ`g6|3K()H)wE16(gTRR^LLbBdRz`{tZ3wvoqWq znWSxqM4P9=P(+pJIjXx?F;e%x<8BQfN4P1$$E#t%SLepd*I2O>^7Mu%rTtl$?_Xru z-EPu9QHx#XvrttXL3;l(-CV&iUjJ@Tl3O~($H|Qyi9cM(xPFX{0FF$b)?=29Y>3U% z3qx_(>>UbN^yb3*Z4|EADBORe@J<_rw^5jKca(c(vb`l0$zWuCa_d8R7xmDRRQg!- zI>(kIx88gK`huuz{T8gG)8Dz0j&{uD#`K!Wa4!h!a4qfabGs|F&-L#SwJb!f+Mpcu zFKQ+XQE&UGCyAOHq89t8d(;b2+5N=2=|r7`5=Q&#o!An8(0+9$F?)3X0#2AleVSE9 zRCd|?Si{t|HS};ycQ)Bg&M*}Ri=6Lxtx9>_H{wqA;auxj_N@U2QXAXyfANbCcouTpe9(NDgC{NYB5pzy9Cu zk6-;wyY##9{`hwgu(dB`{NUPck0*FbZbvEga?d;yZurbwxbr+ zpMfbg8#tVJD}Sk;MT(B6>qs9*)HB27Y9qb=XQ?zVtRBuZj(UUNqRr_7-!_BG^5y5j z6oE_ZmgMNQ{2fgo)WS=|+ol@7F09|#J#Mo*ae7*a%!_)c_x5l5%bAmtGlmpPqVpfy z=%00Mjgvb`Ab#0QcMMD43Xsd{6X@^i$JPvFsd+k&HaC8o{KGFO4^QEkAG5?Sn7Dau zhA+g`rcWz6cu|j^s1?PUeuCYG_Pal5+jTMuz!a(&c6r=9X`ie)T9GnBh9E+|FGc=3 zdL=Hf?S7cegheo$zd>}ozgBfrZFE*Ki^0ZESSj=5464Pe!JOdLTI)+U7UGty$krJT zSFcb0;g{M<9MeBJ}Ze6;-_aG$60)*2Nfw@fELU4So=|ORD@`9&gY5f@jBp_lv68 zqVTrjT>oZvsww|x{RsBBl_X{JJ`(m-yfl-x=F@mG_`i16^&oyX@K2 z6B<1HF(og){7FXC`&G(+(V1o-M?$av(xu|FB3Jcy3L z{^ZP1#Q&51$qz%B!Tw~MP-a*Ald7Xpo-wI;bF0kxdKPXBPbe)MklT@D*jB>Mcf~Lz zRrpS-ye-+ZmLcWm&>-1#u?=}t);5rjhOuo7R0GK+E1Vt* zI>HL7f1IdeLezmi>JFlQ5u$$Tqpl@t-w@T;qLNL2RFzR#{}5eh(N)RopU$4i7vEl( zVNmyb`7PYO$TT3HHFqQ+xesTR%c7)>g_TeQV-J1qJH5H;yK)mTrBp1Tfb%M(tUt_C;&1?r z>QA*+8yx9sG@Iwrt2`wrHVrhrG&6lHy?>e`9|4%=ivUm0qlVY>79clg=Z*kH>DH`W zVv74u3opn%6XG}E8h@@jD&7k?_K_VpZDu0RUU!{^-VV-kp2(teH9J5HEi>=iQY%=q zS4=itOJwJ2_M6W%S+}|iC77k#<86VhDc$W#aqeqN(9X8NNaQZ$`>-w0Wwrbdm1*VI zpVL|Pt)c84RCd(cJ>I!5@Z`g`FYwF{P=<{Cx?M{u*8-h%k^ipE$$!Zv+2-c91#Izk zATi38-YDDO^RtclUN#vnx@rdhWQ}9VTi+r?ehH!fs6#h?wF{?iyU%SDj+`s0(A|JU z!`>^pYpBlTMB#yVhEMEIr|-!|XbWOZb%8rqqK|2MZ16_CpD$9+jN&WTIHh5MupU*@JUEwQLFlL$}%p17~jx&IOwQC;JtH!sywTzTdwo{mkAQmEL>f(*L>n z|BBzER{C~UL5)b4YUd##YHy3mZ|8mAZn~Y%ZwyHz3A>>E>rFsnHcol%{MElH{eg{3 z-+klKPv2DOkDAh=fldbC~NHo>#3An_H2Z=Zbdk!1l4K z=c1~{4eU9krJ-!xz&^*H!hW;kuY^-`6kE0rXH4(WPqEpH|TUWSR*(){iy&p+(829#kJ|%4->=?rclfqkmO$#=@F;pY*CO z{jjR%LUhJpKvziO0|Ph9H~w3Xf!hcSO}|grH{&kC8)Kl$KG8a;DQ^Ea=Jy$s%J}cw zuN~t$nbVFOvNJ3K_i^MKr55t~CPY$wLnIW^ymjDFq|aktXk*u^wy*nK`4=N{b&B;*kmwqqNvF%TuHpR(qxT*tl>k z+r)W`PEUu?=tTAan6TV^L4QmS(df;x+%(uFyqz&?PcPBv&9gnaeBa!3uSQqdkKqp9 zw}L!#=*xnv?l1Pf=M`tV&H0KmpZ3=0^iaA76lXrYoz4pWf*FV)JHyP77qdqmp}p5m zSNG4F9NuX!&Ld5JHaC6H_)kpBoY_hn_K@W!ti_AmF3j>~E$;1su*J?Z6(8_-GZoiB ztaFbkCHCTaJ(g|$u6E#G``Fmjlbr$inzE} zH}S7?x38knd4mD*HQDqXh>1tTfgfspu+AOd1|%AEUW3kXi+8MANUhCyBD^&<606@{ zlWAQkvXYE_NPspB*79+@b>&vJNznQ}b+vz~Mr+Bx3F=xFKGx|Y#?68BJiSiW$MFl* z1@Nwz`p_3jxZjk$bK6o+m#F`}eQ;&=Ajk|dIQuckpbuO?-9P5no(#?i?zy;m3KQ8Y z)?iDTM+%%85Cas9i}=H5y^J}4_!Yp1>ng>+&;%ggjR5EZHzcdJC$1jRpS{*pYg7Nl zFa!PMeaawc2tOT<1hi9b_>GP#hjHZ!`Ij_Iqo)gg{^E>8Rd`ooxl ze?3MEl(DLiLoqH@$on^68AOM9h%zHecdRCP;GCA4SnBTa z8Mn6h-dp(3aGaV_eW#d8im7EU(yGlQrZHIxxXF~KpZqs@FZ!w$G*H?f&m_i%bkpK* zq|@fDexw^Ea|1sJ6T?E%hx}J7a%SvrY^hYz2EvrOkKhZqoTw;zs70=yVfwn?n${+< z?D+niSUSImN*D84zhP*8H_Ew!Xu(^g8kP`1OIKUy>U-MZDA`%bQYTf@_#LMnbdNDU z?DW2*Uzl+=pBRiuGL%r8zOVlqlrRY6bX2SZFsr%G?~!MCX^Rg5lD<|;ySsLs`s;xH z3_7iiG#Kk@;)R4f#pEcMRbu%VpzUrmTgO2qM>-h}CdLfY`J|#6c2F@{8zs7m z4&}3E6?)kw7G{sRSr)#HfLfAY*b_GQb{1CuC|G{#SP@Bh1}?8p?@)Z#zPr{(<@eDs z>dt&j16a7$as{oh+2;{0{xXTvj!{KAu#=bGO}BZ=h);wkC5NX%=susSGh%P)TY5B5 zs>Vo)2&PRNC?_gyqU|WkkB3TJ$7+(hQ$7*^GJ65K!G2;KX`t;O(74#xdOydVs(u51 z!VYT8IVp8_winaTJLp$|1E3Qw|3Z_4zYtEO%s5Qv%RT#?{6U$ef^%c z#o3|Q@n07(87G_8C?It==Kb(g~JK1cf;-kcsDl0vFaB@b$#35x`*GiXddhMv} z)i=G|{>%qf_wLmF+P1s1wN2Xn^3pa?1BNYa5BmMvvin26YkfZ5X|dV%yBEw6JQ#+# znybG8B|~&rVr8FDURm1%e*U2C^&$TeKK~Tb-L+j_{+^xruO!~Xo;{oP&HWXSxQjo; zmy+*%e0j(o1YVRpW-sRzcZXeNerSFKJYr5gw3urrAn_U6to=?%b(JV9{?2hP#|Ev zKpB&PyEzfyE}`O5gS&9tb_Q_SjU+W|b9d`+WdTE})q_6F3Cbmgzy1t9Xl}&NSQ=SC zR~YuQpB`$9I|Tjg8oXUPJk}32elpn2W66jS=VdhQKs9%3L{o%E*oE&z%;VbKEi=?D zD0Wvd-hF=-t3OL>GyUOlQd7nq>jBF!;MHi3y7pkISlLl$`cdpsIP=}^uKva6f_reR zFH*}ogA$280cN>h1ouPSwzV-np;fz_hVzL}Yzd}y2_1Iv;SxGcXH~8I6VU$3!>DYF z*EDXY$cP)pcC&f}w_#4Ut5(`w_C5Hl-k-B4uH0J|Onm-XOyFCu=_K&0+vv!?(N{*d z4U92&bE8D^c6XuHoydQFj3g&@H;58DQz1m3Z2BA&sFqY_y4oP(9!*V==IZq%l%_)y&>t3BfYzoqU@_W4=(hlaSP03_v>QxO{~$F}qH9jlt}2&sb~@KeH^D!`?p#YRd37 z$AJ+f5^7VF_}#~S3+ia%dAM}(1vqYtTQ+oz0At6yN=wKr3Ok18G=9$Qm0BF5U{s94^9L(*mk3}UeUmbViimZHWq*T0*&mDb@=c%(9 zO#)%MrqQUn1?BuqPu9G=>N7^P6OCM5ExD63Jn445&%w_}j0bWFS^rojh`BF_Z4?ctWRq5bZvVLWCTX!q zH}wsrTjzfCZbyfaL-u+;#N)XW(!)sS&i$w7^O0tQ%yd73E@uP+WVPJXU$x)5F@7+z2%nig+yeG6NV}(JDw`j~XT2z}JGg-QeDiBH{Pi<31SR%$p zbW#gFl1iWSkP_`oBJLi7b3;x;Q8&luXr5!Lq4ft4<$iJAT1w(FXY3HQt=(cQ{FIdf z;#%_o)-&(%mM55$)*pqYYJ9So|ObnU-EW`gr13u`NTzJzS-Z@X6_ea+O{$NJ1ldqzvALi zAg;kkVwmn=Ew?6La9C&SK63BBZDQ+gwLi6w|E`4(_!iz>n{K1*;Wr-sok~E1q6{@K#JOSL;K@o}Q#ph7^vCrl+cT zpshfT$1EhU?U$gA9_Ivn{b5pnWoia^JPBj&i#LUTb@L#J#bAx3LvbS24B z8nM3vtJ#I1)bM9psI`Hgk3+()jYgI*Uc|epT=|)KG#XBQOCyJozF}B&Zlx@XqN=)7 zYn3ExI<=}2AkX`vf5D=vI;ebXUw4G*cw|?TYuj_l7qE1{a94$T71YhneFDsS;Q58c2oy^`)`0vM{?d0Qq%AMfw8<)`=_%F^Dt9I!to(FL*;$ z9N8jvx9Rd!+QzNx%SRjX*Uut$o_aE_rMU2-R(oz-(b8TyDF4-e2A|IZX7NN z;e&&_dtTU&gQ{Z(wFH|0nN*tS`a$^5tcMo{dg%MQD?OOiP zjt=+!7wTW7mwAO=Z01yBkrwVHHnFThu$suGVtOkhb67 z6+Xul37UIIs^20WnvtvH57Xq5s6+`CE0&)=wBXicwj!+n;ck>?Dg09N(rO`Mu)1_Y ziB9jNvjSzc($N)_sd?{_BEVL-ScyyHR}O%CfcVi{uc_Z|@#inlV69MQ8F@S`8L04^ zRQWf_rZd1BvmE;1_C{bdUo0( zt*7#&9ULjmpAKWVldbMrsc=xe=~&&Rq>=t@aEhxRN=4aqZX!E&sz6zwslm1JVGAo( zJ2PIM3b3P{8jx((9$qleP`;ro6)&wq7s<6iQR2+6gU~Wl?E+J=DzG29yeiP2hcRtn zcpeE{J@6{**c5`&Ifmv!0X*Re8lxn^`w>!*S~M+u zk6)2dP~R8vy(Y7{Mj^HJDg^jmfy`6ouO=Jo1t#ZtCMyG-TAaPb#H32AEgV!aDo|-- zRa=y})@CrV;$~&bBnDUcb;HG>s$30F)AnH`mDbW3m8oc7Y*W{{cVAXXp0+BG%c6e< zguC`PKkION)SG5$w}TM{)JhZ9bt3_}A0W5%bHwW~F4w}-ofV7U2V=w6eNBqJn&<-Q zN$QvK3HLq(04pZzm=lvT7@4(!^aqjNb6KW=a*E3^&N9Vo=NBf2u4{b1TXN`28V@z) zEn~8kO>4(gH9a$C7iIBO%ecw@kuptmNM&H!*iJKBj8b)ljYZwMCjGTd+5XEKTf?|)+zC~_}r6Q5XJl~7i7mNye z7zuyWLsiDB9swf|`fec0jU#2Z4K(1Q3u5v=%~(L< z(#invF-AFwUNpd#Q-=`#UIQ-ry&nRe^y`*rH1@gnJwYVWpM;j${f@aITVSPutxN$d zv{&Qe!t9?-rqK$&m<)qjTp`k?&FvK(D=cEQ#3j=Ktnv}da}n?Oh!=Aa&-;kk7V&iU z748?*>^(oYj|BJ2;1=%Zzqg0*%HUoX+^cZC{g{7mI{l^DjE?_AZ$I0!V|1JjXSUF< z%zr21NHDBTYizH4UR~I);Q*+C{W=`K#n_k3`q@Qt+Ahf)Zo7m7;&@nfB?bHK#S&s! z20Kl_rEv=UgY*2Av7Z^NMJ1=N?qP2Jq@B6Ui76M=7IwHx>E>Fy&(6=^07i!luE~sZ zI$vrtLLu85Lk5KH#S&LzlraR$`?51D)S}^R*)UrCjt-ZyrP9}1rQGU=-|yz(A0@w< zgTGRKD?F1JB(wnE3gFdGe$CPPF+h>;*npKkY6=rIIxiimC!OXH{p4Toz2?`5&`90l+b^{Au$_HweZoCFxQ9 zPn=VDW>LdX*wg*sN=wu!^h?!j{uQi)IQA_v`gw^$ET&k5ze_Z9=WesOi`X!qi?z%qWJ21(AGT9=;Wo&TWz!QuFN+3QS=niX$+ zT}|)=0-HNgQ)#A-P4Txf2ls7UF}-ndQTpJ%u0?}8N*wp8kixWl7U1*%9Bo*fpzdi9 zJSHDV;RRWx}*TV~KQG0eYsxL<^aIpAUvHa%Dl&FO4>2B9T{frTdd6<4wWj22y({Yb)|v zAqhMZOs9nwuphvCb0nmu@$_tLB(mKE%xb~d8P@5%W@zaj^ZAG$M!d345k?7DJj>$# zK@#Qki=3PLB;b$5T4LcZJpT4{Yo2BYYOwq1GlIL%w|SFEJDLjYW?V5Z?79=q5o-D! z1yGIq_ZW8&WjM-^nDle^fG=a^;`R0hE`&+|32n$@;xT<0k98Wlv=HlK|;$p z&S@gXP{ZuCN&+Phb}y-wBz~O4HbJ`C#I!wUdb5h-G{^1PE-|6sNy-zIec9yEbHg%a zY?Tr#W8UTN=UhwM)~q?cw9caP%$HXG0mi@yj0L_T)){h$XK(gN!7)iwQUu366Z(_u^si(2G-k z=LuYk<9w5{cO-m_Untn~?0RhJ-Xu8b7#Y=63_qmq&}7qZSf(Z?l}i$?ShD4kExDft zF+F+BO0rkYWc>%Az2`hhy%j(1-ne7^k5U!$em3uC$>zh!Ql+(y5{zBiSBEQn`F@3u z#M;;H2XqG@lDeNv-hzbp*#x4?h}NmbsO%*)?ve>pbS-j%R4!9*;EOtbgIgm)=Id3j z;4(C^q~QJFvrr`a4coGtgTlTi*@K4hWS^bFTw|;0bll;}PR=2?LC|EO;}68O!()n= zS$nxL+8W~X3Yw&wO5{=}8VOz`taG)6Yr1fNF?&`8KK>1&glKEGD2xdNIRMpX(TTG51z!;#T6~ z+Q2kX(E^%cT3@m{#_p>@7ACJSD=DLEHExuc{B!@^3O1X^6msp6nrgQ5GfG{FsdTB_ z!{WbrKldb0oSqBhaLx53^?cyb zr~Lxr67VOyU1)eLdn{z?(V6KuWfJ)5RxXsbJ-qWfIMe$uQ-LU6Y_wG+V^7IOMvKPkXmR?kQG2eT1 zmOJ|eU+%A?p$$E=hmo*zy_g%-vy`af;NgdiNH+b%>OJJ>3(pv{P1VdIYNo*H+%lK# zZC{2Ta@6nu5j&m*0ix^FbW8(Cr&eU&V`~HzZrN`YK|dU!9%Y_@ZX|>TBdyf_*Bh18 zS1V1#k|ev7j4^-7v87^Fe+^%P9y12(_2-GdC>O6&pgrA;1-4gkzl!{&U*!}7ot9rX z(kn0g5CWA@!iq9+erdSbY3rdg$oINVbWwiN$EsP7N?QiS@Ht-bovmcWv*M_EB>$dcmJ&KLIYu9mBlNj>$}F zWHGt-CA(&Jvh#k6NF~i+C7?>t#K|xN^gsaRrdjwp(_pGb#(w}+SzA7jXYDv;zf|P1 zi`gkiv7GMJ-(50K#r7g0F<6sKs2w$3ElPO3xFm*bm9F^6a;puhhJgMC;p;s>i9};Y^+bcG^%R@Ac5Mrf)HhLJ_ksP>g zpfF50ZGW!*m|>YSpc(G%<$mhkI7 z#cXgrsBS9K&YUd!?$xPw_yMTq{K!!s=XEoBM~WA3Xh2byG)gm+O5<#TgffMdA9 zk(@YHsA7ITJ1xAV(FD#&cx!S>@cqAGzD38}qB_bQia1dOcV0tDu0d^R>A-`$Y8 zl@WE=Ia;)yBY{VKMgb#Lz_9XF^~X&11M@D#Lx{mItHZ$5(KRmUKe|Y7$obLC(5#&s zhUQ9?>?N+>EC`MvIkJ%A#ypZLr-m`Cz51NPJUSUZ_|)>i2Y&<~JnN@gTy!6|Jydhj zGl-(yfy2GY15j?ekqDqr@O^-7&3D_JKn$lDy6zWIEa?IJbfY2yj+_-q(tjSnlh_SC>t z?q!l>&(ZLVD%MWJa`QGVLg2Y0b`QKaxCi2DU>%RE@uc+tw{KJ(!}eC^iG}f>tf!-g zVXtqC0lQi+eJI4RWYDsjb)VH_a%+Wnbr4ntwVCaf4AWlHJ|M3q)2$}`G8B!K*^5|n zhHLb8;FC6=YSQy{QfILWvxEhv9+%quml6_QP#+E6yZwAGCk$75WNq*+4b zLs~p?4??X5G$hG=@+bBmExI`{C$B&tkTDmCuq<1lMMk>S)~4`0^rX9#xaWwJeD%4J z*wYZ|7+x=i&+@sBIYmqrN`tdD^`8bgh(1%e-eC0wS|WY!WFoYE+w_VeQ089woVD@l z{x|W(Umo6GGjOrn*^8zx>>(Nn8yu0uU)@lhlYPBCd&8b2ie*oeU$MZ~L}S8fEcIGI zM6y(3WhQaOKyo4VK19W}QN`gS;eK&u_kztXi5mv^G%HABqGKkOd~3HGNkoYkdyiu3 zGP$;PJ3O(#D@ZMNsM03B{t0D)lu?wGlXF$D8~ub(%dS9FLyQIXmK^06lVy9!4`BuWX#|orrFQ}b~ zDiOo~MvGsFs{V6Yte$U0ul+H(I%#q4N%^!`r3G&$u|-HDlKFq7#q)NjzD?5Nhcj}t z_zc$LVZF7>m8>$(@3Ov${BEW2GZH$;{u+tj>;PJ_d*O9Ey^C=s7{n^}X;oDU*tF4h zWrLx;7{aN7Fu33TeeV_~z!95yB!cee&B_uKdHq>fG& zwFgXqkDu@6KdumZyDZNCdlq%9%GxAZyzp3#EFO70M;4nm3yY?X+jE9zQD1--(Zna_ zu5)+LgV{PQh|tjOv5VKx9cu1^?7qRR3Gv$m_a`C#z~BxH?vBCzxw%hg4-fACA$~w` zD?)r_a3A5OTGj947i4cF+-12GzyDhsjYH>`itL3kCi$TH<6z>;()=-1#hSk`o7bkt zv5pv566^astK)?@X$n|6q?_&C!t;+ zR!Q`t<}VmNydRL+4BR%aCtwCtLwc%zXDf^xJLgoo+ueP&rFkPxGnX_Cvn_x9X*|wp z21!wKour-C<`fROAi}a_v+g^>TZK{B$gAr}r;g9KKyW3Xl z9+>EsxV4$-R<}_>d9)dc1& zk0@Jasv#z7ZV?8fDbsLToAqBmyV$sSu|BaQlJ<#Oo0kw_9h7cfOqaSMuFwUL=E*V_ z2b+Um=-?njvblk9X1WR!j(&+Jm0Y*{)K01EEOqZaJv1gHbKo~B0$}%wHO87a&?oDoim@H%D_vD! zj*{P_qV6QQtd6a%E8SX|gG7A_$%3&Wk1AO5DDkhS1pJhVWT}n%J+DwyF&&d>1T`z! zJ%w&WD1J;jlFV#_^B%=zrmKbOvp<{qB(cvjn6!y*{ky5d5^wgC=+-ScX*-4CT|!u9 zy5I{4>j1MkgpC#4!_01F5vg00T0^|q8gx4J%=@z?z6_y6ls6|=fZNuZ7)`Tm9>>uV z6}gAyoKm0$zaFH?(bN^HH!8c3 zErwdza!sAALI(RnQZMJLhwNw-2F?=@SLR0a7+ME-X=5E1vA^ z(^v2dg6Dml%?>TzZ?He+{np-lyx$OWi}xEcCwspdf+{wPs%Vve~-&yEFtVlwk+53H=4{KRLlm4zkrG@`Dh4%D?-iKye82v$K zq33rNdVMJL#8Bu_a{a85Dbk!Wgx(vPu}RnJu}KB#kOBN|RpW|6cg0;cqxAH!Yesp< zT5mW>_?pCG_XstuvDMr<_c3lFl=#~Vo*}_P z#4qZ91y8EpQ9P-~xP#q=cWWRe?)=>js4}%8{J|-GL3j}~b|m2XP5Mk05E@Gf2|_xzQXkSU%DS7gYZho8DJN>4>_ZJcWRXZUP!r!QGTl7Whbk>) zG)*B+xcE?s90XJx)wRe#VI|T$Di@>r6f-dwqdEoFLn7MfL7{!B3Q9MxCZ@Lh^JLTO z?2Z9Ji_H)=zY&_|L*kx-&W8%fNa!IS5+^3K#D^yP&`2fuA6sRhWS^%6ykDD{UZf0R z{<-X4`Ezo@i+|8~3lB)6-yDrX{V-OvM;5zn@5$xz4fwnm<9v&F#_Pg>!_?Pva-Qu|L; z2PKmBD2giiW)l#iwK(9X zcUxoCCsoiyV z3SUzMF+J)VYnj|weTjPi{$Udh20ZFD=T|K5!XEvTy$s$TZ5PBgGbxRl3xtWxbb;*U zF^A8+LhsSO6}~pH920A!75ezNK4zvXA<&sDafgr6XW?OrIzJP6`7{e3zU~nN?uCcs zlwC#0#20tze%?%KUr!lU)&TFfs&@8%gQ?j3)BTv4qF&UTc05B6S2SA4qRd^@;#Vu5 zF~Mf0D^(2Rk|DNY*?pp)txmDdvFUV1J-z9N2{>@C-|1U%tCkO;fqyc;m&41AG&o!* z1Vp{B65_+CiV`m=l#V6}6H%Z02{9;hQ%SOEIiy54+`LWbhLq*CO1l z0Wt96PKG=6erx?bpwlh2m4;`yPkX<3j(fuUTjamr`yZ13Z{9ym{-Y@;J6R{(B0u;3 z?-LU8qee5(x(9@Wb#Apa)uhjApatcsQv>b>=u#>6R+UlN{E)%p+cIqDGZ>R3!xDu1j#blhrfndZqd`bVxU$K;n`oazoM!|Nje2ibK#nIT#0`GEWf zeUy4oeK5@j1uorVT@m>x)ee2r|3->`AQnWm7=SFygs6K+GK`0mPvG0o%#_v25%sR= z5CQag15iERX1dvVJEMjdiK{xoD*=vVu2sqK^4o}}qaM@O;Z;W;N$y6=EqIP#-R1_~ z4|*CGR%*b_{)ZYh+n{>b`wi|p@vBKweVkG4weo|Aw2w11UFQ9U-QRovV(M{cc)w8L zj`M!&-eKM^jJYcBH_|Edej(Ql^!}Oh_w)W1`M37|hvZLq|1|lZxCh>J3lkee9?k7v z;DtXeV7$6&HH;K;-($wBg9ytl3vRi&PiIr+wq}1F;`hQ;xrYV!g5X{h+&>2Q z^5Fh5xCaJzm*CzU-0cEfzuU;YI($Dq#HT~}un@i`gl`OPT;H`Jd|q(R4DLS@9_~v* z_|g!L-H{=@Hn=B+bg_F%2%iz$xctpRcvNs>e4iS^u^Yp&dx$?hxQjx2;__#N@UMeA zJh(S(BP)p(w!Mn(6 zR?OI3OoM#H+?0z^9SluD7xIh!$y=MAt+f}9Eqq&>xi-kBNjH~}%iY6dpSGH%GrB@@ z{r7gVjxy=69Biz>B(OSu#jYI+6Z;y%0bmiK?!c5D=;aK%tu~qY>`Z9?rbD@8L;HTU={vP2=pF(#+NAZhX^&c= zZ?~mZWzk-HB4}{g2mAT9`bj+YM9`O&!ODM=5GyYnhgxpBRnM&S@?8LyeoF;K6+`ZV zmp^=p8pHe5kPlrykbA}TPE}Ab{%NYsd}=l4W0Or^0lfRwCu=&g?f5$NQ<-Kd9s^Bf z?*=77|5)}z1L;8Ouq7#{>`j~5XI>AW`z0rPbnl{TyH0a`qTeyG9`d@{SP%K^ZLyB; z%qLJE9#PKn^t9<3VHDZdJ8B*;=A;i$&?_*wvPBnw@orJ#7*&P3Q#Z0*a4+SWrgJjB zcvgGwb}(`5EzD|b27iWO_lJRqVq%Ls+xPCAKdUR&xw~xjGF$Ay{l!*CvqcQ<8jIgp z!)fRL8!ss>s6PeVA32R0cUMB`N$g-lZ$FDZf(p53e+H^c_*S*Jeg?+N`2s zGde0=snos5WJ@~@Dj|ck8fcE9xf+%r`s5!b{H*!FV z>M{vUDJ{~%`0!fM2~$LZpD@IG?}nH`Zyj(+=%e9CbTtqH(#QqRbJ{2>8$!svavVeR zH<0fLw@=6{^W_0+31?HHX4{ zey@3HwbV*BsKecN122ihb5D8~TPgLKd$;xBh!=QJ658lH9oh(6v|N$G+wUhQ{ecKnFB;?Cl)r(|LN#Yhmukw-&YNJxex0hFh#HC;X~i|J?=g;-#EcCG zKA0QS%iTg-(MS)!#XYu$tk5pc11EYt{32VH_)d6sim+rHy9NW`RM(ym4v7)Agpr#4 zvAV2Jh>+_17DI;YAXt5_h*WN;AxC1JRHuswwyD8#Z-g!)n8%>@WgKcCtYkRPvAOYX zzJ#`94@M66L|#Sg|NV?xBx#D!fHgT%PeutC_YR^w%^7t)w&ap8B45J%JpN|ic}+&& zGgFMpgBX&ItfKUkFrmr#1~q|dFx|vjx9iCwSG)huJ^Cj_f27%9{b^d)PnYZgq51S$ z%i5IiHuD>K6zk6SbE;3V)=i$QPnH1&RH+oR|6+B@57DH|vAh(gg<}{zZg)zu_oEO? z1(L}gC4f|u*-YD|-{Tgv)n?4du15;Q^L>%BLq@W`v}M;B3?&}<|0(n7tK=Iop8*yZ zGoMl)%40r*eHE(7_kYZMLSa6Cvt?v{49VaMKQj)>Re zqadhGdG-HOddktqO1JEUPGUOqTI!CPSJU63sUYZ@a>thZH%L_TdqHrlw(+p41sS6& zeXc?+vK@oJ8bPReOp%E3{$dzXXHlAUk5m~^;x{*o-SsZRL4Is^Z~ujIqD1|Je*UKK z3V@>iRQPD$Z+0^=@|ZA%8@ac;o)nZD7wGiXxz@;JxE_?Ljqj+>>wjVPhB7r>zlz@_ z%5^2^I(II$sn#=8E2|U{xWu4GFr7kH)({#N)hDp_{jz>1JFlF(Z|D)`aNRc~L*OiU z)aVNR6?fr5f+IHq-DD19Q)v}9cYgWjTz%CO&*}ejDy<)~afLt7`K(-h2Y0Q{1U#CP zYM?oXTxE-*>su&7qq&M3Rrc+Q?nambqgo=OcDi1<#y9*N010>;e=2R33CB7&!+%Bo zS8480LEC5>*~nt!Wo8y7u4%N6d;iaV!$iF#{Z0LO^wfD@?Z&hz^SE)p>6EvGAt8If z)oOfTBdgqw7PS53YVKZ_^u3Rj-Dd)2)5L3W-0;6rYv5at-{gUR5SKV(M48Py>IQ&X zOfev*>u>7IdQcpuYVFfRBrYc+m8@P2F%&X|Yl|lbaX%n_YQ3ket*LKs>N9F_8+xtP z?VnaoeH7boU(jch%Tl0T|@ETEBExgayv-m%e{+ofuI=p)cu2oCT9$& zZu*pyl5C`UGlJVM-XJ5srXs(OJC>vc$>!O%joDlhk0vk5wl?<-^F71Gk2GGQ^#)$) z=2E^9QoKG>5Fte_vU0TS9~`nT^82s|UaC&xCG0IX|0aih*|3}my@eucGp1bEI?neF zI(w^;g>|Scn9MEp%TiI4?;6*BgYUxl(E9*yjC~GS5qlA9t>y0E;q+Wn6kVrtxl0-{CsOmj>zBZ8MY%rN}JG>@)Vy^ zRk&AKfFNjFU-fC7Vk7NIIqBEgqi zp?|!>U&5q2a-z}1Xpvb!woMosJg&@ttmC7^0sA1K%I&NVndy@)*OZ&g3FZR6I||o8 zM#8h3H_=M=6-*gxMYV%!O*tGU5w$7VUwkrEg^)2q4l|jB@)tHf#|q-zDCOXuNATNW z+bLXNJE#Nm?y_@lFschMo6>u8(RC))c&)@ zXpATf3U&2GCTW@I!*?~nzUN5c82{bKYk%W!U5RQx|J^Wn@1KN0zpMXO@3;QA&ih66 zZi4q~?7KhWXPQvA1jfIZwJW251{6%zc(8A7O=GTH%~(UoR;_Eg|AeMK3?uTpOSaqG z=68*Rcn_=HRZpubTwZC6?fMM+7u+p(a@kJ*&bfOWU~r_?Wu$XD_P!(#l| zovGICf|x1G<~Aw&F)mWCdhKC$AOJ|x|2elOWxrf+b!}owzOOk4m|NXB>Ls#h{8cyc z+VL}De5^q|q+v2&R8Z(%S_tgXUemBy)jD#?U0q}p4ti?CHIo><#^#dbqU}ihM=DD8=Nj#k?$z*|$$x5US?#*>bjrMFRS$P(6g zL1{UqPR;F{*bbD&)i3bk3ZH8x1>LMZO@EZfN!J_$0Y!W5#}GyeF^eU4%_OKjO8n%G zjR!9)7R!wFNrkHo+&zJ$kV_jc#~5K-0O&+V8OGfb?%cGL24;+5%AdwAnKcnI>L?l~`9*@L-3`C_-$W_wJ3`bG#@VNC++0g{U(VjQm(u+|E zo&XZ6PId{v%6=kH{C>N-E;sfxl?7qTI9k}+XKP245+<*7Fq()(2+ehTD>h<^r8>)y zQ|PI%MYg?fTRWkaMP_)X80pef?;@{fBc?Bf`WQ_`N~7`(wmccL)ys`UcM%lTUG4x# z2e4Fipkq&>_VG7YbTZ%1CG`jRJtmBtH_;Ne*q3RI^Hk}}v}tb3yfSaKl|(peWCZG- z8mB7lOp`6_lD6+O#b(w*My9W?d_E?_>8VCx>6ha>h?g+S>JH-lrxw$+FL6#f*OHh{U?;jsOkt78oubL;-{)8GsT+I@k_B5>&WAebMv(5;AV0)^j|-a{?!C1 z_jez^LU@|${YDwrdcRR#Gyd#mHmi1#8s0X;aZf6zD1Da^)y5MDw!#wQ@=6fNCO5&A zhYrV^d2P9U8Mf>KsYz>JyZWh%|9R= z6V^_0NIeplS!$Gm{1(}Hg95i1inolF34c{u%*&LM$=LnzU2Uwj+H5e#8~#^{14m`U zo5kbAw{4_;_D9B&U&+=)hjNvh#tk3Ekfj9qOpB`W1<9sjN+CkK-@^{mh@W1f0%c*o z&h39OslwRr(BdN)e#EQb^*5 zh*AAeaAyX$#oV;n>LY~vZHC7Zm4HD-&_vvh?iV|zB<|Lti)csug@e2>g@(z{b~MYgE8n|j7}%2 zA?3DIPTaO~H~NMRpmxl7D5)=KRK7*wOa==iV(IIL#4%+j13VDenz(+{j3wLdS1JJ9;npCQWl4&>;C5@n_s9jRx%+{C4Xp=bSp zpBM_=jQd!i7uzue8j+q+Qu_Ls8jgA&0P<+jgWW1Y5&<8Qr3i0h1Ge#Fy{a-t7tH&h z`@9uJ<3CuBUOxGF3y(dP^n9-8f>h6!-B!LRaR+yWic0@x6f(qbE=Pvg$HEJZ4}OH~ znu)}NYopyiOMCUkXH#+_ipE%d3H>|eJ&7pY^faHIMp=9X>m4NO0#_eNBJEf4A>a4! zHVzeNVkv1GP#ZSuH4CrQe(_YV)IO8?sumquTIegKq^l`OqNHlFZG-`o@RLy6&eh2o zzb>swucp@csKYsAa2p1E#YM9mX`U?-%_L3^Roc6VXqm`&eyJ<^v+jsZltVMMQN_}| z_3Sg3;$XhC$en}q9%c%JqmxYptmx2&*0P(vh9}$IHiwdk^kDo;_svAlsz10uG-3BF zRC85nbblq-bNw2)pSH&CrwuB0b$jQOV5}9oiFs=FJ+wC3SL!Sy6zY~i=@R9h6~%K( zacFvV-YLa+zKy37Uq7^}X`;%%0?*q-Y*NfPv@|;fAiUj8Rl~SSx+E!L^RtrL7@(h9 zEi6ve>=&W{Kqp!6suu#5hb5Bx1t7U@H|chHE~4VSlAfBWGE-B^m^Lk|X4uSh;UuR? zGfu8kfqtQdRhj5AmHr&4)$MIb;2oCPZ&>-dWYhH+-VMu~$yqm>jB7F%71x%pU?a39 zd8ofBPILJ#7ijG@hGmkangbOy)DB#cDqnrsjMOZau;ch+l3sH8-6Xp`&{u6H)NGkj zQDXByc}nMH%1q*scSYho#+AmH@FqbQ{$41MfyNK7L`>jG%yAG&@BO`j#_l%I5(gT= zVoEj(lBcW}DN943>0S$a%=+?nv+{IH{?Z8)^hEyaoW5G$k$yt_Qc$HuLw0>!s!H?6vmR?eF0`zJQmT<;TDW%YX^RuYW$ilfkT(n zl)sR?a@=-;aki3I&19uj@Pu|qrRZo)Lwcaph$OPYBjf3s=9+H%m znJp@YZT|T(y0M=)1-p$+o`pUz*%MZ>=`jj|Addd0h^u>Y(j68yp-zHdpYv5zpbxte zr8_YwnD(V4o_7%AV?;oAWrwPs>L2(wOzuZ;bc>5+Yql=cxplO27|FkMAXaOh`JMlVeCBtGRMWuHljde?L;g@`c7EVfxglhuJd7lyWSd>R;0%i? zh2)Qi^VgJZXKJ0M`F6i*SoG(9iQW@q2cZ|EgGW8nwI0zvHFEmo>W3ejDb|s ze5ggkerkSo;fqck>Z2I>JLhexy0h}Ci>8OtJ#+R4VD`ICyxwoLGilxkg-G$yOoBPj{JbSsWB~eo$GCXElj`Y43#aYQ5%GNueIC!m4p*GvCgZ8FDg7wF^ zY~ZU1(Z%n2(xtW5^8~GXBsO4d1Bo_{MeHRh^Z)NZ>u{+p)yzbdr+kD_ktOmk8Ex{v-@^T# zc*FSb5&gw~m%BA40JKuvJu>0>z=F$Nh8-_`UU06#?8P~;em8FneEnl~YQ)#wwn&=V z3PrYsND~VY>9r?$Kn(g(K(O*vf!=LgDv;EJqf}=8EHhOxJTl3lGYW`h>pgWxz?wb1 zXmc3V3R?%`BH^DvD@^3R5lCt?6>Zc})o>6De}XoV{P?3jFN@f)8>~vgk;I${1*B$z z%1(T=@~)$ezMzTt7)bi8ioZI`D*of^Ccba8+YbIU43puPyA!n9ipmx;D++D5j8> z{WaHvFnaGHI~Z`#HQgt#f!$s0sI@RPZt_W+MY!q!0 znpG!##n|7vJV^g=9eXRwJI#N;Zp^P~8 zr9tgiml{LvC;Z5 z0AUl9?>AS}6|S$&5SRh3KKIoNE@{F~5nSmv-HvEF1km3k@&eGG<^E@r!(Y2~GN@Bc zV)hK`81J{q;V|zv26Z6*|HIvzfJa$m@8TUuLsYP%vIJ#`5}2T(K|zzj42cl%z;Pctftqt2kBGUJ8{hzv_01Q1*p#s%C!TvAN~i6{h7?EAi_ z>g(K@}f1lrTZ=NUp)pn{*Rh>F@>eQ(!^7a;8Nujd%(`zl2ftYaNei;E=@)>0r zs9c2EgcaYUpCND0oR&;c!}H*mm_k=S2dCOKj?^aAl;MN>M_F;41R(pMa4&J{+&d+m zgc?E*J+DZ=^T|SZwcHS)o9235%ULzJBU+RO8;4l_SpM!%RoPODZNm7!RBPDm2p+*~ z%t4MqxOuFi9Pfmo=C$hcWjJv&fp!JDh4l&<)l8(X7}3e__vWw|-G7dtxI=Xv&&p|e z&7RA#!d~T$vB*%|GY`tCTI4O+JRD*(?9elhp)Bf8cSL9-^e@Rmu0ui=!{$8 zlI3bEXQLlayKAYz*+AWF$bs{eiSw+=Rx^cBh-JX+BrC8678cq}AZL5&Hl))W(h)$& z5YgIyyB!GLJVq#zL71%Hh73#YxKFQrHJe>Y4lZ?amJW#oX-H@cC{Yuv>MdJ~+9uGp zDYeUCv<7t+3_3tj`Y@rI_A5?*8n$#7+@LY$%ZWEfn7w=R9}|S%$?t1ADl+>9PHQ@3 zpEycTh(p@#Z(x6r*VbU>MYnu@Cu;rrxg@Rz^^Qma?p=mP`7kBR`43#xQ+^g0je|#= z%fB?1Ws!f5;4FV%3CXNMjb|bMuJ7MNYn!&4cd=%;^RL$}ak`e8*38r`fm%@z^xq9> zVZwWq7LsS&gc)UJIrfC?wwFELK6cv8Vm+Vu>OfQ_3nvypQUCQJR1+0UJ;@+Q6-;Nq zp$5GO{y+~cr#y=l1e)d_ALuUNxx=ebI+}^sfhF?Qg^~|dFCX854DPv8R4?iVS%Nee z70h7x!UsrV!5vV}sY$;GB?v3JREpA5#d+FYg&M0a+AUMX8HAq$cs%u$(#7+j3o_j5 z1!VL;jph+0AvwEkeA`bL7Btro zwJx7TpI9$a4D3_ZxG!d)HMVbN%eZDta{Ad&r6zAPW)Y|78_jg5U0;Vw2+T^sZas-* z;*A-6w522#C>(g`lIBFf&duU@9dwpVEQ~20sZNrGjGf7Jc-fwxpw`V(b@(Lb%-FSG zGMM$&O{Ak0kQGWgpq8O|A?Po{$5TF$AR$L>e~fYdVn8^*0D<$XF{D%fBEXO^g}%5{ z-MA?>T7`YY+eJe*9<9VudjFQu&Qx$UWD(T)3N(jm{u@0NoFxk;cW)9t=YW?;LU?Bl zW&Oty>*FMAx+AoNNRV6qbe+Skcc6{crrQof(vZ>EpkCq1#&!>!ZkP}inBTvntA(d> z&0bGb(7%DulnWMfs{FeEi{jT%y1i-EY2cn(!YDo_p}+MF;Ol{QB_sCceXaI{X~-y#Qaf-!Sbrf=Kw+O*+}VCfP2X z%ozj65+}l4B<+SUvt-j>q+!Cf@8}}N7{BvfCF$0O|7pTkn{*!;|912JvdQ-^z>O$7 z-)D{gfJv9}zApb`li$ted#m~W)1=Qwy7*B$IR{?d#NVr`Q3#BO8~Ypi2Dn`R)BdLT z{ZIQ>K@;Z+zW@P7%ct7^SQG!OCjQAy{5Li64{PEd*u;NH6My$6{&sOcx52|Ln)nYw z2r~Fe{C7?KA2;!@Z{lCt#Q#DQ|6@)3vzquPH}T)p#6PTwe_#{;B~AR@oA}!`@waH= zKL`oPSx;cE76({=V})8mI9o}zNC*ee@x)w5-Itq~_5x@BquS`_qC1ZXpL;a?11AE% zSA>K{cy##>oCy3ElusJB{}m?!ZyybR@`=Fb z9u2<<;?D8w|3A$So0gwH+#7_EHm%LP!4HS>A=YK!0KQNQD>MxEIo!tMde`B}wxqQ_ zxdN2Wu4btTLqtlOUTwsm3D^pSD0S)@tlV+_Jqx0nr(C~lIRp<)*?0kquT~ZDrL=T8 zN`(7*`TR(cI#aUhxp^(sm3_vY8dFz7yMgzv&>LK)!ukCu%yP)Qh|l5_GrN-5t9SAM z8_zV!Gje#oNL3FehJL;vG=#4ft&lg8_yqZU)Q@;%0uMgoTnWE=6v@rQOj2%dlxyKN z`FTtnS}ci(L`MlXndLonnEMz5@CDak!~Z1Sm)P?eX=J>B7JKO@Pm*54q%+sC`v4Jt7A(AQ81tx! zxcP(k7EyJzKMGK1A48b?=77h0m;kIi2l`rqRdxJ+by;#8m@^-Iu zKkRU?0m<;`7<71v51qkR03p~)zwq&(Jh~8l9XkH(YuQ71I}LBBL2f5ujou5|Ubab>F4j4Mk$Z(M2WNxG0< z|EsWzzW~#bGf(rx%T&CnUKg5@9(X@VHG_6J+z<1$z8@*nG=3KpwBe~@B>}nDIx2oG zt!bJj|by`BTZCxkTbIz(qpTKkD)AJj^YFJ6q_b zmlbT2;S6w$xa;&&iWsy-9M~`ky-g3_E6|V$!`nycMQ=7nk(#fCfB2L|;xhR<9l$Tb?&%dbhCe@XCU@bPh-sLzx4HPpTP5r@(Tp@nxL5@S$Y>rLV5rtlQC z|H^o7txay%Gq=EHxB{;H9|CY$hWZrgtWfU^Gm`pBf%4*Et$H;fk9S(=);RMx7&S8( zT|tb{VJRxlxYE=m#+9zlH?B-|j&Y@`G`diysw*%A4`B$3ol(>A^+&8p!jB$*{N2cS z-l0XR9zdF(NLOdNe01FsbDd7t1q?f#Z8%SAM2sIat~6C{TxicP)D+{%RJR*fsu~9u zwN0bs+n@$B29-EP_6llMfA}MB;(bdkT>0#qQy^Uh_N4jn+Nm!%9*?l{S~lKl?+abv z3r$X031?Zvqxnyvd1uw<4UNf!uG=e5t^Sbk&gwo@bcI;+b@2800k3#Ae($w<`pV!o zy!ZN6!uzU=`Mzq3e~=fCe=<+pL}7GhxRRoiXDKIEdbT zUHFQu&toAYoYn@}?u-i>SnHrJh>3iIN|Yl#cBqH*u>5jl!oM!MF`S0D8SmisLl(Xs zhpaV+n#o0J?MUbqRWc5|+~GO`MeY_D(j{#H%6XoL*ZX=Lws=#@Gsqq(Jrx__5QFN% z;LcD|q3vs%T-c)?R|>XuU2SJ1!5U-+?mDZQF^Z4O=J|rRgBwgpv4W#vaKA3C3I4QT zg}LwmzD3_EL%mE1E<_*RBxWYk4>}T#7g0VYxfX-zn{i@VhU? zU|E#~81)3Q9tA2G-D|6URfKd@m@^^Ge+EbAxooPw#p#oKqa6P`a$K}9=eyFLu<;|2 z!v1o2f8<~Vl{Zk3nKW8R$K*tOB6E>nuc){0bs6cPpAC`q%pW!DTbfq-wB#3gGfuCD zM1w~t*ro{EEjO|hndA`mAf6ZDd#oa9p-<5Y`dX8HH)nvhSo07BA|IAI9OK2@`3kv% zZ+3O{&GgLi(i_OVXDK$t{pZ3Ga+^TaDi`=5=~>d_{TBo~FV-F=9(JeoG~*BSb$Nmv z^={fUrokqKr+foaa7NjQCZ)Jo#ipH}PbLL*HoCoB2Yoi2YGm9ea0QJZYn=s=dgR)= z=<4MF>Q$wt2pHJedUfBo^|;T5ybUvc9(Ke@#dtedjr+PDGZ@YC|Qt&z~-l)@l zyZ~kb_EQ;U$PP-9Hzk;x)oPl>QnA4fgQ7Y$V*t~&{lkn703()aw8Yn{3a?O^-3D8Ja<;In%{$N~Lszh?DQ`rW^ zEW)7@nc{Cy>Ga#~wKqnP$l$Bqu(SUQFT2-0=ch(vU&BWo!c7Nsx)B6sn8{&wOMy!La9|3AbsS0x-ujO ztfx&*ZI~0vY9;;#m5gs>0a4nHpYZMAiu{h&-^k~T`G7xf#C0u{U-f;#g*beGTdzv1 z@`w8D+ZPEV!(qD3n16AzEAF(t9D{h;LR8WhESzs8)%${_i?~3u(fqzp;rwW6Dr|Sa z>X9Z4M$;>re@$WVC-nvPh^^4HMa3h1ISukac9lq@A5ngzQz=Yvwbu7q{%qei!zQy88W=)1GG)9lA<>CLvMt-jeCvqaobk-@KjfM#x_s{ z|GZogS@z|4i`)msgBWFEIOe(7!~ME&?Su=f5}YI}&!~4&zYTm^RR;$1;pHFQ3$+vM<#H^d^%@=S ziB6s2&ZC>Mzhw_Z11;79I+YRSxMH1^FdR~lbQ_}5@Ne1qC~8iIh~o%Xgu!3DO!iT5j6i=D6ENeujBE zr`kWt3QV(He%!Y<6f+i{At&oAcBFc}D1!K*3Z#Ug7SiOAYWvV1f0|cy6MvnW7R$Qy zdCmwWxIv}_c;1G2025*rk;Y^&HvZZzZ-;9@rT9uY8yYf{r~FF>@Rjn9q`GsY+4)L2 z(B~`VlQ9`V)phi1*0+;)+3s0mooVkmmKbvPe3`3Cx96cp=*QabSkI?dG0wR=8p4RD ze0o#FCOC*)*90*%3K9E4SU0r}>fzt9iMSto^Dvl#x{f@CU!n+!a2Krgurh%*#2oeVoOX5>ugqsf&f7TjeBDc8Z7 z$NroF>Ynm&x@5N<>K@OnzioEp+8I%iUD&Jww~Ova%5nuU;?(>!zTqBoG6588&@Y~fxh zfv-~=p*Nx2Ea`3cEeuAE6utF@#+@FdDY?ka1DJ{JE?^pwnTXHe?bp6^0 zNY~3H`#SZk2$pr~Q%=bc!6eJ~WPaYEYValZSSjBIwM4#k>J`RI13d><5&ztxWWj4QZrx?D)MhLgeSKmG+yZ{vq!_JzWMqV%wnTPY?kLkalNubC} z3B1@F%93@oH&le1+o2xjIx^1+UWVm0uC=0q9~xzD6Z*g|veY5cqUc~KuX9#I284xH z`E!Zuo#73JA+T#Z%S+nvrUCdKsS z9)CM^2dAx2^MnJJNu?erjfxZKLEY1j7i6r9;MVYU5%fZx8U%d=d%GXL?C1u}FUAf) zZ?yi1WeW5QfjyaKHR26^OK}R@Wmt-!38`pVtD={1tf^-)H#P)E3}le`2}$k z^Zrm$V_;pT#tXM@VD6|>t1s7hOi3u;=p!8!+!V~3!k2qPyM?>__K;9R$xuu|Q8_Us zl4kJ6^q4BvX%QX#4f&|dK;OR zQOTFHaoQP2oim>L95PRX><9JG3x&b@yz+ykw=uK+lG&FeiePevx&aybfEp0!(QB({ zA@}<{-nCi}Sq~M`+R@Ilv``^w{bON|I`2#nB6OJJ;UFUSjT;a=6j`aqvCp28qG>Cq zB+cK8%7eEl*oC0&!}4eR3GJNLDRG0{^gC2z>v3Nw(D8+S58dKqh#f!pLcjHe2BJj|P~qzt z_z^Uh{`Ru%4l+OsjOp#PKxsQPtFK4Bl`B;nVdYBAk}In2Da1J7%WFBK)BM-5Bf?-9 zLPdx1AS$XemDN$rFUG?gcy8u10O}Sb=Z({K`0mT7Ul64xmZKoT!|H>Jq+%!ln&kow zg)v$chpM&$GcsNNSAEzt!_%v1G2Dkg8H6%DUHwU*tAOG|ky!r#&2(5kYpqg>>ICsd z<`wjS1zd~LEmnLOK!I!!oAe+7FdJ%Py*yTi_Am4ltikFDr)@k1+fj3Acc=f+A6_2S z@_7oX@&7}3AhLk`#c(9WjF4cgA?tIj7EOQYF=B=8fZU4_kyC?1g_IV8Ka*-A_fX%k zdMw&c%@RH_G!siHpFI_PCJ(nS6rcr4A=B`(Rn;5K?X?SvAZl4&ds-f%^SIbzTpHp$ zOYh5Q1$8D!9`#oh7jQiH&xFlC=7UQ)jIo|e&TuZz8j5^HpS1#93v@+F!B3TE?%Kkf zA3cv&rL3JjB%>AX8<7^fJ+lx@KNDjW-RMx3yi@=jr=_bF7s*)dTG-twF);!80GiI8gwiNTP1~SAqP`PbVGuO;Pf}{v*nlq zEw=7e7hT0BBYT<;aaC;=9#x|ziC|KvHbabzt8`-X2cChyGetP2FLbl;Ed0m@I%YmF z3s3o0=E|Lv=_%aXDx(@a4|gJr&qyOPxwa634us3Ye3AiU>{m3y$80vV`ab0bUSK~R z*#kX(vU0XJ-c4CE{Vnc$Onu!K{FXVUBFEBKtsIoio7P7&U+L_epPd~QWLu|R&C)y& zsw1CWkmv2O-D@^f+Q309@9R1sxRG(l9qapb$SH9+VG)cngvhL5M0FOq2sBnAG-e5n zLEQ|tl`to6%tG^n*47skxkOx((@+I@EC!qfR|r`s8eITLbuW5`LyAu-pwGO)kNme< zInZ+Zdy^qwh*6AjI4#|%wXY>nXR4YD^gv7_Ibg>D%vAGReVZdRQJ4sKV)kkWg&>@qdWtPc-_`g4`SkIhqZaja8%1_hPM<%KMsAU0zH^ z*e>(3c#dNxZ!Gt1pppOsVg}^TI4|{dpFep}E6qPpS@@u`U zcSj)6xj-uK(UtGwQf*~9sVna@mA?x+pU0_ucaXy|D*q7Vo5q!|JfV7jAQL6@AL!sl z^7c`^$__=PQm0J0WxVNAsZp}7Q5%=)&&8MN&TCDL{tE5?acVT=ykpjA<;6{F+vyI(4OpaJY$^}o zSTNPS(o}a54$T~=x)aVlW_90(9MQM~PpJPqrk)$X*iAcG%L)gK@f8d!@EwOiRkwU?5{_FbPJtYf+#%!Fy2#vd3)Rit0B`Or4{8C-)Dc<*nW9S!;8X*+Q@-d5e$f?GalDHN z%y9K%hOTrG6QR^%0m6=(e9_MQ0(fB@*dj2))msKw5&?LbByQAik1`2r*DCYh_1iwk zRIGbFGeAa%_(kjGnYw533+kR~S}&a_Fi`b2C~Ps1+YDs7flM`!6AdJIdU*x|)#0ve z_gZz1P!wo}DN%N|K%(2_yCS26U$nsdcnjn)6NalL$V6y{i2$s(-B)B3!B4IKSOYv; z1N(vtBuY&)a7-u7F6kPz+(;%t%Wduc?^ZReDJE7L zC#P1&N((V|_qn72)85#E%+v9@8xX(A#HTVlInE$sKi$dw?y9qn?mKhH!LkpKa1c2LI(Jp%j`6JKKD zGc|mf6CaVKiD6NI&(iVpo%qcrUKlIlvkiJAEH>XuCY}t4nrUeqmji8^*i-~iKdqb2 ziM`XrW-$PHn`0z-PW;u3pSf-u>YAvMgX(@Yi`N>NYVJtXspn)UYl2gc84t-{1&wDu zJ@<*{zKn_LZsVG&CYl7~HENXcRMB&lNmHx_7*~nrE(QzSB)M%{GG}UIm1NKjZ7$qrdM5zd6gNdvT^Zgtq#@boFRA&&eD+#m+*=acg z;sI{;_Tp@}oUtklzAL*RGxtno4?~sW3*C-6W^NTAd^pyRkIK#fC$Vk5xd4d)Cyb%b zLEd(yAc>tin*rX?Rlru?&YuJ`$W3ZXXC$+2K1JcBWPrQ*HQ@XhAOpOiLIRdCPy;@$ z0bLRaBS+^64V(3ly+OMkE}HQWa$+2Ew1(WtkkG{d+(K8-=7q`{Py#|%5^gF3b&1_N zv%0wdyDO_Yx(YWMNhR%qMYy+Tp#wd7krjHHI$A()6zCtY8LDbKA;ca%A5g52&z?{T zsM$z>i2`=L(3(A+MyMo7zKqF3OIQV5@p*{J>{m({Z;vj+lnz+&Y1AIjsWsmAHc7pt zNQzm>9WQ7eaAzw6OkG9*Ai9L;`9cM$g~6|&Ew@7Qa&MISU)%wzU*xRPuf`CR_G9`Q zV`eFg;o)xNt1AT)2u!W5P(hhQ+#?awDsee7t0*z^C1#9{S%jE{PE3`=6zI&P5`9;) zH{{M_=_hibZaQ9?r0>c_PCO|<;N3btmHxhRm8rm|JMrIU2(no^zS4oubK+|lf0R93 z4a=}=`;*N*S-ZSIXS}-j0)p-Ph}!8W_SYu zD%h5qunCJ``3Uu@HvTQBRJ)*|UJD?B&USB~{ zW9h@ z=Xo$J*$OYn7w_NbVJvO=uy#vZ&XV{BHJxFB-1kAb+5({`uv6JUh9fThLY@Cg<`2GI z9r+i3Fg&Uwr{ITeahb`fw|wi=`SOMRFTS+ztq$KNqpdp3ohlr10PH7m4T9|d6b9eV zA6gi!p^}R`sLpzu%NTVE$i!J!L!PGWz-4fi$OUpPZE?nYdMH%uc=aM1Jz?!kX@tub zE(0ivb+o07Aq~*hob&6eu06O6!n^(C>JHJm+Fy7Z34Z@`qV&*bOp$r zl7qA2=lR*#d1gjJr&!C50~In$^#PRy3pqiP zvwT03V-Yg(#TIfzim_*#*i;5!HDMNF=}vr-iO-UFXCbAD0N}gGU4X81c6>3iQ~Dh7 zYfZdR5#m#uEOnlhcn&N?npIet16*N%D-jS|2hDe4Z#J=uB-X5T;m~_g1{ao=>S^Q3R*x9hSQRv`Of|!}@>HpD6{%Z|t61G&ToWymb!v2 z6w-_fNpQ2r`12%x+{RU>x+6{GPmN>e(<^3`;(DHW{0eH0{3*^3Z>l_o{4$UI1IaVE zvXXOCaLH`WW}#_dPFhqKiDhn?M9Or2zm?W!dj0khqkFN){1QVTit zV%UsBOhMX(1Nud#5rO6b68W-L6hkQE7gS=Oa*>!mQrK7s#%QdC3@>gu)>86ci7 zVT>c;ybU^bEHs~HR$9V&b`d0;+s|Rv@@AQ~(VX*Yf`mik?)vSNa9)|ucA%A{T-~ph z@CteRl_Jhvp(XRAk=kySqMn#Tk`cv!QQBCgQVGOE5p2yU}l zL}YPWFh7{YHzPD8l%vMBmO83sXhx)9Hsp$bBV0&OKoRQC+N&GnOBK>y(wv$hfKpWm zo~lHmq;*)O8?={z#Qa)#qf1C%zL30u;N!~aATH0Fh_L7qO@wnx#G`3+Wtn)!;#Ym$ z0AxkrYEYk?r5o)7e4R$E)^3)j-qLP%lX^+gLjS=q)c;BGN7W-bO&-(SPq*z(&vHl= zf?C&8Szc~6sNUs28;38>VXO#h4GDr;$2Jty@+2l6%uQTvAE6>hVA-vIp@n`Ug}>Pl1_=cP57s{7B>?Kwlfb!rN}h62>B+AZxmM&cXPaE1kP zU!2Ca;W4ll7eY)t?F?3Ahx!Sko|AJ=q>OyX?(a%i{g5??1IIDdY0O1qP>7fOnrW{T zbg+X&NeAwRn`F6*VYvS`_=EaHf}-jJolN?$8tyPIq;9kw6}#Vn_m{xD3wt)gJhiHs zMyU|s2f$1S^I95tk!*+9?sgYsxCX#3y|=TZn?Rn2dr9sg55$?yq4WoGpT7?+fXyJh z+9DR}zxD);0N3u|<6PB^VKUpjfx%{R=#rqGduY%fn1(BkgN9K)%S6Hi-xaQiZ5QB5 z8Kx3n^;}CfgJYsDL9Wgmzjew2bKnK8&2-$#@VdF_X^%A(?&7A3R zYAF>lJmLu^f~FMJf7HlQuwno^{OUup!%uuP+gGpQB6lAQ;ft6f%&XGC;MPk5 zbW6t!_0XwgB(Npo{Q_hG51xzwyKS%_X1{(LlK|I8$tCe^1)PQd$-)eWm40r|u7`x6 zzBjH^Rcl-+>I=H;A-rq`Cgz{82Q6>#6LsKZ9bP16auS}Wb|P>9%9xs>`P>#^;%HZl z23d|mA|PcgLppBHQTSlB@<^}GF-P(X0n!4vtgfSKwiNc1NJ7ReuarT+8ust(4B}7T zdA$ivg+-RSMm&CQUqfF{5599udn8L0*`y&fLU#j~sX9t_(9t2w6m=@X;pnX@&Soh% zAi}mgbdoMSTkS)unu7vgGY|!wX9{?(oo?tS@zt6ANn9vxwh2mA(~T=l`RPLSZ^M_9 z$$0rTsO#j5^9PIvDtTBhYnP?+=(640&vmFBZ1i)seIWNf3>>U?VT1n}W1+JaqD-_u z-Fhmvl6k(BQ3-;a)~l-LIGf}YxIFs7*9_2ccs(pmuJD7l zxTmJ;??6e9W0B|%Z*Y&gBnE%JxX{R5O;9RK3ROGfNmH%pLOUnp%Xa<+(*?=zNBP#N zJ)AzIop%|RrMAH(td5n25ue=lQWIImnhvCdf^Tp0#rBZ+PcvW9;GvmPyuo#1(Tr-a zS<0E`879#s=1YrbrW>HYk<;nX3UHhs3pbNw;6H?=s!;4{Me!Zuw<*FZoCEbBSPof? z05IK9dF()a8vMOMI)BO3=jqeIEy;iNxu6pAL%dJsH_Ue|{ej%fDeMy-47wj+?2gyK zM96mU6b9-pVz6Pmtt6;Z=>q3q(8W5<`Aj2RcRMk~&fHGW3b}3-zN%+4c89}tCFlWY znpxOZ@;07d(E0{-Ii^2{`*s&FQLLT!0vPT=VOxz4)Ste9+?I>uAP!?(hZU;bXVM4c zws`Nd1@Z=?EdvhVpEpV{7~T$b{z)Qhn!_{~xS6hPkGvRvZH0JZ*IQ$!UWRl*9ZOw3_C(S;;s{BdR}u@e}f8eE+7-e zd2vK(mU0JQ`p}Puj5C3$YJ{Z3F(I61LZIPK{TUBLLk8jI2BCD-1L=WTmU79?JM<2! zoet`)_F_|*8GUq`9wzVMOB8CvkMl3|+wNiAot_5^8j%c)1Gzted|dwDfLw|htIyE` zgE*@RUk&!^*y$Yaoc&p+pahO=$`Z4N3OE_VRRD?L za(OA~P06QLy=3xxj`^Xbo)kaiUwk8fA#QTuo{|%+*~7S;56NoGfqR5RUW+eBWqcps z9wxgvMh-M1v+-5q*sr!$#83(ui{a(y?Tpa_hmNQhKx9<0P&-7?LN$QK5=>&UI5Ok5 z4%FB&NNpi0CaCpN5lCI2Xf%*s=5wtEWR#jO>0>4_E@q45^&DhS5j8SmV4%8F0GcYs zUY5;y4$pK{RNDS29R$_SWds3PFXjk_RLOn(m_3Z7rz++#5)oReh$ujZR4k}8weHXg zO7coDOk>*dIhgLz`mUobX?C(wY*MYRtCad1ST+VrO*5sI$rn5P{G#2qIIsh7?IJBI z5U$1nn8H#>-YkNml8KSYG69CpPxvV+%r7!o6wf42)P4w8oec(+26&zU*1Ppu6-Hpu zVQO_HloH0C=Bp%KbwLv)Pc^_hT zSZ=V$A{Go+pJV5qiB<1vP5T($u$r&o=QTCf>P} zlwQIonfOW*Z*;Wto%pX>Xxy?)yfMVdbK=*S_#zWORx5zVI`Pk#co~Ag&sf^%;fwNT zns^x;h&PrrE(iVw6Q64GH-<>*PJF(JFX5m9e6cQHb2rxC#8*nZqu-t{LlDu;O!OiH zZuHkxPW&zrXv}nh?2Y=|<;1Tw@u>)i8TzC(>d`s zF&>v6g4W{V3Qv88zav>fp7-#l3x8Vk=NyvSA{l7LP>VSxL9^%?F7k^p2{InpY9z#80qI;B7{(5ifQ#V> zAb)~Nj76b+bPbX!cD5CObe7|6AcyxgNhq;+Io%IA$($HMFnLLjgXw0Y}0JWN?oWS zwrGfL0&zUkqWvlfsj*QLmCX!oRzw4%XekzBd{=lL;EP~k1oTBode@I^B5id+#duQ# zqh3j@yf!fEyOO9S7#X#Z$YU899d;3{X-j@1p}OnvXgf1YwL+#x!9CaMc&TdNl~bMg zop4A`EYR`NczsuvIPse50AH@-r6c;T9P7kuN=E#69WOnJcki9}JfT{|4`BS!21vs( zn5j;AzByM_b?RyP)~dPq8ZuBp?aoG?YMOQz(S4V8TXav*?mW6jXm>H)g>++8* z5~>icpH$CV7lKlpSQpkaGaI{(!KWuWg^6|HA@Lb@AV!9RHB=c2*}|Od=SxV7!Kbt7 zBlFNkhM}jo5ms9!b|#R+-0Wonr#BVtr^fEZ{di9mrOA4HiR8rv8I(`xT2~4HRiN8?CZ_)9^_z3(?C*Gsu>vg>4#Jijd z)%`4$P1P03a^lmS_zxI=G}9Slm`+x7AA3|~$`|*);ET4KjeJxa35%*$IxLN0F6~aC z`^R4;Z6@7HyVL3ZT)R{0-aRSnYZwnyD%{RlLf$(~D&V$tV%IM;ue7n!Ax2fzk+vQPp zZ9U^fJb+5~PKkucWP{52fyM8};3aeGTSq}>B{4y=3(wW&1#OYWgsL2%>$qP5g%j#| z`8KGhYn5ASF3awU0n zy}R%&O;9#%GBJ)?emo;9!s6 zNJRyK?TC?`&MgQNG@`0T!nmdU4@oGt*^3Zpka}L6wQ8?HZh|R1O@)viSY)WRHHVP8 zPF-QJxtvLW?{CGA_pj-P{Z}ieKQa8?-z~%Mj!`6n3=qM4jGeiTWQDrNbsOPz_4~A4 zjgE}RIQJbt@;$QWKFl5tz_vC9;4VD??;#(;#>MaWb0L4uGgfby(I_OKbxE~ zm=ntCDEc4c4WM22tc+7q<7YS#d7}u`L2C^M;Z$R`F5`5M@aPCyqS4GqlBzRa0$ri)U4R zGATdyJj6q#qYJyX6vlg!9K|&8g@WuhI zpTR@in?&}&MYnuHr+{NQG=aDGc*@tXR-xN?mk*-$iLVqMTv;{(>3D+}3h?745nQ8# zO%64VEDV+L;$iGi91Q@pFgsYk=;LU(N5`^ZX~~Q8 z2`+*Wb**z9aQ4w`c-Vu3U>XpH!i0JwxwXiPOCz$_3Ics9Z*A434|BlTja~uY>;Drj zDhq3Y>|PYx9|HcZPO!mD5*j=D{ zQ{y`I5j@fv+%GH)9td9#crV_p@Y;j2(7g`qAPxIM95$++;P9#V%nuWU9pUdWW-U2q zh7QAR%0POA0OKU2?l0+?353DWOc4y!Fq1_GZk(sc%nKqnx1!`^M!Pk2xn$@4UmXR6M#naOi0^Gpq22*kMGIi#T1HxQbS$f&d3x20s@;^Ai4N5+ML zt<~NREivNi)LhaOhS>l-Ymk3k!lP?U_8p!_9+1}3)v&Fg!#4@3XgA11NhW)s>Ta#G z_mnRt9pP$3%=Z{#;L2)ikCv|d;JWgv(p#~I?Qh8`5cXr}zL2}~VExF>WpWiFhH^nt znhR6Y_4ugZUJmPNcsnENKTCynvn2~K$D($BNaR_6lb89yw#tez|1n$FX50AX&b+AEgtFA1 zDHdXee1j)=?AC){Xy;n~j)v$?2s^j;NgeRMJfs2izlDeKf-U3roZ+(|cij}<5)VI# z+!OrhLvM==7xX$mlT1qBe+NUP7m9SJr=!obAHH+oQ-xSK5Sec&hhzc^^$!sro3ov7 zQtyWm9qOCE%$3I~wf?e81}sC@po7OF(^YN)oQXCbz!U( zf6t5WR=IG^&1(MmLMiHS+m^18Bdow7jDqH)I#g8$HbzIq`&%X#cPOyQ&C zeU2Z9kjn&7PRdj!!=zKKiOVlVnA04Spn2)M3IVH|VJEtFeKAMdtcjhBm z&+0c!%&q@{Z+4;)@+`YkRWinE-)8Vf_iuiO%m8go)4ZlT8-?Tl0G_lc$;A&oOy6 zo!_0Qq~)L6VYg1$U(aDzW5tPP=p36YMb^$VvbLxE6iiH7-u9IL34=c_aKE%2H33KO z`Zd3G&SbRaiFPja0h(C-T@ut`CQ79$0rz}{F!&{ZcP#&xn5W3|{@dbtUv2Wv?~TPhGbne@tEXG{e-DiD(i|35rYPr2kBjX(mBHo>onkHjtoPDS{`lotSnOs^-YQ#~N7hV=KnHW*;#6%<@>< z^F2!s7U16s{CtvU);gvN{5;MxtFPb%v(4o_i5Wz+lEC`rvax`R-_`k~GTh(Z+@CSl zdb|2S=5-IPJ&Yc(aB+wB1xbKrIJU9^Kc{#CPa*BW>SRyFdvIV8)+I(8sRyf@`BQ_R<$K;5(&^Wm zf=JvBM8itU!C@`GOEVd+}ia zcGnY-agWtq71tm=;EM>4)mr!}!ozy145(T5R1o(*D^Pm~eHZ)`cagM(%a?k{>T$?! z)!gc_KDc>JqH-&Y8YX7)UPB3H$X#_OT#k2kxN5(BQUoN z7?z&A`uF&#b7(GLPc4g79Y@|nC1&oS84t><(B+x?;qBatGoY*muPfrcgJY3K9@d#i zhtD1lzSkR*2BO+X2sbNWGrvP!buxurJj=lmjFD613zejJ?K{dixl&$cvu&Y=TSU+i zVW2`@f}73ddFW$g2aN)RuR}+sEF^6W;N*c8STF2PtvnM_Jd~>l1jqSO9XUx$(!yJc zh{Ab5K{pcyM{z!8=C`qCFDQ?CDi$I4)s;X^wfMogzel~)j_ZO28D)qBJSw783bTNj zB!ldU3pobMf8dM&WPiq}(8wk+B&47FV99p@EI(Mo!~+qv`bL)Y)PBAGU|XRBqu~!w zS&lP1_iSuWsdqoy7ezz00smlEBrp%X-tx};m1ua%CxKNTlq!J9cgNa})-pt}VymZo znDFt6D*7@0aV-guxKI-H*$-m0Y;bA5sW}8;fxMI?E7T0y0JJ{%1TM7olrLkCk#$4{ z$h^)MF2Ps(EG9G|zeW-HATqlsnjajV!nvkg@7DncjF(&olS&qzLo}VA&i?gXeiuNZ4mBL1Nhi_!YnjdLpnJ>}1G7}$oo5Ske| z9rWN0tWWXf;5--}|3U)TZ5*6MdQI_v%SkFz4Zh&VC`|X!&g@5@g*!bPL}65{ zWrydqjmag#07(|-B zY244=NPLDUe65TT2FFSMav@N>zl+i%4*^*7W7JA&*R*QqAUXOYp=zFrYf!4w3Tff~ z#G$fY2q#&7hQU8Uh_27w(U0l39ajGihy|W?B*w0;O9v=QiN0iwq8D zV|pq+LJqnu!<*nd9A`Rx<!=|udeAWEKGQ?qdJ zKD_y7$2*1I*U-rE)UCqXNtg1Z14LJx0K#J)o{BJFJ>?@oQ3cqXs7S)7@!5TD#MThS3p@nSpt{Kl zO;k6(sceJw zT1@rYM&QDOcQ_1D2Ga9l407`E1|Jn8e6>Lm>)LQS=d&v6?$bH-HmEaMuHCj{M0(^! zzmb2?V0w#oqL738-pg3oB+o;|@QYQ_SNiP$yN?T?syU{}@MVb8d_Y?EMV51>hvn23 zV%bxy?1N-3wVX-ROt`^+@FEC`|BxOC7c@3lmPE!>qg;UW=IkpShxlo`1-%r5UY{6x z?+BT@KksYMdmH}7=#2uX8jns6KaDtZK1@wI4SZ`l0yMt56TBal$r|lk>{X=;}(YZ9zq( zCROP&G~}o)xi(BU)P$`(vP*Z-{~IzJ0GAsQyQ>8Cap)lp9SH*Za{sN*Yn#i~WL1w}1&Dgr?{rO&GjxX|q{De3mp z?$%WKyM2a9bVYN8bEL~>v~S$qj{roKg7S#UEA7zj+~ackQ@A_!bCOXX;IZ@X$Nbys{0n;R#rbIzfnEEkD%s2TgS2gEzGzMKWpzHgX9Y73(pnq) zIF7|dIxQ}sGv*Vc+*-|U!71N;8p<8eH{CNQlYYE^hLMNec5E7rkz8#xarI)BVHrH&3nl8F1{o2*dlRp=sXm7^UJxhe=f zm{Ag8>GX+K64gOTgvAY%M2x1MXf2*S$GjBWF#uMY_7DotL?Y_uF9XspC{gUz-~Oo` z-d^xKeODtw*(M39@SZFjs})FYY%IgPOk*v?oX!&D2$v~YSP~jb7}}f+(O5SwTy5W! zz}IkC%ba72F|)TnV3{j)C7m;Ty7pjoPny{Itgdqnpzcn@PBXD(h>aa0t7KBL$uSa3 z4VIh{6Xhia5Ml}pToscd(wzO<;y`voe16~;x95H?jxlk)`&E0_72}ehwUV|(cT)dw zoOdrV55H2@4zEEt_ZfvYv-Y^q;*a8>3E5P*yrJ8n7uf5MHU9&E;_C3TExHHN>FK2ABmvpH@*%&pCzk_cex1o1eYEI-T47=yG-+>1o>oHL8CfVFBN81q{cm73PT}gZG zp=7qHU?`dSvxg^z-^H><^rP)#CB3Ze(Z#sYx_8i7Fw z5x#5}w+wfb@>_;CpKe+quGvQ3ILx?A%-Erx~sBUrRsNgvQ^O{_?m#gMO}f z8BZZ?_WPtNZ0p)>U%9?s?`j!4Hc$DFNQgvY%NDMM2N*=BA%~0LhJH2F^A_~q@(%24 zyU!URO|{*SWdgCqH~#WLst&Q;-iX-VSP2ji+qn>voL#>!AJEx-{2n&`UPppZw%QG% z#G2KjN^UfAAk4tElyWieV^?RbT8PxgES#*(DSQGAC{k{>vD@Je8lmx zD~V<2x8hmtUZLx8BjvErXtc_`DXL->0*P@uz!;Iy-$GOwDc%hQC=k@0kIrX*9D>Yl z`lHk6#{J=c+UbkPBTV{UJn8=H8YlIXcf|zhB$wlwgm^LzQFRoAA7XS2;%0bsGfq`j zQXO8X47{JD&ie!liN7F95`sxS)e>F1weW4 z&DNyy5?CZz<#V6Il8IYoh&kcqn=ab%;bh#Glm^UEO=Zctatcx}Dqoc6Be z`!(p`dy%c3d&4&{1WP3nSF&h3w=IfOtJjG8B)Z?E8#doKK3o&&Px<{Ww6x5qWC8P$ zof^Xs(kSk~G?B&X3ggOFdB#}J=os1`^c z!3JziWHoV^$)CsQeJT)jPnm>)?cdSf6^vTrl9$Vj6`PN+hHU+ZcCNVn5{%RDY3x6# zN&GiW;y-KR-%3C7-7a5k57qMmV-NN6r?RBpI|I!s_E4iRv#RwN)0!V!!9$|2YWU7m zxz@9Es}+bQ;m}dw*ChYRT=#hJ5G-63TjgEhl0!`s%Cbngds({TbK?`s|xi z_1mPrAnXod0y_sux#`4J*8!En!3l90Tb(tKBRx}oi{GTu4A0V`uGxbj_ViE5U!RZXxba&rq=wY))PUEi+`X{t$g@^)rv^!)in_*ca*= zc^U*Yt^!0f9egYSd(4l}f9UI*gCFC`0%@9@&CZ*dC#h-RTiEWx{(OWo-3)6cW=Oo< z>wyDxEaQ$wnWqrD+UrtA!RD&+MD5KwE(4wbcI=-)Ta!X+4Q9P-j!=7i^A!ozVWfpu2E&?KX8WdMNm zM5q_`ddgozU+_38EVBLM3$>xPe?}qp7!dT1r=0sS-p~jn{>(d27|_!R5j1UpR6s7ColyR zw+UL?xP7Uk50dep$>s6?b@uju1GSR$j<&adNMazk{bzgo@kko8$0Plpm_1%M2b`po z2G5Dv<9&yrWlFDA+u`9D_%H13Uv=PwpTctj_IP(Yurzm?AZ3E{|9AHGm&9SCs)v+& zV)ph2xN?%gBlFXD^n%|1x9strF?kw$yoXJmjqUO9?sIM}1bp?T43aAU_27T<5WTuV z1k)Oh%6te#pCA>5o=xE53?t+ngX^QwE$~>_>ghGIKFS+`T=iA}do%aDUD!Hy>~>}E zA@UjIfA>4@VIc^ZJ;ovdq?cky!aDs+;Lkr#k3v<1gJ5L7(b;v6{Ei|KJMf9H2fW_!=FOY3zXhudwbZVXYhRbS(o`q1%v&eu* z5i6Xr0q@qw3NQ=wbNO2zynhkmu+l!lB!QKjR$cx{zR>ek4A@X10outB{&9p{V}&}c z?Z)PT>i#PP=5xxI?cpIAvY~t-1$~O#P_Ho29+OCKwBku}N+Ku65~blF0{Cjwe`d^f z;aNbap~gDGx#=SVPuJO~e`!!qqXXAyd@!w}rMn*-bxh}`vJHCb=0 zCbd!IR&5mdvEq2bb`M4LN!*P>QCSei-~2mvRd^h^PCd00G8656Q^7BLd0b|!MHMBdEEnd{hK2?llO(mZG&F@NXd z?N|LyvKRaFDI}4|2b{Pc%fw?T_)bswHtHZ({xECY`uJ0SPs?~7ei|ws%A!hd4>J3&|!EI2~r~8tsJP)t+=G5H1g|hzU zQAx^}0UCKvy-C5;9+hNyUaLl@qMXd&wq9Eswl(~aAN(lipOZSoQP-yz>8 zhlC1MXRFsn>z1ks!IrlrZLxyM*o#=3WX(KW0$y7B$$;Q4*brZ5z91B#p5W;yXKc>-lQYG;4boQT30=IJz%XhyOO!q zOFA66ko62qO@>Xt3jhdAO@ZrWakYYrZ!}?INENfHB@Big-xiRDzt#Ex-|0&tKkP;c z5VCz-2n^o^)L@^m7lui&6RJ2_@@XU{QvXQF{3KKhGf|e$o`G9C24(w!+8{JpK@lz< z@SRs`dCI?O(gf>0_fJQL9NBM^yh5cGSC0UJ1`3l@p*_AW^wY3UssXis30!fzXEj=c8PZf%}SgVgwUT2dU}wScWPW#rfcd@CbxD^v{au z8sP09X}4#P4O+1LPsNe)jDz%nT)P?Zv<#>g2DfvQ&F;c-9CR(gA^ z6JiMb(#)TQwOw=n*<9gyDlS7Z?&4R_9@m$nJQZEx2zS%L{=F;<@qV0_t4fZ1go*W@ zlhq?&*f?P^^`IJoQQ0fXt>6nG^Mo4!2Fi*&4*f^?+pcxd%7h_R$=zXZ5Kj?9MvyhA zRv;W$3Ni-mqRnY)n?-AhbT2lF)2&dEY-Z?J=ySgZTLX{GlRA@W!y0^tT2B!X8?M2R zxSYM%XHQBIfrnyIp^sNM(4tfA_#4%fJFP(f%p`|U4L>6x<)KO#Qz9ty7VJepY828t zoR979gBHL@jV~5!?s#GV=YdI5@bQLxT3VwUF?l9k|nij3NW9sPYB98P8_c*v|DjQi>c2Ly%hLT9 zV*lNKw$p#ZS5a50jT*3sow;WtyksF+Sj)n6AD5#Z1N$*uf^Wsb-;A`$#F0~3n z0}*YYkeK~1JL8hL_)Y#W%mL-5Hft)lR5(L1;QeFXP=Ya*M)pVnM z_dM2f-1b8?(RgYyHE1%;qZ6?wi)^7ngDn8}w3ov;02ue_@D=4P+#P{T)rV+L=j!hP zyat==TeRI}7A2rZ_2w#eN#_$5LQk4{mOTJG6N-U}cHmHR&#Y3GBD!3=&+?sE{7jbI zS7ej{8pDH%J@U;RgLLMzCDX+cP1Zb!$q~OA1CB_%g)a*oyF3aFGBrj8=t2x;&qFjC z1DW^1d?~}j4+7uWP7jZX>QuCg)DQaR}oDawE9a}nvQk#`E-+55@fSl-SUCq(i*S!q&6`LLO*yTwe z;81dr#TG>4tEi8ncZB>zj+6e?vACmS(#veN<-S=cP^c{6=(VU&T2@T244Yz$p3CCv z$|p!OX_*KcDHIAu<1E0EuGIE%> z$L_JFf3p?bTd3c4vkZTVQx0_*Cy$W8d{x-KUWjq#%77RvX~c;;dSWbblkTM+bqK^b z7s3?5g*)3WShEwNiT)}%YAMhjdgnL1cVw(bEy9n7HKQXYCf{_keVw*=grH=`fqZ8C z+c1lA^Mvnod6xVS%g{I0?GJG{`;r2{iipIDVT zx3D_#(fF+c>OkVcD37le+GNCUci+McsR;${WmZg$(8lkO9D+=2ch5cYIlHBes5H1; z+Zv#%AE+wY!K11mb!-8B_`-^S@xaOn&x4h$#f(jVmCQ)C`w`JyL~&+44fQ3gCR6S7 zd)FJOmC3KoxIO99ky3P1gL7iZY4dI6^mfrW=7JW!tk;vh)PIWssx`4P3~WuT3ccy^ zxo-chq|h`ql0hn_jLVuwagSC7T~L+$m#G?3=%zmYc}LSm78NE=-c0no8_*6o{_k7Eq9i2LnZ_A!{Z7A%(`KK-5e9A&_ ze)7=urqO*=xri3>T<4GV{pjhMWC!-9L9z4@CIfaG2p$QL8^t6|OF4Pg*6^-46_p3s z`Y(5}B5V`p`fi&rjlQkqwhw^wyycs;R<`#@9}nupJwVRyfD7<0!SNc;_(y>8scMZS z3G3I?Q;oEUi(8V38Q`mL7BlVgtkK#maRkE>%S`U;#kyB0F`ej`PtILsYx&Z6bM93N zU8qlP@zQIgvGg<@Fdgs$q@!MjJYqQ1lC>hCm@N0f$I9HU6FI$RODb(}9rS-S0zL5t z17dVuQwzyCE8mAk&UtGeLb96H_n6$Yj9_Zdg119h$h`Lzsy31$A&tJ;8r^5rp0u6k zi_+y2kZNF|n1Dvzl4C7p$I^GrsyRW;U_;d6MQVaNI8w1Zs(s&kRwv$>cm?so4u$XG z3%^{2cOs(&a44D5DD@TEt;B8$OBKPi=6K{8PoF86D;YVpG=Q--a`zqv*Di}8p2v$M zblcqq=0}36UGt=rN4nVNWT>6}7Oc5hheh{KH3KFg+5&RN3d71 z|FWUPP~nafpk;Gac73lEO$#ZmM=TxO>{l{z5oLH#QG9f1-$7QIh94dgRxT@aB?BAe zW8WnD4x%4cwm}7Iw{Q=-TDS$M3M+6yBcVdi+7ANUcDMvZ5Hu`(CBn+X_9Vpwur=(` zxL_%nvKn$57l?YY>bDKY-CzoyE*Yi5F`s#WU6U0KoSz$vg;oJu9fimbsmU)5g>R^gTV0*ZdrfNk_Isx=A1o zU9yRYh{m_T7=oDi*EWGb{F2;WAdVrY7l>cnk3f8j2+5nq1?pUmYi$qnHZD-3kq&w= zD5G2Zm>k3v1h9cfsVMSq5w#lmDk}3LWzm@hoAT`^2U%~@z2m3D19#kMJt?uUp25n* z!LK0AO~t_juWu?2LNi7t_vgYIk<}Am&nqv+c<#Hq z0L1f1pxUh?1aPYWx5J7Xz>$W`@eo7{w;fnh^X`MeY4OtpxSbDR3N;e`sXWC^c-S}V za&tS}1-Joox-;-+E}$2?^qW>AXmv06d|E>6#p%*J8R=aXT?x9np++Z?AiGPp3drs= zzAG{HyVviKn!`mbUmERs)$X5y?X*8Yh096j=btN@#K=7|Cj@j!XP&ocGve-R_t-{y zTP+ONdHPQ09S?)6kDm$0!EwC6l=*6-2%Lx}$ZPR+f}gp z;ZY4@IKhx+0~wKSr#7|ARGjF%isH#$0yRIS9oH=&W_cnX{FKk9Y5=~;oIcIwbE7vA3=-(2m>TJp88eMOo<}Hv#oL~illK4) z8UmfZaI$bd$|g{}e`oFnSBtv|iPu6;G;c~TnpcW0Gj$LF;kX*Y*5Q^NNS$F*ebMjl zFEH#G)|%v(oq)eto1A6>rw7e325)y;{zzh%^0N!jt+i<9@6)5-6kq*`k#w8Odzlc{;KLYh*0BP$O(CId?6Tiw^8BX!e&f zPfo~OT$Nl|mD5tiUFsyPN~XDNR|H#R!ph1;|1RbWrpcOYmlCrs!JrD&ANV(!*T?4C zV$2wrnXoHgQdqG+E11y5y991QLJZi_uktCX4GpSFJBa*-pp)2$Q^esgyFak(pEc2; z|By9+!;s&)>9^Y^uf1ya|EJ8jjV!=iyOY_$CQ=a7qh;64XO5d_8UF;bRfSWk0BU%c zdT#<4=uyF{z9#uM9WRK#NlCF(4R+)a1;LYZ&2M#>q9v^nnfHLO0X!9zO<&s@%btE8 z!6~aL35D!dkBE8ZRQ_sNb)0)AXQ^1;zn&j-xF%CAJ^egelc}$fRP^_ybHYL7z&|sY z8dEC4Rh`Re($=h}SP0Wd{lyG%RDxQecuVHUPqAZ5Szm|IwilC~z0 z_r|dubwz-bc!D<6$Z)PFTd;!~(rX3{=b@yCmU?(f=1~<@JLpkilZV^M0JyyYw>CXn zR?aqT)ZDLuh9;sLWB{;5p86`Ii>vo$yLVC3#)((HO|I7-RU;eMstnKZ+*Z&~(6-3a z9a2A^O57;Q>WZ(Q0c|NfRd+-xR+_4)Sn@$mY{~ltyhlOklC?dfPrurCW3Q~N-m7B0 zSF)zwFfYi_IKE$2{a>^gR9eGfqKatzI=UxSQJ^)&5_Stu)Ad=d zd93b{um@P&*>CuH6tnL+g;HKB;@l8$GjEPh-fCX%-;19PK4J4oy+ zHTwVc8a8o6t5?>h^QKUj;%#DEYhjTv%(#d!hf(vcAe}J|Ve4ztdrTt?0N8>=Ve4aD z&c*q4!JfQJ{lqcQ6kq6Uf!HkriMIhXC-0v6iMDg``P3WqEtuXguwD@?YFL)w(?@58 z`sjivX|I%Q0=Yg~l(n*hhuC}(t4{2gYs`-=@)ceMsXXaq6LXa#q{3zao-6K8WlhT} zz**`s!`b`Wc%0buw1$IijVi3Gm5CSXa~iKI7KrNS5kA)=K`xUbwaJ%;9pQo^_0IN%aFq2EdD$>BfC7lULVF5sIAYE-bGRvGj&c}%*(_&9lu;!-> z$9IWg?0)n3a+|s2{pLq-d^k9s%eQK_5&^3=`PX5oI|~~FI3PO38VuC8x)aD6T{g}( zYae9o;$zh?w(#|?Y@AT6R#+byq9BNwThm0ez{uc7@zeqFVsL|660KV8@qVJv{uO~t z8eToVmN~;fwA{pJQ}qmPtJy79W|Z2n*od19a)`BOj1E1#! zUb?Jfmb#4lm>&1yAjr>-;#B01-%Bd=n7E(H*u5Gd&55LvH_2gyTaBzJs5`zY`HDOG z;q@IOPwfOE(@WD}8}*Y*k}I0t?^V(AdC%i3qVrfDT@jtP zEVkrxmeIarN}RO8BczZG$-fS0@sDdHzgSd3r@6VP%(6&)TX~8`tZ!dd^?6UjKIlU2 z?hW6SmuMiicL1g_0i+9d`nS5EXLM?U@8hey__7iqi4#)+M)tsl@*m9jy})lk=O zsp<@sJcXK|KuvP)p{d?hauoG0MpT3KlK0vB=Dw}-t7FFjhdb{e;k4aV@{!p_fTSa@ zYxFe8K4#w>kX`egAj25(y1vtSM^X%>)!}%f{D-$-jCe|sOmr67vr4#%Ne8Ydi@^^CGbM z3UVCCKkN@ByOM)RQq7}MmWLE+ek5&^t8gQ4V4&0pUyNO>ek)ZLO>D<_%oUiqSqixJC$|=PgT-O5n*G-V^OohC&Rdpi-s1ecr);;#^c zlzBTPn9kc5T0ttNi zF$E3Vv+1aD!a$5V?jt5E%$b~2OXh9al}&%!!ad&WJ5Ac-PXi#0DjonjDx%X`-MqH% zpu^|QtdP2#O}!JC`niq@*gDIbRt{>)5qd7fTPxsdHx?yp2YS;+iCzJ=Cgf zsavTXq`6kW5MKq7^^S*wX7z=RhJNdtwM$KkTr+UBZCIg zD0f|Z56Bc=u@+X~eJ9ne~MO6@%S7|b?b!RjYe!Kh@87FQ z)TX@u5m2ffH(FHCj#=QpvmH;i`gYt-U^jSRHMikSPlh_76phDeRAa1c3z%rd112K= zfg=S-li?oCG$Orll_qBJ!E%FOTOittm+Qd!j)CvOVntUaW4^&O#XhStd7fb zZOntCq-o|VeLC-6%&*#16a#{nU=p|89$8suRE~7L_cNUZb;TX@dxqEptqI6jPlGa^ z41E?TtOt=gP}YC2%W|e)^lV0KV)D5w?^gd^-eiz>1Ox>=VcYOF9_s!4fe^2!d6u8{ zh49KSuLA<2a2l4u!WwE~m#JYRul=&a9kMUueP5+w{?}Q|j=q@V!eX+!iutlzF-IGI zRLrM+Ddt_#KRcRu>nw4j{9=mWVym8EQNL3}I&aOhrpR71p$n+v?*phqB5a}gGo|^0 z)ThzJ;pEBe&ksZpmsk+@ydMwyHy!!xeszDY-37ZTYF<-}X+VA@E^_ty05!z|#G~fr z2fLss6BOmw(58H~X)6OaGNrSafnLQsBrK-TG_Aag?-liwG~#$g>Q6k;!{jo1OE=Sb8xpSzw!czB@l{6-!-~6Pxrtjca7SUAZOACR^0o(IPSK7 zCH6`tc1TXs2NV?>@Leo9*^*0&maS-5Qj=;NkJeqoS?<1;6U|?MtkNj^$|p64G^@6m zJ?eAjTT2E!Uz2RM9IcJoh_6384-re3K zz8V|AZ9=O!uF$J*<4OJQiVd*ZmV6Ku^efuKXtzBv6yB&x+&kB3PS&K7+8)q;*I`NC zHs<>5$`Ql3TWGkyIPY~CvBy%qJMBhDDt%|+3^MC>RDbEpd#0tiBPVIj7cXoi5{=7N zE!d}}MVWmpN}D)&{8r1OFudEAKuuS+v_j*-RaEZ=@%gC6uC0+I={bdKeUT{gx>q#j zUbAp-XR!M#ZBa)<;4{Q%tJM=X2-0}rXo)e@H(x2k-%@v*k`N_hYZp8fTBV&3L={+6 z*n}cAVYEffDy#qx*1C2#EU0T*oVuv9PudqeW0N`=-kQygs$bWbS>x7N&1_=5@G zX$2wV@3~v72(ZF?ML}t+ntUT-l%lM&mGuH;WlQ-XR&<9u(A*7fA9LH?Zsx9YJK#!C zm%848ugGo;z5@5Se3O=m4!iBj z)Hv`bs6!+*(%NGgF4V_+XasIN-$Kbab2qrL=C-@h=5n7Rt_S_Nz*pp|0$+tLM>s6_ z$aVb#U$NUK@WtFNfiK@h17D7d1im`=y^I{-rNDh5AL#zeG`Y(&ztvd4#Rxa+=N9QH zcj#w^ejd=z!}@t#KXXWusqyJIciZxmpV!cqW_Auzc(>h6q{fVY)x6zZrjH*b`#TR8 zX}zj4$y0W=WEHMe<%W90?Ui2C=zQ`K;#J@6O{7dNU4Fo9`tfDm1e!I1Lc zpPA4l)AlZ8@b;gdFGZ?8*_+Gka-&oBp%b}M;*ihw7BeliCj_Tjwsr35n{9_pqDX1d zk&y(4PYAv)en|Jdc30+?_JT*!4iKdyhbWPaPxp|-RgD+_oHM&NeGwK0ID&oQEVz`T zrit@DZZsW)HD;M%+)2riwElJ7)HHji zD_wGZwf2;A|IamIINKS=7=4+AdRbymY`c<)#D@=Y@h_L z*@e+`FCpMly2$R*M?Tk?99!CUxENx8{cx;lox2JU)Z$A8N`SX>EUd$w?!ydk$6MG2 zSEI0|@;^eU{<4#ecW~KBPm}cTxi(Z*6+Kr!GxY=4Qj>n7ZC}fIUWn*vrE#D54XS;e z`wG{mf4_?X!}BGTx=YkfQ#S3LN&;^mf<&ZXWj2Di#P(6fztSgRbJ&O=~s8b;v z5o7t!LS!@~q(ULhma9s8w&R798ayHS;Y4V7ig)2nfZ{OVi zZ0-hktHKSDH_6vj{x;<5*|!WBU6s^a(Ay7bu5!_ym$%K+&ud~?uI^agb~lTtZBt35 zF@Fffv_1V_>ccTe)*Wk-o+C+Ugt{&owtLU+0dWJa5XgEpqc%xD?ropz+^&|v>&RVd zDRzpbuA{+|=xCJ%jkfbGpw~fFqSY4Da##xLaQ{$LpoW`L_?}y0L9+@A#7WY3d9N=h z;9EWUqod^an;z}PTrbe5W1UNpMAEUz>fo6s*=_r3If>7jxh#+)se-ST!}tbJ(5{D|v(s+J&?v2U2lK9uTU zOQrh~(;N)zJXAi;Hr;O@6ww$I(JVJC!ah{Qry@J(q(DV*0y#LBUTj7DJ&3GOWL;-u zokc#W$Vto8>D{PVbW<)#o8J}_qP9_U^~}V_u7^!-I^1`r~Gn=U)AIjgkE#b{r&h6|=ni zc=La+@1-LvZ-watl@DuMpyz4Z#7>g@smK{?10`=ueK(aK_aVF(DtQl+TZH#20#Bob zS^mgS5&`avi^VVhq2!H3zfcWXh-bOu(F^P@ z;sGsg6j^MDu-zCoCp4wiowz+?#GVqzX?%yC{ z_4smgS>H2vgPUu_ZFRc8c)!YZcbPv>>ejhMmjZuku2<^X-Q#?QO5OXW)Mea+Cjr!y z!c7%AughuV>CIMLmg?G1bw^q4>)c_gB^_Dyhp>wn3Wm(Fq2TiO>Du~V(Oa)7_CJ)k zmymik4s5E&b=sfY9ao0>oc1!g-FILh*d8B%G@8&^+BQHExRmFPy+k!`6!nuw;HZ)?|oAgbFR!F)Y}s6%|S=L%v`X zKoQ|2sm?c+=1N)-RpkC{Dk%#C5Did{iCz-faErIlQPS|jy6AQ=iYa^c9Mpwg8;t1z zFgHwdOf66SgYs%qmum$p8egZvQyQZXKQY}AvFUmlbgh?>hn4-c1rjFJuG5zHc^W#Chb9OsXO?2=~l}#iS^MOyq`;KW2*F_KDYB=^*vMAcr zvGtYD#9CWen&!fSj)sfq72ee7TXIys+~fdCWz= zBMUl@<@&+&dU4r*tkp?`0{sXw0exK1+e!P-9<2>=KYRZRCJ^he9QT*2C>Yi}6Jf3U z@sb_gPNNsuK(R;Pn7Xwu zDwIOHj*^$+m#Txe%9eOXYm`ex&U;IvUTJhnoxYpONB&b%XCJiWr_(?K#P1eu~O* za|2(ld&GS9?#f}bYH44N1fP4ks$>GAOs9_1N6*c!u-5)IU19wjb%Du=-%(H%juCBfr zAsNWEU%1cPohImiTtd&J| zwjb#NCMtatz6Ycguu6DQ?)^bo*V|mb!+k=>h8N{tH`doPCWw2PIQnYydvf=a;fI4V zzvcbZ;GWzA3$-j(UY6#bTz8>bytFNX2x&V48r1ymER>73!-9{KY^Jl$9Vd;$Xt65r zjdX`w+y?h+bKBhkifJmpdbN6wcc9DPN}^MIBq>NozZBS@9#mbc^=Efyy}uL;JaH6_-)(W; zG^6DT&CA?7zY`mK1FJW?xYekbD!&n-A$KF}7K)*NlHBy~U?%8IG~BtGOTETy!^mMF(CqHTA`9lnV-y#@ z-9Ymh!ygL7wZB5_tY^qZ>Og_5?ju`v+g$4C;tNTg{=zwx=DSZNc<~ju4+3A2TOIg{ z-F3RH>EtJuwq-n#$jQUH!Ztomg?Bi51ZlE$o`KW)8cc^Bz6Kj^eu_L;Flmn8w># zJ0w@)y^t&4bjcO&S?}?N$(7mtHBO*E+02Uj(gjAk9;l&{M0|g^f9yU%iOl~Gq-u5!(l=IX>{V${4p-ia@$~s8G5!i0C zvPuqC60d0kZxDC2#r=m&dF^Vlru#exO@%V$&Am*fd^{PMa;u~xJZ&8w*2${P_Qx{rG{n1QTg++7NXY{t4<@X3CB$GvJ_ zt9$BP)rF1eVe?2Sni2SN-ED!7_qhXKfxABN6}j<&uh?B2_)6W`fv>`y8u((aF7Va4 zp@DCtJ0kFncH3)PXgYGo^&ur-G}!ijfNLs0@)dQx?8kR0_UG)!w~qO5?8nk)yX?mw z(?g;CxaJ)7;%4^adZdaFd7(*{_uSd`&3PAdH@M*nH$>Werm6f-kgMn8?=*}$WY z`BXY8h5xtqY)mMiY@6DAHDUw54^pRIFM({KbUN59MN;4{QvG?C>`~ ziod4Mrt+Q!)&WTO-%*BIbQ5w%Tx01u|EHn@&XbW0uBqerf#;eBEg;fMX^d-*BS2PR zk-LU;(X7ikO}Gk&bPI~0c&V~S&+?;XUq*+JYkHGB;F@MN&vQ+Y>(SBP;a-w_gKLWY zG~=@$+WBOJ_bhW_k!P8G&k(JQ!ls+ftF|!Xm#8?&PvbFqGr!?A5K?UQ$IemwGdM_a zbw%T;$HeN5Tv5_UsZrTUEg>6U-xaxis+Qy8U|T z7^sHh(}S=AcgVwnCGypYgItr!Rf9NU@Wasn>zBYmm*%Wf=7P@O*4n zR5<=Np@kcL*UBswLE2;n`|<8PQ=yi(^%or$sP(s>?^`_;SFOI$zB}ARb2qpv6>hD* zNWP}>g%Fh|?%jdV?FTd>?x=>^&53(?usEWKKd83-DWmP#a9^rUBBvs2UfMg0o0QXe zqbAw*t-JPQsI>PKwni?wE6xb#F|w4^{&(*moGvh!is(?=|AX%zAi!h4`2K;ADho{K z`v*)Q+;wLHcXx%|u3@$&bM=(HThwbkovXW*NBWmsV#y!t_wIUq<-(IGx2f~Jf;DJC z*6%{(3`CeVLWl1av~1usz|Xu_Fcuvmw2%D1_+G)K(szIMy@H28OKs|Gv#Qv81&8hf zvW};1vd5S;l*R0(Pnnee|L}hM7sL&+Al9a~DGY9j$I6ji=pMHicCKT(dXSf&b7fFd zOig;IttIs#&|AOaB<;N4{z~Pu-70aNWv)#PEDWAAxV9k1qjh>1L90!D*mmQySBKff zmZg0B@9wwXGR!VA`wr6PP{se`e*2e6YEVmxED=kP4=YJq<_ctw=Bsud9FS$YG?2NX z)PwwoFt5p9tMh++zx_#Fc{xvF_5Sbfx6e}^BwUU`@3stz_`kZ}ehE~rGK2f=pVTM& z-&r&sRhXMOn7L4M=l%_C-q?iRS8l;b2oYh6uE3y+V6na3EkQ71X1sr?<9I@9QfILB z`<-aKr$t}D2bZBZMl>yG(>`lT) zR3^u*IL&rpSJ_j8vU{m)&e7yyD|o>}|47tq1<#DfRxoy?)U$O)Ki$XsRqdVQJ(m~I z|E36#(m!r@Bq7Rn6}{U%+aJ4UYxs|BVtiMEuxhq-SDv&l+t`rXwr{vTW}71NV@*KT z@C6hRoz}9ns}BaWEbV@SO7rI5^Fef0xAc|62fS*sk3m43hZ0|)Wv`rFg$GQn=>AM^ zkeKdQrh7Bn(URt}$>@pC^uM&=%rh@LYpg^OOEVnzfA-LUEOc#`H6~eSD|m$R>M25r zLXb>aIyB^S!8P4&O^`Mq_oJ#3RMZziSN4ZU2`t;c9z4Qr~oDM4HpTg=1vOwXmr88O6IEEknx6uN z7b#p|6-c)Pv~O7N@^gsHsc4*C{i%2#u@oja=%mf{*>3My1h1O=^-kN2XtUMSwlOAb zp#NuIw3tPSHnOE43_pcSE?LwFcuWT7Z6nj*d!mdwHyF5TQp1cWI$yKU<-`S=AJWgA z<#WFOfBCM(ZR>T8_Ptu3fy#9+)BzHh;%H*4rVr5@4-;%WToO&>;p1)3!f}(KHI}Nn zh>C4@_IFgQ3`|Gky3@no>ya+G#Ayz@xCY2T#wIs0JqS1VFBM zD)4ZSn)3*-u&v~CvxHs>rq0$1j^IKu6}egNh~H@5NwQ7?rf>+jDkSe(UYxbNi3=>e zUl3jwOINWE3W45V+%eiBqeQmtVe^Y$T1V}ijjruB<<$8;(e$f81yVBqVmJ%ucbdBo zcvY=GQx+Fwe{mPLRyK9yTwYuGZEJSJcy9Kq|CPsWE+Jdg?^vDe7#w|i_@JN03{DO& z{mI}Gupo&MB-2PO&0Ka_!DW{$v1VS>x1z>zZ2(&+)@=k|Rje1MYInd}o4YZ#KmRYS zOmEYRHRL6ko?pctXnRZhHjW0B_uLr?|0uLjn{=5I>08Nw2`kJR zooNc(%W=DnKx3Mrd$w@E`|h&)gOhQSzzPcgIWnO%oQKhBX`h?xdrxHIPy|w`43w$JF7$~+Ypg59#TvFcafsXijj71$`6SesYS`@7Kkm3= zNY4rm@Kz<)cjIUVdw;%9jJq1ii}3$Kg(usaHeMCIHS+0X#^;I-!pw%{I}2M3gjv~gm1iZcRhkmfcDN%<-bRK&A=-(tO36aHr8Iq}A_prrpj|=Z z-Z)VhkpT*!Hk!Wkqbb0tAY=&Ir$#=I8^*j-UUv##vSaJhG`AxOy zHt~m4P%2ngwe4B9TURC6IP;JRuxkK?$Xvgbw=s;o$s!}WiD>@=QxS!B!xYH-#0Qzs z5qez)C^RH;p2}wRk@fS0{O1aD1Xj@Lmhvd;9EqH;BVn1KFH@0w=8~;@mv*BUx8u=N zGHID8vOC)_{)D}%8Ni(E+0<#X?CrMF4B$GB3*!wkoJY1GS=O%_EO?1byJcH!Ajn~K*VS(T*dBzqh-zZ zua0YHOfdu4GE4BDOCF=Rcww;tqwQNkwipVQn=sVJ)>-UNDoxpYp8u8Cgu_iJ$%1MN zgEO)lT&S`2VBmQicyu8Qn^3}oH=O4E$@Kyrq3Pg+XnBM4@-Z?~3>=KSnG5ZL;BXu& zK_kelwiDxb27PUk(X&uM^`paTJWEbm_lrz5hA1V@HAKuQ+=QuWf_%k9`W@i2#&%M; z@xZxNoAbaz?hxtD1J%Y~h-xcia~?Qs$R<3nS4UpR1AWNXDIk(>8xL?^*wTB>fZ@iV z>Dqc7=ZVA}kg#=4(4(D_oSv4ZU~jTqC|L^mTeo@gzsG{+6ngRxhLxWq|7InG{H>DY z9A5_Hufp{Q`KuRunC{)~zQal)wdV_2OJIvqw=VG2xix{0^W1^2!o3jqM!Lm;Z?v0> zPb5C>&HELUESH&lF6RVeYZb6Sk-Py?10yu$RFaG08ivS&JBtDwQc?@ zB7Xq2T138wK^QsIGg@@&P&2+oRsa=*9*rN$_hyiZ;yq-!Kqf?$Ue5-(Y*K0-=E2|4 znaM_zD~4(Ayd^fKJJ+;#Jj+l-+x4*Z%4qyb85z>Gh2sM25iMgkm`q5kGN%z2icpF5 zg0NUs`}<0&4+bCK`cKZ$Jh$E5Ug?GCdSeH#-gl=WlNS=A^OOK8lKyY|xTEn8MdAMw zA^NKFLPe@XLe$EDid4A%jEdUb0-7#ppTZRd9Q(VF0s}A@|Tn zVgG-5c4z-@^r&kU+G zne+=)O2lMl7?RZ8%J>U{DIBvxp~rJfW0h~7*8%iY(5BeTJSuyG;zfBr-UvGY#m>qr zS|ZX%cZW1{yyi^Ct-)aCnRHJ1n&NU8|Dk${z152B2;@e1n!!^ z-8qQgC2%hY!e5x{)BiPaAIEL(vPb&)U`^+KHE&|%;WQZnWn06Z5X^M-?i+gOIPN!K z$L{Wh9HPiYQk+e?&;&{lugXo9!LQ4HcOdprtbIF1Z>UB$4z~mzdZtF?cGq^eMCphe z9tpMYclhp>8RK73G@hl5P&;f>vf(lrG27jfB$T8exqj(}2PxxOCL^lxp3&aiSRv4;ahx|dUWk=1FgMz{I*KO1 zn;V&h#Fz`#>S%JV_OWbIXUa^4E*gJVl7Ksz#(Fbb*?ZCW1PiLy+>-e}B~Z+8zNF_~ zq&SxFM{5uAIAMLPcra9NW1(ph05Mtqz6x*|-zz#zmY|C8tAcQzLt5AUnYA+s=MjZx z&hQqQ%SMHQJ;y+b>@rj8-@w8qz3`+vjRiCp|1p3H`6#FD?@HPV&BVllcLG5Z^KM12 zBAUDN(AmP9u*OoC>)jz^oLaRh{I4)6`#JcZvG9QywLY+NbaB-=Hi2u{9?XvK>z`Mu z(4>%s2q7P(*lf1BhJf)Z!0+=3)*~uUul#NJp4=u_r)8skmnYjZDFl=?DswHe#;@OW z+Dq#)x1%x0ej3Am%J850PT#`BSPdpSOW4*IVTEuTk5a=FF4(l+EPS$UbY?&5&^nRc zQyb^sQ?q1kZ(>4i>46FL{6XYSm(P*^x86Tf{uAWq(vcgUlDj;UGM7gHHu+wjnGl34 zelvSzk>;*wAYNNVP^*)nx7^Mllj+}V0#QmNT_H_BgO!mp7b>Ymf6(kqu8n@^4>S1I zpQiq+y;tUswer?7O3n{lm8&!@xcYOyI#g(ioc{m@s8Sr!sN07Ob(d_&oGItF*L-SKU%8evh%;+J=W9HL!SOMz? zVtQI5eTMODGBvny13%ZTqWSTbhN8vO07~l9DqOea+aWy$cEJb8*S13AJgT2HB}nR5 zQfFmrjI}lQy(qb|@mgkq1F@lu7=k7sGucNd(qt_rS#k*%bWKKwtslHto$IE*B^veP zztq#Q=*@Z=7j-!O>Za;&{p>&sZZ`$E?Vg!j;r;}L*uBK=&uTe$5>qLA%R~+9)hzI~ zQ58*u0?hc(?h1dcl#!vQfwCq~Bt4o5crRvKel`HR)+Sg;^08^u_B-^KWn3eMh zqI^r`PnU0xWB&&M8B1aPstP1q+hpM4IvH#7)qoYkK}0~rly;lYS}Em4dkhLSo| z5_~m2OvuI;eK&^R_$P;cvKgT!xin4VBR!$C&7JW-$CHDNC&$+ISj+6*?PViFWHQz2 z6)*0#Pt}nCmC+cKiUn;da<1U&@d+vDtT$uHEtF<5ac+(EXk@4or1~6%BT_0-c3yLc zrH(HaaN`U(1o!w@@>VY?Qjr(IivTVrvHs*Q4gIz%5t3Ns?jUJJ7){bx=x=Hn8zK}? z>w~0qVKhlchJKSZLF-bHQv|g2TiioTzm6tpVD}j5nzdX?|H37hC#+{FZ7fOh1ut1; zs#f6wz#2^v3Q(i#6gW;FWE!tj{JB}0w5Dbm3vgbUjZqO&Kq_EX2b@t4W5bfXF3@g* zIE94dfsy2EZ9Dk!lb1-cc=a6nANgv^PS0=nOl+fN`>5=q442P9e607qUYq>!**&Op z7}^BfQUN>Pda_AS?R|{7SIRw+QZtolyTZ6!_nZQ0MHT?lIyu&*Ud~j>BI_@*5w8fz zYMq3S{%jFzhrkM1LF6zNXX5_`(%Q0?=#5`kQ>R$hX@r8IYxZC1dNYq=+-D}OBCzEY zc#E9sHVLrN^vK9|Cx!}^WH22w|IZR%+^(&40O2qv947_TY6FP~0A8h%Lx2U-oq~yg zP9QG}fjnq+?R>BQm8&mNKScJhFoF?7!Ah&Yh+5@Yt7QA~_*$z*N?~1DW^{Yzi~v1% zdUSnpS1_rcVu!vy@K$}|OK7P&Y4v*a}IpSMpJ^LXDq^A!JL4VD@J^DTFF-G;^ zU>*8ZaKX}_d{N&+9N`q`=1=md)ok_^?rmWkP&Nt_+11QN?RPB}^UM7-u2eada^9-~ z_m_KMXlKe<8v00SXr-@WzOPzTsrqVnOBq>61C`9=#iqjVUPWyxOYfdyWChdL+~Fe`*z(4izt4H*NSdEOD5Ff5 z3_s4Ij%Ofd?C1o>C-Hz)Lb%5x!$Mi!J-fz7D6CUsBvCW4^8Ok7#nI>UQQivF%al+5 z$sNRi%yJZ42iVM3kk#;O%*VH!;3r^T92clIS`xqWPiE1wCGn{w@Jr&`mdG%8XP|(5 zU;k@%IqC5RNzhR7U}r;tb~%n;#x0PVi=hOjjui?B863J4iP z&d>Jg%Zl2xPZ#*0?tR+myBWnI7+rp*PyZ=7k&2{g?tk{_dq*hJ#$S!Su%`xX8^|{8 z$arC+McCC~Ax){PreynWl!EcU>cjd2Sm4l2yF8tk>17KYbAshS?EeR8VV*!mPE}+o za;(}c$}TbZlZ_q^yw7De_MQy6f#)%6-> zvrq6{6u8F(?wNsmg}KW!Ee|MPm-}Jx?cJrBr|f%aW@8)Ty4#{EchN2e4ihD z--O%Eel&vDX}Bvdmi&gDI^QpzDdyC6ou#HDb6M4U6sFlhO`0uURjHy%j70siVn%RG zqp2%iSVgXyv{zU3Z3D4MYNe=V7G9vIJBlnlEH+Zq%AYRb9xcCi;uY7Bq*O_iw!%Er zRh6aJtb~01$v?iEU&15|pB(rrNh8LU=BXNPRk#~`F)d>^Dsy=bNgkWyZ5YhcIP?84 zSGX_OZW>a=v%kx*i3Gd3mNqk8u&so;D=JGU*(93#P0C)ZUp%0rYS8%w7129e+n(ya z+mrbl_u0Hq$?J7j=2U{|@K(aZN>i?l*~bVv#FFV)lNJ zS|i(0u5yb+^UVO}1ro?FCIKC0hQ9(~QL6$)1lA_+x56dlDpU%8phuOP+7$MR;;mPL z@UcN!g@^rsSKS~KQ^Yk&!K4Jeuccwf%qTv?{cg$inhT@MvBNJlF25{RaE&g+k8!aw zXLPj?85@)$qa{^|nZU6~*q(=vshXuMj_v%ndK>mw8I1BVF#jcasf!&B19S zPF?BxgxLZXiz%ZKB?JcJei%ck50J9lMSI)Ei^<>c!Anbp0<__D&PaZJvkMrh3RIfqS4B*Bdgw;4M3zlVyTG)HF`^&C%$bnjY`gl)YQOOF$okcuBs88;I^P zc?d)3SE7&8S;TE?*t+eiW_voRt$v(cz|MV7+Nz1YNCQ{X#*X^6mCvb(Z6}8I6LjL< z)>I5IgJ|lUKlr8|>^>-v9R7%#Kk^I7ozCm6VP7mydpnNN#Ak{7v5b?@vDS7yHY96e zr>WOlI&WrRf(FzL-7K9;-M*`Q@7;FKCcS6!hMEq}**VJ|d+0nnmi(UHjA1ND9lebN zPKESV#C%;9Pju?3pQE!=QMGgwn0q!$%5%EpMt~%2|L5JI`+v@ZOgj0^Y`Pd|%mk*X z^-Mmbj|^v?CWFY7Uui2;!)WmGMRlP62rqa3KE%t5d)dVWJ@-+D_XC9F-L&P-^k@sU z?nbR{+L=G_e(#F*4pEvUfB{WinFv3$lV`qdH?a6p0Ga-fif0!fk&GQ|esGGuAo`rf z@mf7@R^E9PL!ygT+T*+?2{;dCswU#;1eap(Xw%w=_$ivWi{unvMNmNy&x%T*YB+KNH2(u@GiS0 zxUd#SJ|+ge*rO&;t1HOl{t5QgPuZr5MLupO9b=B97jnu}J4-jv<_VDoI9Kt$*gAA> zEI?to;0q;eN00u<^;1d8upj|vjSPxYR`(5%s~;d{QDL_&V$%L{+{dU*)=@}^-ivgM zgMO|g5*pAgasR%mfgj0ud(Ia zO+6HDdwZ#lOv3`eDWtx*XMofxKrM1ZdE;ddt1qOj@h;Y*JuuB~#SAH8HqbTP<#+t*&_~rJVI`EWP`NSkr{utokiZTk00je4d^8 zCe}K{D;TXqMyfkcTWaTDDo+Nn*(0?TyU&uLdIC=;JnVGCOgg%;{73uC_%RW4-()VvP zzCb0UA}6MW;4Pw4b%aQZRWOklkpXI)hK5FhZU3HD*jTjMP4^p<42iBe2O_Ik8Pnmm zv|u5`n@kktGD1r-qva`DMADKC>>zi0f8?zumc7f$F~gEDoBaUR7ln?iE!z-Gbi=4t zi;9dk@&xpQ#ciqn>!)AXZP4Add1G}s-)H#pci zEJ(K!`V#b>tH*)g?3ZmR%M*}eXm!YcJ1@&!Xc|xXMTAT3eRMw+xH)#j9y0{Iwzu8y z5vKJ&UH6wNAJDDLWp7btzLgp5lfZ&u7)q7*CY}3%kwa>a!aCI+D_hov$EaRgnfA58 zzWh!4)_uYaeQN9W7AE14gRil?@-*ls8uu!b??qmYKbz6Q4@UkahnF-j2K=0WyMNf# zZ_PDz?>D<>=n-NQy8~7_Z^tZ8WkZh&q{v}l_luiEVLc}vSeZJ?jUpirGnwIx3?Fvv z6bw^e4uK{X)qmIFl8Ys;B3IL!5|zGj;Yw26W+DOIN^%-<0@0|X?ie7H9J&n1l`iFr zSxsChkuBZ5CL$vrf+JOdx9t)v-3%xwu+j zn&@uQrzR~EGjFbT+W9xAbTphg+D6$r2_dTu9yc+eakw`1T(*>CZbOX5pT|?#I1%-z zAL~;m4>58!!ur-7g|UE5y|YQuqrQ6a6(}X{`$e|D#RgUg-~AO5so~IFy3ZF+Z?-ly zCs>>6@M}{K2)+TYKEp#WV5nsDV881BZ>@bucN>K`nH%#RKB7G6@WVlQ7I@OK(?Q)C zXes#dyAvmohc%}|D9;W1SZhw)e*s5}NH4<8=t3vzWn5Fe-&Fc~uMg^Nm`uHnK#8+8 zM|7)q^5mbX_t?&Q=a7ebU&L{*f8^`^5p1~CtsUrC(ZmE(56ZU-+B7LFyMQ+Jv$D6C zxT9~wtrX%-PIv4rlT+j$M&!t%Lv1LDoK5;h=}7yk(Bw}(@lR8}?#SrPCF?bJu;dt% zhEs3v?k>$-W8X_N7Y6R6z}+u!Cz!iD^XuSyc<|lN+}6yv;QP0@o6VoQ>UH;qQ4cEj)X_ EKeRhrhL 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

_2+XH=d!}M;RK|$t4$7eH$vYkE?GNy`Kk2 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ǔDp8-VAhXDx5}RQKT*1k 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�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

Yq_!*J}Q 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 z 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

pLJIk}_ zoY-lk8yR06JIWz3e{Sh$>-wZL3)N132#rG0W99x5rgZ z7LL6m3xj{S1pPy@Nc7#X{7H*v(S_;v)m+a-ta=9}9?W|iCn@eE?mcq8b?P4(lX^TK z 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 p5 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

ii&z0iKwxh%tT=*WS@%g(6OKD#L>8 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

Bx;~QCtSecl)o6lCS*^6!UEt`tEr5 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 diff --git a/vendor/cuobj/lib/libcufile.so.1.18.0 b/vendor/cuobj/lib/libcufile.so.1.18.0 new file mode 100644 index 0000000000000000000000000000000000000000..fafc7729d9de999a11390c280c24be903cebc788 GIT binary patch literal 3834200 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�dZz+lB^4xb!{ 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 z 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
    UE;>vU{(l*39cXG*RuN2NMDGffO)O2 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 z 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�g2b02ye4%j8Vp>{* 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

    fNEPk(2Se5wb(bb);V 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�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
    U5Dzpcobxa*j4kK+Tm?}--wZ==cx@&6>Q1Mp*? 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

    R;(Rp3y>9f${qc7Owof%Aj#zJU36 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 GF!(RFEPZ7F diff --git a/vendor/cuobj/lib/libcufile_rdma.so.1.18.0 b/vendor/cuobj/lib/libcufile_rdma.so.1.18.0 new file mode 100644 index 0000000000000000000000000000000000000000..62bd8982ba07fa0743bd7c53ae97329cc5cc0be0 GIT binary patch literal 86664 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“?7f)0Ys{m+U9r~O~}bVP$5c-9qr~3 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 literal 0 HcmV?d00001 diff --git a/vendor/cuobj/lib/libcuobjclient.so b/vendor/cuobj/lib/libcuobjclient.so index 03793109..18bae933 120000 --- a/vendor/cuobj/lib/libcuobjclient.so +++ b/vendor/cuobj/lib/libcuobjclient.so @@ -1 +1 @@ -libcuobjclient.so.1 \ No newline at end of file +libcuobjclient.so.1.2.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcuobjclient.so.1 b/vendor/cuobj/lib/libcuobjclient.so.1 index 2456d898..18bae933 120000 --- a/vendor/cuobj/lib/libcuobjclient.so.1 +++ b/vendor/cuobj/lib/libcuobjclient.so.1 @@ -1 +1 @@ -libcuobjclient.so.1.0.0 \ No newline at end of file +libcuobjclient.so.1.2.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcuobjclient.so.1.0.0 b/vendor/cuobj/lib/libcuobjclient.so.1.2.0 similarity index 70% rename from vendor/cuobj/lib/libcuobjclient.so.1.0.0 rename to vendor/cuobj/lib/libcuobjclient.so.1.2.0 index 17bd0810c3d6128e289b57baaf56e719ac381a48..77ef931461d374190a344cd6cc0aec9e0b301398 100755 GIT binary patch delta 65814 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 delta 65519 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

    @Y!N=>@092}dz<+52OjhWd71JpzP`sj zzrImT)InZ+W!LU#BeETpg@F!Q&1XTn0BSZHA8Znd8LoJt5Xcxx+6>f25&0tz>iF#& zu;$hb%XvKHl|9wG44QqF(T15FZDR@71>QB5{y=PG97x8FgDA0pJmNO8-XX2~#@69qgF&oBRwAJkk z!mfp8IdDtGm7jQG^a-$Eky%%yr=|iKGXmTrBs~D(^6e~=FLOWqdbGu5UbjIQx;zL} z18?=PyJi-=kg`}G-?=MtpjX*C1JMB_Uu9biCJ$79jQHX*kEr-{7yJN~-q};;*1Pq^ zpQE_1d}Zw~dOHjGy!LPXuG#_l%!c7!j;Z<#}ctGh4YPfsJFT7&XQFK~O zh{=>R39chexP{()^c)|iFF@j3(DnjhbT<73FBrLr5x?-5&>@&BY&Aa0CS%Zuk(jqW z{MFTB=P$gfeWyk6?&V$xNS$NJMlg;_hnH1+{i*Jq{901#KfK`E=~SxfcyfIlRt3~R%?)){K`fr z8#VdIKsy4IYNu2=`wv0<98_Zk+Ef`?y+dKtw@L)%LrcM9ARdAy(~M9kXT=z$!(s2X z7To+Jv#@9fSG_1t=~|3UH`sYAakpdDa7Fo#ncy;}f{DjZgtcdsdjL>X2ICL~s=6B^ zLz!^JC=<_HK{^ecc0jfvGz}dE(iLN%u|KGBG!@XvL{v3}vMNRu-@~Q{H~&smO+@^P z1CZ)rmWtNG8&Lk&dZWP4u`+%Nf1iN#`w;wwpk+Ye*Rbd*8!Z<$8narK^n#5Z$=M1( z7K1F$Xl?ZNc!|}$!+?F=QXvaiO9N>1Bz)L!0{t6VRD3=}@1kA@EUwXAu+3*sw>B4=}^i@bc z3;h`ovQP+`36$HU||t(fL%)NP|E-iWV-~A)C{PaZ3Rb0^y2w#Rj*t! zLRVYp&2#z2xl(CR*_k%O;%uQGL;KQ8*ng_NDIl}Mnx9U;sXvK)j)CMRpdh@2AnW57 zy@l$~CZG?;-$n#VZUSi#8i3>`piFedP%-Ip_wOBMgT37Al+yZV3%S>Ir`NL|sd^~J z&9G$H>pD};v{_6=Mw3BuvsedaEl6$_r@@>AVY2`(!(0Wl3~~56_qEf`Q3CBjJK0%AN!HpV_MyFjur zl!+EwRT)!;xUeNA!Cp3oLRn(dUvB&fsyvD**BDbNXKIWG$ml-hOdEg5NSsALvN0Ni zNd?i)`QGn5Qr3R}68eE;{oeyKpAalT72quV(ylTM`!W4^f-X~*ygd86nhGsD5{pqJ z59-hdrJ)D3yWwpoNS^%_OedK3limE~_%-OS5{6;{g|SGCiUlf+!Xsu7uJGYlW);e5 zJ3LW_?@)%bp=ktE1CTxi!cZ`SL2!+gyr((+SrHjk#`Y%{_+M_xNi!>raAjfV zN$8IghMHPI@M;Vos;M7C{Sbt!W?R$AZLFRzkPme{{o=VJm5ntYZ>nXa}h6yM$AQE$)>salQ2^A=FqGsy7zM#28~Gsqg3F+SUyW#`^5DEo`3+C$N^e?c)G zjz)_%w|V8*&%o{>zw|~`Dgk5O1*eU}`4Gu50>VHDeZ{idyo%?=fpF2*6A>WNR*N&Y zd7||c*b__c@JP?$gP@It_8yY%h=e=5a_frY@vIM|?{mWD4WUEuiYo0=F1R4$yFsdY1=TKLfi@ym^;biQF<6nT>pk zgDKK}23h(*(BHs^(?m$(!@In)PZHP!kna2tQwvNdap^8kwoV6Y7oPWcqR$4f9}(o@ z158LTr$xJaJkB$hYC|ph0BQHdTwp7Nyp2^BWVwp6q4_+-@q0WfBpHp7isXhM*)sjW z^dVe`&`bC~)_1|bBdmYot<>#cw~~rpS(lebBOKW2myB90K4d^4--wE$sq$GaXZ3KW zA34h5%{*#j6QiFuYF+Rl;qpDYD1xleI2(lf2$1{@Bt zq#brUg|vLgODWA4UsCZSGL7Duq2JZa=0gYdW&EhyK>%kXVLB*niw}TbO5jPzhbT=x zfjVZ}0bJv34ApE(JboU)LYG@;{y9jT0!lmE6FGk`jh{k(2x>Ga32A@$27QC^owwaS z+jvpqj{N1ztJATFgKE&T!3QZ!UOWjd`8CgrBQc5ScrXlzAs~4?kSKBb0k2?PfwX1f z>H{90coOV!5H9I!U|q>G{G}QAI_24Pl-#mp}j5LRsMCzkp4~tdA{t5P;C?F&oWBQ~&svah8kh%@n*M<9I z9{$E;uy2EK)ofw5?783Yr8>+gsF!ah>3O+0g|w#^Xz+_xJue%#u6o`qJFB_gwAl@t z_R^*kPj(a8kMT#L<{Pr{^D^nFy+&^@b+P6>n6}6QAFg>N(-vvA($Zj-;BPj@ej{i6 z9IcNm77Q}2d4EfT_SU>&Fsx=36FeQ+o-50SC8V3_8fITu*$KmvS2)e7?A<9#-X%yP z=?RJ$3>?8QQWJ7b+h#HizlR&yyQ~0sJf4XbFv`IaJ~N?N3L0ZVS;A#gHCd@xnaZP{ z;ctmjT@pv1@Cta~bMXnzdGrmkacoJcK`X{ibj!yebHzwWr8(4eHjYFfW5q~mO)Ew* zbJ@u&zgR*aOlX~ozDc>~B;F&fAfBkdi=>VmLhOnr(K<3sSPK*oyk zmRvC&LB36Ca>eK^=k1srOg50QV)T(|zd*hSGFObga>eNKF1`x@87oFV30w(zA*IO` zqrY4+{N~}I`n+mLlq<$4xnguhVmpwrVoa3AXCR*tTb}XA>MrxK$${it9$VXJT{IFV z(=1P~3Fg301)`yN@(criIM|^gRfPV{Ly~(;G?7=3b{Qm>rTTS@LTdTA zmz|{D-=in(1OJAHdSFw;Jo0c_c^HVa{vhdLnDT%Qed%Ed)QiOT%qC6~A9vGUctPGLwBPbBf|G}3UZNat%;i`EY+ZGtrpirtmEw=5)fVxkybYfvCYACx`B&nHQl4giI+?Sz zTn0Los?&;ruYEj{-oztl1PxjRe8@8ky^qeK2)z0rzUx4849G$t<`LT$zjXwsrQ$=v zzn5@=+`Eq54tIJ6B)<+}9t!}chdU&j|d5o~zuiC)CViFh1!Igy{5wi3CjphC~RUL&0$A>J4>fuf!IVQ*J9+4KeWyy(|f5s$$u27FP=oO zgF8JDFhVeoPG|{={Pl(Sknm+ih$m>#@~<6(V;a7ja2fvr+M56;c{bQh;3)Q&@TFjw zM|>K7#sE&Iud<9kM{wyRY(4I$;y6GG`YX0JQ9;uxdD3&L#N}?Bxo5p{f2v5+G`~Ug zS8R>6_SFfRxVt(Y@U*Y}2b_$UvJreoANq^9D2>1^lKwKTPJhbLFiLwxI*>+bDP+X< zX!PfC^>ch=U9_5uF8>atzCs+*v`BtH6lq#S;7@QcqAL!M9?$%-xxnum$*}Pd0lJnP zR0WR(@aLDtFrOSA@&1>je(gi3TZ*@Ituh}fX6srdzCdiy;c&zXbB<3*>Fn{TBSVH5TrMQ&>BoDaoM89rH=wTg3>8mTLNYg2rH=%V5*dsTnqN8 zr7m%K)8UO`BUP^7#Ji~u1XEU;>!_M0=2*92G|MB)KL4Tf+H%vBO7Aog#JA9%1%)?yijtTJo&g6Idy;cN{tOg>;%E0o7@HuS z;^$Uinv+0r^eiyhB(#BW0?d~n-;xI}-D%lyXU%k~rdLFKtu4mGBf?X#oeH5oNPhwR zEHK$1gv`P4C4O|$D)}5h!e@ktLDDraSB0mu78l{N1R*>~2IQ}RsZPQfxakO{z3A+$ zRSEf!T9EqwZKO>g0QG%7nAJkSOVBZ}M=729{wA1WkPO*>bk>ZJ-AiEpfMgfd0#gHo zF7kKLqI;H&y5Y~!${2Mt9`&~%bO)+4nRS7%7)%~0wE!*A>>Z?hrY*+jX0yS4C{tWp zW@BYv0>#$=pBBPJi}Se;wge;_AZ#hdzc`Qdh{j-3L9zh`faym9HNZkJxgyjR4KNT6 zWdrO*+HL|+1N;i6Nc3<;12`{3*MMXLyaJ{=NH)M4SF-`yBPD|%G)5| zhCG>r43eK>XF%c#kSyj2FkguX8;W@c>@7;C2PZzu5zm8UF<+O$@Z5n7hae^;2)8 zWf6dixd6;Ou>oF!c7WYZ>C{h`zp8LV<1%0lOyCf%g zu{&G!d5Ms&ApJ4{$%VcWxqzgLI506Jkc)O;+KA8Gv}(Rjkh^822Z}&{lW!~(qs0R^ zEz!Cf>`D>it|ePffc;9m>5kMpU~h?qU;}(sp&3DzuqSZqjgJ&awZ$cOEzaH(Y_8B% zn!U}e>FM%$nBg>tGaCJUYvje6&o$L0;1`dH5R0| zgmML#Wg!2k?3YOQhmXThus^luP`1(C1IW|r)- zNL+@Ec`8(sNgYIwgOpZN42}x&a&Dw~w4H}+9{{x$_@I$-^r^(dn)(*@P^H z2L;trsph~vA>3wYdIR$&NdFMR3NXv05!Kbw9_DtCK9a0jXkM?(hd>oP0#E^2Q3d}1 z^SiVfrL16N%_pOD&F>%?y#tN=I)u$2o$6ErOcJOv6;I{_8>d3DDRNs(CRDo4>yUpZ zvZ3Nl1v44M;@{l<(#VA&oN&JC=Q9q8`apcF1ty#<6M^gR&jf~f<-%$bO;a96$* z6JWZ+;_&|au$cqUo51$~1#LiC6p*{O?`vR{i8J1tWn{Alu-U-R1Vz(SQ8t=lEM_jw z_k8N$S%RE3n}Oa)7BtcoP0+bLvaqo{Asdyo2BO7qUTC2Am|x1Pe{xB1E%A# zx2lw%SOB#>>LYw(0n)2L*#b;6Q2ae~pF;8^>L>gl+85qOLOYb;P7t<$*+jxqz`q4k z2nrck&Q>E^H~b))o{H%6pm`3+W3sVBNcp%Hw#1Jijfd0|Om`5=sB9K;^E624+3jd( zmBuT#7ppg-{E5?3i*6v@!>#y?YwB=(B)m z3TR`H|N3%p{lDPf#_06KauC4>5d1u^oOQp=^`i0QO@Az(C}h66Gb zRGFreg6V|>yXSM8x`sBM#XvX+MN>$jEZ#VcVBt@95p!qxpEy=G$I$B_V-ojWFkUTv-$T0H54^;@z;t8S`d3gE)i2WdWczO)x zFOWPVF#2O8bny(>&>_K%LP+YXSGVE_0IEz28Z-AzOD@5#$NjMgD4YOTHz2xzSUh#9 zf@uX379h_NcBrQk#5k|1QgVYyB!zL|WYxS8WlyKKb+A}VR`T?wjPwU$)IQC((inox z1neXr$0dw*D+RMY$PlMK)Iz%5h3Yn`TP&z5mTjF$aACV8JJ^WLgyFtd8NNM%R zYG_HEiFOKjp;JdQVA4SH&@m0n6lp|fqQp$;k?9#^g!4l&8PSpGBVg8nWRXvUISFDR zbR;s3?97@?RyY&AO~abbL?r;-B`Z1;`R_mvg5;S<<>a)TY>M16$b?Gw8W43svUG2O z=>;;5M9Rjch-}IqiRJ*~H;aJAnMfgdqWI<`G|eWcJ|VR{{fx{cATGuH*WsrS*s~yc z_<0280SR>Y3EPQUgHVlISeBbBSKcvlLhq!g-E9uGC}2`Sx(2~M09-%NkcN9%29ht@?v&C= zF@`7jQrq48fGz;RfVMk@bCKSB?Q)0P1^o_*VgBEitF}#{l~?x_uj)kr`~dLxh5-wq zlW1GBGk7W*)){ZseYX+~M90q;fc*`UTcm<%BMF8r(%yn_v`1FmjYb5?JyPNHe8S!H znMRL9Xx(iKL~BCPf~ruKLPA{+XiF&CBF6(U7G#_^70gL7sy0}v#fX)fHF!0!D+zC$ zKs%_B)ge>7w^H-Be+Au_Ai1~R26Gc6_f`eP|6f88%)Qlr4^{|}+*><<$s~dH)`?)o zgXG?-Y&Ei_y|oUt1?{bC0a;Bpw734UrzU=ML=x?-mc4lP31S&u+Y_2jpbDfbMxoUSbPAA@Ky=A5uomT%R}!@a#=uiM z9)QR}unxGjAUOyWj*lc91_3?3kz?QtAg4fb3@DhkonZHTK3D}5je!S1+$R)`0fo{_ z2z5PR6rpGggzm$t5G;0W(&DU5!8aDyHfh!EL%|LP$*x=oCKn{Ta+6tno)ia9W>+47 zb|1l=vN6xWJSKsXyHNaflmj$*?$ieZ2Z0mXO40;o`&Q2OpLeEA`ixI^dx#)3i8V=FM}ppYxrJ`_|dM5!%{Bhc;|MqyraZ0!vjSwavI*6aP-<%Bv=5On zwek@_3P5psJ1Rf6-G8-mJ27;d7NnhTE9P#~s)?^Z)m+io-+zk6egdnzAfvHY#nO0UtOBzF6!+Y;_>UeaD%S(G z)i_s0Q8xa}xbPd|dOI~+$0Kl90FpVBfVm4Ydc-uKzFer}xJ`-L4 z?vV_$N7@-Z^5ae|;WcJX%>csyv6=rz@b&>*wuGlN(EHrg1U*G6O{4KRUg5vmG})z9 z!@r*!vP+AqTG-lfz!hWqV|*Fce@B09gr^N+$1bflFAz6&X)!ScW+8cg6}0yJW;#V8 z-vIVCNUsIqA(+1oi@LkDSMhIsM(oyt10s*$VK~U24k@|HL$1i*tpx<+KrtN@OVPVh zYPsUnIM#Ao;XQDJ{7oaStZ@J5bC48K;j$DpSQ+ z%&Ow_A%nzifNmkUarmG=UnMWa_?ohFiKm`09mh{#FM#9@#=gW)v?0hH%&@?C}oNT4n30GK_XA@o2@Wv7uXZDDfz@;QbF;vl(wwFA?J1lqkOf*B1u z&9|5(HV+~qeXm?6=kL{m?cV}%icG>k!IR6c5R-%SI0)~6nFWeogWir*jieZ}&WulK zwF_W<2S7)GJ`6JAd4<#qDx<`qPz6_|Bse z9_L7-wVK|V+Z^vPfn zLB>}fnF^XIo&jp_0?iwwm0xlwt)5TyM?mkf1zsp*wgWR6BtzzXVD?BO3h4WqF7-k( zLO|b`j3}W01(=`7h`!^noJN;`jDX%W8p5os3ak*&|3X$2(8mH)4I~5lc3|3oWI(TS za!MkbBDamIbYp=SO(ygm$8s=BLCl|?kSH6MzDo{hp=}O9@dYW3AYN&?Vn{<5)x(!& z8V&s4VDKv$$;lTgX+_%S9Rb2b;$C;g+hmeo}$;mlMcnF9Oh)_}F5d;(hLJ|^gs6k1K7Of&! ze1j0R)fP&jic@b}Bdxz;TNJR?_^jAk_1^jb+lmjog<@@O^$OZnDS~&+%=*sW=OifF z-p~EzkIY(YzH7~zHM3{Wo-=#4x6msUj^ATy$;fgVi@rv?N4&DNr$=7UZOrF9ZP4r6d0OAj_!HiW9;bYjK*jF5 z)5>df!CSl&$iC51R%^@TX;k<<9#y0e4tZs?nOAQ4jaQnv*E_-0cwMN`xaG8RRfnI- z-Go?hpSDHiq>?{Ca#Jtuff7CFp{j~|$jcI-xo=By zj`%k+{&45q-+I{|1(nB9Uv%m^+xK`qyn^!=e*VHs=btOrzUKAseC7|{JE_#up8MdM zm@f(fe|_h#-tjiXmQypiK~bIX#sxPDF;~Rb#ynBr|98wy`Pmd8ppFD({$JSSI+*;+6-xCw!uARL-A-YPh^zR_7INeJ-f;t7^>dH*zjs&m;`dqe($)62gM1h}8t4wWoi}O?;DE7Z2@BfFF8FI@tZmhun$#Pd4cK!Q2H`Ytk z_`^>ill=~gmENP+qll*pV!*TEh+NT0a-=|S(i zWjB!lb%j04JyXZ5+&>^MIOO%8e9JX0V^jp(z=?ZnCaTevhTpfTxOhpdkksB-mK*Cm zCe}4dr`ZH(kKBI9>o;OI$N8OQ9Ou5Gu!Y=~HLdlyl04M%^O&nHpWf7iZ&+%soBjS0=Brif`uqLcm{+4$)^994kE9!7 zONf5y>N-u2(R6hv@7&bWe;^>Y&+p^UAiwVK<3AzXH8(8JP;bq|CcZ0A&x+AEd2rWzf_qy3{-;QNS7%C~91SA7EDxi$z* zAffL$m$iWYJi~-TyZ#0g&S&=Gsd9U>sHhC>0Z1)sK`N+~N8(=6kHN2c-4Zzh)d{GH zgW=6wIvjSLkM>>e>@BL}(E7Z#tolkNM5tv>#OCV@AWtpn`cP_Cy|U8gH_PAA^^)`= z`6M{{Q#o5nodLxdcO!!Nx}cMUzOsS(B%!EGihS##z*wi~q!upXFyG24H7Us3Srk*< zp#$885D0Qx4iMbV5D4;3JKQ8M;#?H=zhADoF68n7qHuYBt$pXx!Vb8Cng-@F=u&eH z&aXSb`L)+zTYs*!T=!d1ecJLaA()M#pS7`@4e~iFYDO7v%5&0m&B4yijPRZKhaJG| zyrn`^_M@k5&J0196^5Xxa{Llek#yaafGM?v<#c`~>8?ihRN3zokxn=$=4HZXQeMbw zjVihe99flYgw!Zk(a)u&Auj5EPIav;OcgiP=@xcbs>8ypE(y&|GW_qln^1(RY^miU zO7gKKq9ma{gQ5QJH?{U?7wQ))#Gp8e`Li6971h~oe4~0Pyk&!Yd5T_4>G#lhAEHW1^xWZ}1hU?4* zd7>3HgB)Q+vq6rUHVB%{qd2=hgn^tpO-)M%k-vr3-#ON~CXm0iqFEr}H{FX0LBngl z7lA#_mOBe1Jf|B3$YbHUia=8bI5kG4!0B_X)2$#8LsdjW2RL{@ zhk1fT>8{fX5~ULgBssG7Xqw#=Ei06Jt3}X_H#UUoyC>?;b!L6CxS;$a4hwq|HYj>s zqyvWD%!W6J#;53Ns9A1LE7G-{o!iy=pQyeWqyApB0ciyZS9~>ygDIRQ*UuCcs*5&X z!aD6%x9KZPt`0>Y@3Epr81rpcYy?>-_l*>3Wq#6CtN`<#GrR-#Lt`y4cEH+iImjeA zyXz~WLXMvx1pR2B|1b`qUs6v7iC9plK=^TmkO(9?W#nQxl1@P@ee}l{i=N-B`)I;; z(r&s%=+7q}ZggSPyL0;hNvS`DU4VFb^If7`uDD*r5FirPa{RjS=>i+&*#o)t!hn4A z5cn}Z*#OZnUu6SSupG{yl_CumIx`E-pq2jl2Gj0_gIg?vVe5Pwf_jh(<(i|#kdJZ| z%H-GouB&qEh#=MEBAe+toHbztvSU|p(mL)V zci6tt01`u2fpbY=@FgePVby79-9S(47~@vg$(lQeM~Um|^wWEicB`}1b#n1BG{>}T zo!nfKtKj}Hmw)9>H9v|$W3@7n$q@`2N{`ewzfO`y4o^X#DHkg76i4Mj_UIS3zD*#X zlen~f#HEXQUr{A99m}o)2 zcn(`dL7l{d@Dy21PZK$U{l|+T3+HkE)tu5T0pw@&0*9UhfgH;sGwlU8H3Wie$N_?T zT)N}*%{z55%I&b_Hh~;t&7BPrC7D?jxcU$X5+xZRxW}i<#~Q<#U+n*=)`_-ut}Uuc zvr~|d*+8^_e1b)Rv(&ki1_JQvn|bQ5faG5)46+>vNW*kBpDACSqJ=k4Ltttjs|aV- zO@%iVf<2BS7%1`Vn+n0By$h6lc*jkJ5TK-ln)8ud<%Ln!MLL1}&2UkX?OIpc!jDZ; z?NL!h8(i2gL?I_2x-wK3fJm+QMEx2b{B0^mYy zGrMpv7ZM6IB%KHa^7auT6VFp{!+aC3gqwq?Ojs6Wy7$^L)$BUugaVWqB6OJ{OA47d zuI9_t>^zgOEY-3X)zZD3?O#4kwtrSPJR}%wBI8cGaf`x>Op@qz>IhHmRgsABx}3yg zTn;s;4sTSTMu3zbi$Js_)&&z3 zuIghOsUtuQrqtaPGH7>eN>~`Fs=CRoqk>q~k?0(e>8LgRxVct1f3^*ct zsZYN3IW>_soL5Wp=@n0iSSBAw?H~HEonTen7^8=c5X86U!qX3N zS3;e9XYCYQ=3MSyS_o#o?Q{(wAD69TXzB^KRCK4&>^Q;5!B%7T6-;iF* z`IvMH*0Rc4xq2*3Pon~ja3hGt4-uOO^~&R26-Sa?{q zaP^6Md9C*YPHE@|*^_6pW_}5-mwq77kNhL)H_uO}PSJ(tUh|un}49H^pv> zflXU+s}ff;dt9y<>?rxmiF6kOs=8KASSto3tr`jX-JB<&IuRnt29r>U2#iWZpu#|b zPc7U#&e4CBwvNppYgl9g4{l-z1bJN!5Zo;x5aere@nkV#3J?;#N6Yb;WMo717LFqxeyiYigk zd7Q7-_h9s)@p=ZS#>3@xoZrkTk10^Q*oqs}nDSj_@3dk)0zJg+leuDZ!H54n=O_l? z%1_84H;Zf{6zgF#6^j6sM12Be2CJUKX~OY~zG-ZCtY_IhvnQC?Y#@;vqhCvN2)`Lyks%^+W7k!ru@4sd(q-f5zG1oXC9y(W-AD!ryq zZ=70b%vRESD7;jKj9m^> z|7lG%fc(=Wn3@d|%F0wj2e_uwEfC}!78xM8))2^~=d{U(&lHobAMaZ~8bNNcezbx_ z$;y1A^<${5dn?G}B6V-<05>iKGFj$)KL-h}O@3>J7?DAg;F9aKfNYb0oFPVagP0Q{ zM$Z(ZhQarTZFTBF?y;g)xb}T{`%IDPy^+K5S5E2K=fkhc?K4H+DrDWySuuw`p3wpB zuW~Cr-Smw)I}c}}gyx+#Q=^kXM6kDBRP+r6uje~Z5<$N%Ya3`DTVT~+m!zKU4fEY7 zN3o=wNrYJW*gUFv$eYe(YhIEn49l4)i`zs++=5lP6@B9oK)!Y|l4;zgmxT}`t)7Yq zCaN`#iZ}poYXD8?Lji?3lXx2jCdvt)6P4C^_!T-&Q)D#UM(H*Qvz^B_=96rQ8gujV z4sbiQqk3{~k!a}LX5VQVG8W_(k`%dus`!2`s93ITR;x!&j-Vppfj?v{`WB!C1USSN zG@nWM+=q)M$#L`P83(*6fHnlg`a_grXy7b!f&p#^cv5}rDS9LWj(D|_m20Z9AF`p= z#f;q6Ol<-fS)nZ|c~sLd3)81(~7(kk7>(Y}^TSu3+GqF-VU z+oV^do@-GHF7$h32Er0M`ke!^RJON>syGmP$bpHa`E?+u}?q5Ls+9H}j4n55%)BOwNNEVs<7r1sgra4@9Ag4#_-q-=|>=4Lgne&SrB)E3@?p!fqa98hI;9Wb{i58ny$lK2r zr81Z)%4{P7Ml)fM?Q-4OV$^WdWv8uPJxITcf8?Itvr_srw^J!=(a2aR`!$GCn$pIq zkozK|%-{yDRBky(r2E924-RL9ZfQ18finrqPLTWRNjb29Am4*jG*3=wpewH+f>!#O zQrOGa?qf>|CMeyCxJAmX^F+3L#eMTcp9rw1E#fiR(H_SmKA65`W0s2M8IK(Yo|PK? zWJIFlN81|#>B*3YL_ z1kL~!43}f)(>fejQ-;2&L3A7=aW?`#e1f^D0Y|*Psew19bSU~m2HkFKsV(f*jp4HX zT)Ndljce}2YVvBHFYxmODNhXNVPN<~zPCjLd~eH_(21L@R6fz%+rGo)cAAbx-;-j& z_6fMRMI?N0i%87o0SKPaF;9Gt2a_$Q$;uX5_QK%O|Fp=x4Z;z2loIr`?ddV#pv8+YS4a}Cl>4J5vyt_Jhw4shQKfgtZ2 zr{8#y=`V_2Bb!z+01D>z2Cl=ZH-RK|wVp`R0f4?YPCqm!BD{W(jqv;+8BgR zG}d|#vWN>Z#e*xi#W#Z-oC6#zr(YyipDiq|0VGT)gAEK|B5!18Zb!UN}C!heq&IArngx3Lz@D!kdotrKeEpGX<%`TnC#v!_n zQyOfa?W|rbo``wRHmfJE5_#ZKao*%bJQ-YXpJ|&xt~dixo(1x2EHZrr+$#Bl%fy7` zF!leesV0!^*3@i}P&N$)?sDF4O>-EKOIc)q;BE+kOv2k#)QJO&ctEOmP&b>m^4+7|J2GfGiuC*p69T#!=OK9i#RkY5&m)^2E zK3{=?{?=L47$MkbYq{*VSoHk_Wem#V^Ud&we#?dBFHMo_7t@dm4}Ku)uM$W1{-v#E zv|!cx^r&Pr6?OpaJIWCpJ8UC28onk<-y5vtTBBGJp+T;f?N^KA)r#JPe8uQOS-yp6 zUTCWNYB4zjGx)-9eqkd%7ID0KVhBDSMvuz(ab^E-hQ6oM)WJ&R`lb5OGDna}z%ACG z`3NL$o?#XdMO5;gOX$g}ASy9?3Iw#s4o11`zAm9ZI}DtjNepnQUjas+a@K$Pt&FM6 z%$*|L3X!eu4t7mphlR;MU!z82_wTqyjb7aH3P4{T`$w3s-Zn`(uyB@EsGt$eN|Z`< z7A`~VI%m(d9Z3Id-JdFP42w>QRw9Cub$FPC%$UX$vuK-soJR|6maJ%y`bc>{3V z6K#3=tr^dmD<8Us-XDRbFDhVVBF?b*6rM>$1U!?-lk^q#!@Hp7}+~>e-y##wjnAgS}KvzLsVd_;Bq) z>dLeh9p&|1Ba+V@u1DvAYw6CBzLmau;A}kAbS9)USlxQA@s;*=_bopxNN&DfJmWF8 z^P685^fe>H^_9Q)ikOBhJyy!WH;9L=r0Pb|OD1j!L#XnVh#Q=J;LAKFmvZROzXxB?RQD6nP{6u8@0y;&n zZL{dFH)12}IrfE0sP6!?L+;xwGA@0IV2c=-iYEZ3lJx$b#8G*YWJIFMN~O9WA`(Jm z4?bDJdJGD#p`)Qf1`Pn1de$9 zC<$Jh${tOP1qn2}v7{a(6Tp!ry+#V2tL?;a_`ETl$mKJ%Mw$aq&nCmz`I8&*$QO~Q zM?SjUS&1BeKRsz#mb%f=>vVH#HR{ZPXy96>pH2nDm0 zZ7Cq=RdNT}ngd&v7ILWr`a&yP>VSqx+F|8@hDne1L4#f;FM5Q2{=#wG!)$FDtd<^L z1~@b%=c8yLht_;T;NBkRO6T@lMZMt=+xk5qhlXNW=fS+Li zF_9}si4b8rQeqazZ(f7`mCo{Q4RS4+9O%$)RXwkAS~% zOvs?yjV*l}0*-9y+Yoqdt16E3rxAx(D4;mxO_8ZS-i8!w%?U4_n3&$Fw@I?F(}IVo{#J@ym2RGOc4)!~rRmXFV;BPFQw^ ztfh0csFy*KQh?)IsyPVP*2`ie`cQ28%e1%$4KNMCy-BX6v~>G6XhhRs%9>i{i+@ z4V)4XWL&X6isDyd5mqAwPUh939VL2T~w88;2EBAa@~Rj2HD4onnCtGlTWemaP;uD>1GVu%0YczKD3>t z=pnm%yXb!gPWipVwn8(=jVz+~9~N|g!Kt{W4Z&@ZWGt-?NSKyyP#?0=jmbq_OyZc9 z(CFS5MMe+0I#~Z|%SqpZ$(yArihgL#5md%+<`CR0x4lFI7!DKOST7%;8IAgNcLZdp z;t|wWuKq2Z9YUK&`a$_lE+?R=tJ*vQexqExL*Ly2+$fj-hBo4X{iKEJU>;$qw1kOb zsJ`mB13H~PJW%-)7Crd%YOdoFPU+qS@+vEu1@dYZnSKUtWj&U^f)n%YdCn3C27y

    9w-$C3^1gYAw$lJqM79<5=X$x_9( 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

    1*6 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

    4k%f&1l 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 diff --git a/vendor/cuobj/lib/libcuobjserver.so.1.2.0 b/vendor/cuobj/lib/libcuobjserver.so.1.2.0 new file mode 100755 index 0000000000000000000000000000000000000000..a9f7990932ff6f51d024ac5c2f2710063bcf7f81 GIT binary patch literal 738304 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

    ^Mo&HztwvkJ4uH!@i3)uZ#@(Ubqo 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

    }9^ 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

    =9d-%ZFW5uae$k%A_Dl9gwqLe) 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 F`+q1QbKd{} literal 0 HcmV?d00001 From ef84f2aaa372204e26617d9f8ae3c370d4773462 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Wed, 22 Apr 2026 12:04:01 -0700 Subject: [PATCH 12/25] feat: NIC-failover aware retry + HTTP fallback on RDMA path MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Add rdmaPutWithRetry / rdmaGetWithRetry helpers in include/miniocpp/rdma.h that wrap cuMemObjGetRDMAToken + rdmaPut/rdmaGet with a 2-attempt loop. The first failure surfaces the bad NIC to libcuobjclient's async-event / health-check threads; the second cuMemObjGetRDMAToken call then mints on the backup NIC via the library's multipath state, turning a mid-flight NIC failure into a successful RDMA op instead of a hard fail. Every retry iteration releases the old token via cuMemObjPutRDMAToken and mints a fresh one, so the same stale token is never re-sent to the server. This avoids the callback-API pitfall where the library re-fires the application callback with the same cufileRDMAInfo_t* pointer (we don't use that API — ops are always CUObjIOOps{}, driving the direct-token path). Wire the helpers into BaseClient::PutObject, BaseClient::UploadPart, Client::GetObject(GetObjectRDMAArgs) and Client::PutObject(PutObjectRDMAArgs). On exhausted retries or a 501 reply from the server, all four sites fall through to the regular HTTP path instead of returning an error — matching the existing Client::* wrapper behavior. BaseClient::PutObject and UploadPart used to return an error immediately on any RDMA failure; that is now a fallback. vendor/cuobj/cuobj.json: flip rdma_multipath_enabled to true. Safe on single-NIC hosts because libcufile validates prerequisites at init time and falls back to single-path with a log line when rdma_dev_addr_list has only one entry or backups fail to register. --- include/miniocpp/rdma.h | 62 +++++++++++++++++++++++++++++ src/baseclient.cc | 77 +++++++++++++++--------------------- src/client.cc | 88 +++++++++++++++++------------------------ vendor/cuobj/cuobj.json | 8 +++- 4 files changed, 135 insertions(+), 100 deletions(-) diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h index 201a9f63..62d527ce 100644 --- a/include/miniocpp/rdma.h +++ b/include/miniocpp/rdma.h @@ -46,6 +46,12 @@ inline constexpr int kRDMAReplyNotImplemented = 501; // Return codes for rdmaPut/rdmaGet inline constexpr ssize_t kRDMANotSupported = -2; +// Maximum attempts for NIC-failover aware retry. Two attempts is sufficient: +// the first failure is what surfaces the bad NIC to libcuobjclient's +// async-event + health-check threads; the second mint will route to the +// backup NIC when rdma_multipath_enabled=true and a healthy backup exists. +inline constexpr int kRDMAMaxAttempts = 2; + inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, const void* buf, size_t size) { char rdma_token[256]; @@ -222,4 +228,60 @@ inline static ssize_t rdmaGet(s3_rdma_client_ctx_t* sctx, const char* token, return static_cast(size); } +// rdmaPutWithRetry mints a fresh RDMA token, issues rdmaPut, releases the +// token, and retries once on transient RDMA failure. On the second attempt +// libcuobjclient's multipath state will route the mint to the backup NIC +// if the primary has been flagged unhealthy; this turns what would have +// been a fail-and-fall-back-to-HTTP into a successful RDMA op across the +// NIC transition. +// +// Caller must have already registered the buffer via cuMemObjGetDescriptor. +// +// Returns: +// >0 bytes transferred (success) +// kRDMANotSupported server sent x-amz-rdma-reply: 501 (fall back to HTTP) +// -1 exhausted retries (fall back to HTTP) +inline static ssize_t rdmaPutWithRetry(cuObjClient* rdmaclient, + s3_rdma_client_ctx_t* sctx, void* buf, + size_t size) { + ssize_t ret = -1; + for (int attempt = 0; attempt < kRDMAMaxAttempts; ++attempt) { + char* token = nullptr; + cuObjErr_t terr = + rdmaclient->cuMemObjGetRDMAToken(buf, size, 0, CUOBJ_PUT, &token); + if (terr != CU_OBJ_SUCCESS || token == nullptr) { + return -1; + } + ret = rdmaPut(sctx, token, buf, size); + rdmaclient->cuMemObjPutRDMAToken(token); + if (ret > 0 || ret == kRDMANotSupported) { + return ret; + } + } + return ret; +} + +// rdmaGetWithRetry is the GET counterpart to rdmaPutWithRetry. Same +// contract: caller registers the buffer, this helper handles token +// lifecycle and one retry for NIC failover. +inline static ssize_t rdmaGetWithRetry(cuObjClient* rdmaclient, + s3_rdma_client_ctx_t* sctx, void* buf, + size_t size) { + ssize_t ret = -1; + for (int attempt = 0; attempt < kRDMAMaxAttempts; ++attempt) { + char* token = nullptr; + cuObjErr_t terr = + rdmaclient->cuMemObjGetRDMAToken(buf, size, 0, CUOBJ_GET, &token); + if (terr != CU_OBJ_SUCCESS || token == nullptr) { + return -1; + } + ret = rdmaGet(sctx, token, buf, size); + rdmaclient->cuMemObjPutRDMAToken(token); + if (ret > 0 || ret == kRDMANotSupported) { + return ret; + } + } + return ret; +} + #endif // _MINIO_CPP_RDMA_H_INCLUDED diff --git a/src/baseclient.cc b/src/baseclient.cc index 7ff78725..5d656c6e 100644 --- a/src/baseclient.cc +++ b/src/baseclient.cc @@ -1372,32 +1372,25 @@ PutObjectResponse BaseClient::PutObject(PutObjectApiArgs args) { } if (args.rdmaclient != nullptr && args.rdmaclient->isConnected()) { - char* token = nullptr; - cuObjErr_t terr = args.rdmaclient->cuMemObjGetRDMAToken( - args.buf, args.size, 0, CUOBJ_PUT, &token); - if (terr == CU_OBJ_SUCCESS && token != nullptr) { - s3_rdma_client_ctx putCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .url = base_url_, - .region = region, - .op = CUOBJ_PUT, - }; - - ssize_t ret = rdmaPut(&putCtx, token, args.buf, args.size); - args.rdmaclient->cuMemObjPutRDMAToken(token); - - if (ret < 0) { - return error::make("failed to upload the object " + - args.object); - } - + s3_rdma_client_ctx putCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .url = base_url_, + .region = region, + .op = CUOBJ_PUT, + }; + + ssize_t ret = rdmaPutWithRetry(args.rdmaclient, &putCtx, args.buf, + args.size); + if (ret > 0) { PutObjectResponse resp; resp.etag = putCtx.etag; resp.checksum_crc64nvme = putCtx.checksum; return resp; } + // ret < 0 (retries exhausted) or kRDMANotSupported (server declined): + // fall through to HTTP path. } Request req(http::Method::kPut, region, base_url_, args.extra_headers, @@ -1959,36 +1952,28 @@ UploadPartResponse BaseClient::UploadPart(UploadPartArgs args) { return UploadPartResponse(resp); } - char* token = nullptr; - cuObjErr_t terr = args.rdmaclient->cuMemObjGetRDMAToken( - args.buf, args.part_size, 0, CUOBJ_PUT, &token); - if (terr == CU_OBJ_SUCCESS && token != nullptr) { - s3_rdma_client_ctx putCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .uploadId = args.upload_id, - .partNumber = args.part_number, - .url = base_url_, - .region = region, - .op = CUOBJ_PUT, - .checksum = args.checksum_crc64nvme, - }; - - ssize_t ret = rdmaPut(&putCtx, token, args.buf, args.part_size); - args.rdmaclient->cuMemObjPutRDMAToken(token); - - if (ret < 0) { - return UploadPartResponse( - error::Error("failed to upload to object with uploadId " + - args.object + " uploadId=" + args.upload_id)); - } - + s3_rdma_client_ctx putCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .uploadId = args.upload_id, + .partNumber = args.part_number, + .url = base_url_, + .region = region, + .op = CUOBJ_PUT, + .checksum = args.checksum_crc64nvme, + }; + + ssize_t ret = rdmaPutWithRetry(args.rdmaclient, &putCtx, args.buf, + args.part_size); + if (ret > 0) { UploadPartResponse resp; resp.etag = putCtx.etag; resp.checksum_crc64nvme = putCtx.checksum; return resp; } + // ret < 0 (retries exhausted) or kRDMANotSupported (server declined): + // fall through to HTTP upload part path. } utils::Multimap query_params; diff --git a/src/client.cc b/src/client.cc index 63261df4..fa552000 100644 --- a/src/client.cc +++ b/src/client.cc @@ -403,33 +403,25 @@ GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { } if (use_rdma) { - char* token = nullptr; - cuObjErr_t err = - rdmaclient.cuMemObjGetRDMAToken(args.buf, size, 0, CUOBJ_GET, &token); - if (err != CU_OBJ_SUCCESS || token == nullptr) { - rdmaclient.cuMemObjPutDescriptor(args.buf); - - } else { - s3_rdma_client_ctx getCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .url = base_url_, - .region = region, - .op = CUOBJ_GET, - }; - - ssize_t ret = rdmaGet(&getCtx, token, args.buf, size); - rdmaclient.cuMemObjPutRDMAToken(token); - rdmaclient.cuMemObjPutDescriptor(args.buf); - - if (ret > 0) { - GetObjectResponse resp; - resp.etag = getCtx.etag; - return resp; - } - + s3_rdma_client_ctx getCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .url = base_url_, + .region = region, + .op = CUOBJ_GET, + }; + + ssize_t ret = rdmaGetWithRetry(&rdmaclient, &getCtx, args.buf, size); + rdmaclient.cuMemObjPutDescriptor(args.buf); + + if (ret > 0) { + GetObjectResponse resp; + resp.etag = getCtx.etag; + return resp; } + // ret < 0 (retries exhausted) or kRDMANotSupported (server declined): + // fall through to HTTP path. } GetObjectArgs targs; @@ -474,33 +466,25 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { } if (use_rdma) { - char* token = nullptr; - cuObjErr_t err = - rdmaclient.cuMemObjGetRDMAToken(args.buf, size, 0, CUOBJ_PUT, &token); - if (err != CU_OBJ_SUCCESS || token == nullptr) { - rdmaclient.cuMemObjPutDescriptor(args.buf); - - } else { - s3_rdma_client_ctx putCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .url = base_url_, - .region = region, - .op = CUOBJ_PUT, - }; - - ssize_t ret = rdmaPut(&putCtx, token, args.buf, size); - rdmaclient.cuMemObjPutRDMAToken(token); - rdmaclient.cuMemObjPutDescriptor(args.buf); - - if (ret > 0) { - PutObjectResponse resp; - resp.etag = putCtx.etag; - return resp; - } - + s3_rdma_client_ctx putCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .url = base_url_, + .region = region, + .op = CUOBJ_PUT, + }; + + ssize_t ret = rdmaPutWithRetry(&rdmaclient, &putCtx, args.buf, size); + rdmaclient.cuMemObjPutDescriptor(args.buf); + + if (ret > 0) { + PutObjectResponse resp; + resp.etag = putCtx.etag; + return resp; } + // ret < 0 (retries exhausted) or kRDMANotSupported (server declined): + // fall through to HTTP path. } // HTTP fallback path diff --git a/vendor/cuobj/cuobj.json b/vendor/cuobj/cuobj.json index c68d5362..b6320fef 100644 --- a/vendor/cuobj/cuobj.json +++ b/vendor/cuobj/cuobj.json @@ -35,8 +35,12 @@ //"rdma_access_mask": "0x1f", // RDMA Multipath Configuration - // Enable multipath for RDMA failover across multiple NICs - "rdma_multipath_enabled": false, + // Enable multipath for RDMA failover across multiple NICs. + // Safe to leave always on: if rdma_dev_addr_list has only + // one entry (or backups fail to register), libcufile logs + // "prerequisites not met" and falls back to single-path + // automatically ("RDMA {read,write} using default path"). + "rdma_multipath_enabled": true, // Maximum number of backup RDMA devices (0-8) "rdma_max_backup_devices": 2, // Number of IO retries on retryable errors before giving up (0-10) From 45e1bd88aa712eee3c64ee0e8149ec4edc88150e Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 23 Apr 2026 00:19:43 -0700 Subject: [PATCH 13/25] feat: Drop CUDA Toolkit build-time dependency MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Vendor cuda.h (CUDA driver header) from cuObject v3 1.2.0 into vendor/cuobj/include/ and point MINIO_CPP_INCLUDES at it, replacing the /usr/local/cuda/include path. The SDK's use of cuda.h is type-only (CUdeviceptr etc. appearing in cuFile / cuObj API signatures), so no CUDA runtime symbols are called from within minio-cpp itself. Drop -L/usr/local/cuda/lib64 and -lcudart from MINIO_CPP_LIBS; libcufile is already vendored under vendor/cuobj/lib/ and cudart is not needed by the SDK. Rewrite examples/GetPutRDMA.cc and examples/GPUHostDisk.cc to load libcuda.so (the CUDA driver library shipped with every NVIDIA driver) via dlopen/dlsym instead of linking against libcudart. Add prominent comments in both examples clarifying that this dlopen shim is a convenience for the examples only — production applications wanting GPU Direct Storage should link against real CUDA APIs via the CUDA Toolkit. Add a 'CUDA dependency model' header comment to include/miniocpp/rdma.h explaining that CUDA is strictly an application concern, not an SDK concern: pinned-host workloads don't need CUDA at all, and GPU workloads bring their own CUDA linkage. Net: the SDK and all examples now build cleanly on hosts without the CUDA Toolkit installed. Only the NVIDIA GPU driver (libcuda.so) is needed at runtime, and only when the 'gpu' mode is actually exercised. --- CMakeLists.txt | 10 +- examples/GPUHostDisk.cc | 119 +- examples/GetPutRDMA.cc | 155 +- include/miniocpp/rdma.h | 16 + vendor/cuobj/include/cuda.h | 25029 ++++++++++++++++++++++++++++++++++ 5 files changed, 25260 insertions(+), 69 deletions(-) create mode 100644 vendor/cuobj/include/cuda.h diff --git a/CMakeLists.txt b/CMakeLists.txt index 27d71ba6..8cefd5fe 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -50,8 +50,8 @@ if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC" OR "x${CMAKE_CXX_COMPILER_FRONTEN else() # GCC/Clang/AppleClang/... list(APPEND MINIO_CPP_CFLAGS -Wall -Wextra -Wconversion) - list(APPEND MINIO_CPP_INCLUDES /usr/local/cuda/include) - list(APPEND MINIO_CPP_LIBS "-Bdynamic -L${CMAKE_SOURCE_DIR}/vendor/cuobj/lib -L/usr/local/cuda/lib64 -lcufile -lpthread -lnuma -ldl -libverbs -lrdmacm -lrt -lcuobjclient") + list(APPEND MINIO_CPP_INCLUDES ${CMAKE_SOURCE_DIR}/vendor/cuobj/include) + list(APPEND MINIO_CPP_LIBS "-Bdynamic -L${CMAKE_SOURCE_DIR}/vendor/cuobj/lib -lcufile -lpthread -lnuma -ldl -libverbs -lrdmacm -lrt -lcuobjclient") if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0 AND CMAKE_CXX_COMPILER_VERSION VERSION_LESS 9.0 AND NOT MINGW) list(APPEND MINIO_CPP_LIBS stdc++fs) endif() @@ -140,7 +140,7 @@ target_compile_features(miniocpp PUBLIC cxx_std_${MINIO_CPP_STD}) target_include_directories(miniocpp PUBLIC $ $ - ${MINIO_CPP_INCLUDES} + $ ) target_link_libraries(miniocpp PUBLIC ${MINIO_CPP_LIBS}) set_target_properties(miniocpp PROPERTIES VERSION "${MINIO_CPP_VERSION_STRING}") @@ -216,10 +216,6 @@ if (MINIO_CPP_TEST) target_link_libraries(${target} PRIVATE miniocpp::miniocpp ${MINIO_CPP_LIBS}) endforeach() - # CUDA examples need cudart - target_link_libraries(GetPutRDMA PRIVATE cudart) - target_link_libraries(GPUHostDisk PRIVATE cudart) - add_executable(tests tests/tests.cc) target_compile_features(tests PUBLIC cxx_std_${MINIO_CPP_STD}) target_include_directories(tests PRIVATE ${CMAKE_CURRENT_LIST_DIR}/include) diff --git a/examples/GPUHostDisk.cc b/examples/GPUHostDisk.cc index d7cbfcc9..596dcf23 100644 --- a/examples/GPUHostDisk.cc +++ b/examples/GPUHostDisk.cc @@ -1,49 +1,124 @@ -#include +// MinIO C++ Library for Amazon S3 Compatible Cloud Storage +// Copyright 2022-2024 MinIO, Inc. +// +// SPDX-License-Identifier: Apache-2.0 + +#include #include -#include -#include -#include #include #include #include -#include -#include -#include +#include #include #include +// NOTE (for example/CI use only): +// The dlopen(libcuda.so) shim below is a convenience so this example can be +// built and run on machines that do NOT have the full CUDA Toolkit installed +// — only the NVIDIA GPU driver, which always ships libcuda.so. It avoids the +// build-time dependency on cuda_runtime.h / libcudart. +// +// Why this is an application-side shim, not an SDK feature: minio-cpp itself +// has no CUDA runtime dependency (see the "CUDA dependency model" note at +// the top of include/miniocpp/rdma.h). Allocating/managing GPU memory is +// purely an application responsibility. +// +// Production applications that want GPU Direct Storage should NOT copy this +// pattern. Link against the real CUDA APIs (cudart or the CUDA driver library) +// via the CUDA Toolkit, use `#include ` / `#include ` +// directly, and let the linker resolve cu*/cuda* symbols at build time. +// +// CUdeviceptr / CUdevice / CUcontext / CUresult come from , +// transitively via . +namespace { + +struct Cuda { + void *lib = nullptr; + CUresult (*cuInit)(unsigned); + CUresult (*cuDeviceGet)(CUdevice *, int); + CUresult (*cuCtxCreate)(CUcontext *, unsigned, CUdevice); + CUresult (*cuCtxDestroy)(CUcontext); + CUresult (*cuMemAlloc)(CUdeviceptr *, size_t); + CUresult (*cuMemFree)(CUdeviceptr); + CUresult (*cuMemsetD8)(CUdeviceptr, unsigned char, size_t); + CUresult (*cuMemcpyDtoH)(void *, CUdeviceptr, size_t); + CUresult (*cuCtxSynchronize)(); + + bool load() { + lib = dlopen("libcuda.so.1", RTLD_LAZY | RTLD_GLOBAL); + if (lib == nullptr) lib = dlopen("libcuda.so", RTLD_LAZY | RTLD_GLOBAL); + if (lib == nullptr) return false; +#define SYM(name, versioned) \ + do { \ + void *s = dlsym(lib, versioned); \ + if (s == nullptr) s = dlsym(lib, #name); \ + if (s == nullptr) return false; \ + name = reinterpret_cast(s); \ + } while (0) + SYM(cuInit, "cuInit"); + SYM(cuDeviceGet, "cuDeviceGet"); + SYM(cuCtxCreate, "cuCtxCreate_v2"); + SYM(cuCtxDestroy, "cuCtxDestroy_v2"); + SYM(cuMemAlloc, "cuMemAlloc_v2"); + SYM(cuMemFree, "cuMemFree_v2"); + SYM(cuMemsetD8, "cuMemsetD8_v2"); + SYM(cuMemcpyDtoH, "cuMemcpyDtoH_v2"); + SYM(cuCtxSynchronize, "cuCtxSynchronize"); +#undef SYM + return true; + } +}; + +} // namespace + int main(int argc, char *argv[]) { - char *bufptr; size_t bufsize = 10 * 1024 * 1024UL; - if (argc == 2) { - bufsize = std::atoi(argv[1]); + if (argc == 2) bufsize = std::atoi(argv[1]); + + Cuda cuda; + if (!cuda.load()) { + std::cerr << "libcuda.so not found — install NVIDIA driver" << std::endl; + return 1; + } + if (cuda.cuInit(0) != 0) { + std::cerr << "cuInit failed" << std::endl; + return 1; + } + CUdevice dev = 0; + if (cuda.cuDeviceGet(&dev, 0) != 0) { + std::cerr << "cuDeviceGet failed" << std::endl; + return 1; + } + CUcontext ctx = nullptr; + if (cuda.cuCtxCreate(&ctx, 0, dev) != 0) { + std::cerr << "cuCtxCreate failed" << std::endl; + return 1; } - cudaMalloc(&bufptr, bufsize); - cudaMemset(bufptr, 'A', bufsize); - cudaStreamSynchronize(0); + CUdeviceptr dptr = 0; + if (cuda.cuMemAlloc(&dptr, bufsize) != 0) { + std::cerr << "cuMemAlloc failed" << std::endl; + return 1; + } + cuda.cuMemsetD8(dptr, 'A', bufsize); + cuda.cuCtxSynchronize(); - char *hostptr; - hostptr = (char *)malloc(bufsize); - cudaMemcpy(hostptr, bufptr, bufsize, cudaMemcpyDeviceToHost); + char *hostptr = (char *)malloc(bufsize); + cuda.cuMemcpyDtoH(hostptr, dptr, bufsize); - // Open the file in binary mode for writing std::ofstream file("output.txt", std::ios::binary); if (file.is_open()) { - // Write the buffer to the file file.write(hostptr, bufsize); - - // Close the file file.close(); - std::cout << "Buffer written to file successfully." << std::endl; } else { std::cerr << "Error opening file." << std::endl; } free(hostptr); - cudaFree(bufptr); + cuda.cuMemFree(dptr); + cuda.cuCtxDestroy(ctx); return 0; } diff --git a/examples/GetPutRDMA.cc b/examples/GetPutRDMA.cc index 2e448a88..29246af0 100644 --- a/examples/GetPutRDMA.cc +++ b/examples/GetPutRDMA.cc @@ -15,7 +15,7 @@ // // SPDX-License-Identifier: Apache-2.0 -#include +#include #include #include #include @@ -27,50 +27,136 @@ #include #include +#include +#include #include #include +// NOTE (for example/CI use only): +// The dlopen(libcuda.so) shim below is a convenience so this example can be +// built and run on machines that do NOT have the full CUDA Toolkit installed +// — only the NVIDIA GPU driver, which always ships libcuda.so. It avoids the +// build-time dependency on cuda_runtime.h / libcudart. +// +// Why this is an application-side shim, not an SDK feature: minio-cpp itself +// has no CUDA runtime dependency (see the "CUDA dependency model" note at +// the top of include/miniocpp/rdma.h). Allocating/managing GPU memory is +// purely an application responsibility. +// +// Production applications that want GPU Direct Storage should NOT copy this +// pattern. Link against the real CUDA APIs (cudart or the CUDA driver library) +// via the CUDA Toolkit, use `#include ` / `#include ` +// directly, and let the linker resolve cu*/cuda* symbols at build time. That +// gives you proper error checking, symbol-version guarantees, and a supported +// toolchain path. +// +// CUdeviceptr / CUdevice / CUcontext / CUresult come from , +// transitively via . +namespace { + +struct Cuda { + void *lib = nullptr; + CUresult (*cuInit)(unsigned); + CUresult (*cuDeviceGet)(CUdevice *, int); + CUresult (*cuCtxCreate)(CUcontext *, unsigned, CUdevice); + CUresult (*cuCtxDestroy)(CUcontext); + CUresult (*cuMemAlloc)(CUdeviceptr *, size_t); + CUresult (*cuMemFree)(CUdeviceptr); + CUresult (*cuMemsetD8)(CUdeviceptr, unsigned char, size_t); + CUresult (*cuMemcpyDtoH)(void *, CUdeviceptr, size_t); + CUresult (*cuCtxSynchronize)(); + + bool load() { + lib = dlopen("libcuda.so.1", RTLD_LAZY | RTLD_GLOBAL); + if (lib == nullptr) lib = dlopen("libcuda.so", RTLD_LAZY | RTLD_GLOBAL); + if (lib == nullptr) { + std::cerr << "dlopen libcuda.so failed: " << dlerror() << std::endl; + return false; + } +#define SYM(name, versioned) \ + do { \ + void *s = dlsym(lib, versioned); \ + if (s == nullptr) s = dlsym(lib, #name); \ + if (s == nullptr) { \ + std::cerr << "dlsym " << versioned << " failed: " \ + << dlerror() << std::endl; \ + return false; \ + } \ + name = reinterpret_cast(s); \ + } while (0) + SYM(cuInit, "cuInit"); + SYM(cuDeviceGet, "cuDeviceGet"); + SYM(cuCtxCreate, "cuCtxCreate_v2"); + SYM(cuCtxDestroy, "cuCtxDestroy_v2"); + SYM(cuMemAlloc, "cuMemAlloc_v2"); + SYM(cuMemFree, "cuMemFree_v2"); + SYM(cuMemsetD8, "cuMemsetD8_v2"); + SYM(cuMemcpyDtoH, "cuMemcpyDtoH_v2"); + SYM(cuCtxSynchronize, "cuCtxSynchronize"); +#undef SYM + return true; + } +}; + +} // namespace + int main(int argc, char *argv[]) { std::string host; std::string access_key; std::string secret_key; - char *bufptr; + char *bufptr = nullptr; + CUdeviceptr dptr = 0; size_t bufsize = 10 * 1024 * 1024UL; bool gpu_enabled = false; if (argc <= 1) { - printf("usage: %s \n", argv[0]); + printf("usage: %s [size] [gpu]\n", + argv[0]); exit(1); } - if (argc > 1) { - host = std::string(argv[1]); - access_key = std::string(argv[2]); - secret_key = std::string(argv[3]); - if (argc >= 5) { - bufsize = std::atoi(argv[4]); - } - if (argc >= 6) { - gpu_enabled = std::string(argv[5]) == "gpu"; - } - } + host = std::string(argv[1]); + access_key = std::string(argv[2]); + secret_key = std::string(argv[3]); + if (argc >= 5) bufsize = std::atoi(argv[4]); + if (argc >= 6) gpu_enabled = std::string(argv[5]) == "gpu"; - // Create S3 base URL. minio::s3::BaseUrl base_url(host, false, "us-east-1"); - - // Create credential provider. minio::creds::StaticProvider provider(access_key, secret_key); - - // Create S3 client. minio::s3::Client client(base_url, &provider); std::cout << bufsize << " " << std::endl; - if (gpu_enabled) { - cudaMalloc(&bufptr, bufsize); - cudaMemset(bufptr, 'A', bufsize); - cudaStreamSynchronize(0); + Cuda cuda; + CUcontext cu_ctx = nullptr; + if (gpu_enabled) { + if (!cuda.load()) { + std::cerr << "CUDA driver (libcuda.so) unavailable — install NVIDIA " + "driver or omit 'gpu'" + << std::endl; + exit(1); + } + if (cuda.cuInit(0) != 0) { + std::cerr << "cuInit failed" << std::endl; + exit(1); + } + CUdevice dev = 0; + if (cuda.cuDeviceGet(&dev, 0) != 0) { + std::cerr << "cuDeviceGet failed" << std::endl; + exit(1); + } + if (cuda.cuCtxCreate(&cu_ctx, 0, dev) != 0) { + std::cerr << "cuCtxCreate failed" << std::endl; + exit(1); + } + if (cuda.cuMemAlloc(&dptr, bufsize) != 0) { + std::cerr << "cuMemAlloc failed" << std::endl; + exit(1); + } + cuda.cuMemsetD8(dptr, 'A', bufsize); + cuda.cuCtxSynchronize(); + bufptr = reinterpret_cast(dptr); std::cout << "GPU enabled" << std::endl; } else { int res = posix_memalign((void **)&bufptr, getpagesize(), bufsize); @@ -88,9 +174,7 @@ int main(int argc, char *argv[]) { pargs.bucket = "my-bucket"; pargs.object = "my-object"; - // Call to put object. minio::s3::PutObjectResponse presp = client.PutObject(pargs); - // Handle response. if (presp) { std::cout << std::endl << "data uploaded successfully " << presp.etag << std::endl; @@ -99,21 +183,17 @@ int main(int argc, char *argv[]) { << std::endl; } - // Create get object arguments. minio::s3::GetObjectRDMAArgs args; if (gpu_enabled) { - cudaMemset(bufptr, 'U', bufsize); - cudaStreamSynchronize(0); + cuda.cuMemsetD8(dptr, 'U', bufsize); + cuda.cuCtxSynchronize(); } args.buf = bufptr; args.size = bufsize; args.bucket = "my-bucket"; args.object = "my-object"; - // Call get object. minio::s3::GetObjectResponse resp = client.GetObject(args); - - // Handle response. if (resp) { std::cout << std::endl << "data of my-object is received successfully" << std::endl; @@ -121,23 +201,17 @@ int main(int argc, char *argv[]) { std::cout << "unable to get object; " << resp.Error().String() << std::endl; } - char *hostptr; - hostptr = (char *)malloc(bufsize); + char *hostptr = (char *)malloc(bufsize); if (gpu_enabled) { - cudaMemcpy(hostptr, bufptr, bufsize, cudaMemcpyDeviceToHost); + cuda.cuMemcpyDtoH(hostptr, dptr, bufsize); } else { memcpy(hostptr, bufptr, bufsize); } - // Open the file in binary mode for writing std::ofstream file("output.txt", std::ios::binary); if (file.is_open()) { - // Write the buffer to the file file.write(hostptr, bufsize); - - // Close the file file.close(); - std::cout << "Buffer written to file successfully." << std::endl; } else { std::cerr << "Error opening file." << std::endl; @@ -145,7 +219,8 @@ int main(int argc, char *argv[]) { free(hostptr); if (gpu_enabled) { - cudaFree(bufptr); + cuda.cuMemFree(dptr); + cuda.cuCtxDestroy(cu_ctx); } else { free(bufptr); } diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h index 62d527ce..12401b80 100644 --- a/include/miniocpp/rdma.h +++ b/include/miniocpp/rdma.h @@ -18,6 +18,22 @@ #ifndef MINIO_CPP_RDMA_H_INCLUDED #define MINIO_CPP_RDMA_H_INCLUDED +// CUDA dependency model +// --------------------- +// minio-cpp does NOT depend on the CUDA Toolkit (cudart / nvcc / cuda_runtime). +// The SDK links only against libcufile + libcuobjclient (vendored), and its +// headers pull in cuda.h solely for type declarations (CUdeviceptr, etc.) +// that appear in cuFile / cuObj API signatures — no CUDA driver or runtime +// symbols are called from within minio-cpp itself. The vendored copy of +// cuda.h under vendor/cuobj/include/ satisfies this type-only include, so +// the SDK compiles and runs on hosts without the CUDA Toolkit. +// +// CUDA is strictly an APPLICATION concern: if your application allocates +// GPU buffers (cudaMalloc / cuMemAlloc) and hands them to PutObjectRDMAArgs +// or GetObjectRDMAArgs, *your* application links against CUDA. Applications +// that pass pinned host memory (posix_memalign / aligned_alloc) don't need +// CUDA at all — cuFile detects host pointers via cuFileGetMemoryType and +// skips the GPU codepath. #include "credentials.h" #include "error.h" #include "nvidia-cufile.h" diff --git a/vendor/cuobj/include/cuda.h b/vendor/cuobj/include/cuda.h new file mode 100644 index 00000000..e26d40ba --- /dev/null +++ b/vendor/cuobj/include/cuda.h @@ -0,0 +1,25029 @@ +/* + * Copyright 1993-2023 NVIDIA Corporation. All rights reserved. + * + * NOTICE TO LICENSEE: + * + * This source code and/or documentation ("Licensed Deliverables") are + * subject to NVIDIA intellectual property rights under U.S. and + * international Copyright laws. + * + * These Licensed Deliverables contained herein is PROPRIETARY and + * CONFIDENTIAL to NVIDIA and is being provided under the terms and + * conditions of a form of NVIDIA software license agreement by and + * between NVIDIA and Licensee ("License Agreement") or electronically + * accepted by Licensee. Notwithstanding any terms or conditions to + * the contrary in the License Agreement, reproduction or disclosure + * of the Licensed Deliverables to any third party without the express + * written consent of NVIDIA is prohibited. + * + * NOTWITHSTANDING ANY TERMS OR CONDITIONS TO THE CONTRARY IN THE + * LICENSE AGREEMENT, NVIDIA MAKES NO REPRESENTATION ABOUT THE + * SUITABILITY OF THESE LICENSED DELIVERABLES FOR ANY PURPOSE. IT IS + * PROVIDED "AS IS" WITHOUT EXPRESS OR IMPLIED WARRANTY OF ANY KIND. + * NVIDIA DISCLAIMS ALL WARRANTIES WITH REGARD TO THESE LICENSED + * DELIVERABLES, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY, + * NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE. + * NOTWITHSTANDING ANY TERMS OR CONDITIONS TO THE CONTRARY IN THE + * LICENSE AGREEMENT, IN NO EVENT SHALL NVIDIA BE LIABLE FOR ANY + * SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, OR ANY + * DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, + * WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS + * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE + * OF THESE LICENSED DELIVERABLES. + * + * U.S. Government End Users. These Licensed Deliverables are a + * "commercial item" as that term is defined at 48 C.F.R. 2.101 (OCT + * 1995), consisting of "commercial computer software" and "commercial + * computer software documentation" as such terms are used in 48 + * C.F.R. 12.212 (SEPT 1995) and is provided to the U.S. Government + * only as a commercial end item. Consistent with 48 C.F.R.12.212 and + * 48 C.F.R. 227.7202-1 through 227.7202-4 (JUNE 1995), all + * U.S. Government End Users acquire the Licensed Deliverables with + * only those rights set forth herein. + * + * Any use of the Licensed Deliverables in individual and commercial + * software must include, in the user documentation and internal + * comments to the code, the above Disclaimer and U.S. Government End + * Users Notice. + */ + +#ifndef __cuda_cuda_h__ +#define __cuda_cuda_h__ + + + + +#include +#ifdef _MSC_VER +typedef unsigned __int32 cuuint32_t; +typedef unsigned __int64 cuuint64_t; +#else +#include +typedef uint32_t cuuint32_t; +typedef uint64_t cuuint64_t; +#endif + +#if defined(__CUDA_API_VERSION_INTERNAL) || defined(__DOXYGEN_ONLY__) || defined(CUDA_ENABLE_DEPRECATED) +#define __CUDA_DEPRECATED +#elif defined(_MSC_VER) +#define __CUDA_DEPRECATED __declspec(deprecated) +#elif defined(__GNUC__) +#define __CUDA_DEPRECATED __attribute__((deprecated)) +#else +#define __CUDA_DEPRECATED +#endif + +#if defined(CUDA_FORCE_API_VERSION) +#error "CUDA_FORCE_API_VERSION is no longer supported." +#endif + +#if defined(__CUDA_API_VERSION_INTERNAL) || defined(CUDA_API_PER_THREAD_DEFAULT_STREAM) + #define __CUDA_API_PER_THREAD_DEFAULT_STREAM + #define __CUDA_API_PTDS(api) api ## _ptds + #define __CUDA_API_PTSZ(api) api ## _ptsz +#else + #define __CUDA_API_PTDS(api) api + #define __CUDA_API_PTSZ(api) api +#endif + +#define cuDeviceTotalMem cuDeviceTotalMem_v2 +#define cuCtxCreate cuCtxCreate_v2 +#define cuCtxCreate_v3 cuCtxCreate_v3 +#define cuCtxCreate_v4 cuCtxCreate_v4 +#define cuModuleGetGlobal cuModuleGetGlobal_v2 +#define cuMemGetInfo cuMemGetInfo_v2 +#define cuMemAlloc cuMemAlloc_v2 +#define cuMemAllocPitch cuMemAllocPitch_v2 +#define cuMemFree cuMemFree_v2 +#define cuMemGetAddressRange cuMemGetAddressRange_v2 +#define cuMemAllocHost cuMemAllocHost_v2 +#define cuMemHostGetDevicePointer cuMemHostGetDevicePointer_v2 +#define cuMemcpyHtoD __CUDA_API_PTDS(cuMemcpyHtoD_v2) +#define cuMemcpyDtoH __CUDA_API_PTDS(cuMemcpyDtoH_v2) +#define cuMemcpyDtoD __CUDA_API_PTDS(cuMemcpyDtoD_v2) +#define cuMemcpyDtoA __CUDA_API_PTDS(cuMemcpyDtoA_v2) +#define cuMemcpyAtoD __CUDA_API_PTDS(cuMemcpyAtoD_v2) +#define cuMemcpyHtoA __CUDA_API_PTDS(cuMemcpyHtoA_v2) +#define cuMemcpyAtoH __CUDA_API_PTDS(cuMemcpyAtoH_v2) +#define cuMemcpyAtoA __CUDA_API_PTDS(cuMemcpyAtoA_v2) +#define cuMemcpyHtoAAsync __CUDA_API_PTSZ(cuMemcpyHtoAAsync_v2) +#define cuMemcpyAtoHAsync __CUDA_API_PTSZ(cuMemcpyAtoHAsync_v2) +#define cuMemcpy2D __CUDA_API_PTDS(cuMemcpy2D_v2) +#define cuMemcpy2DUnaligned __CUDA_API_PTDS(cuMemcpy2DUnaligned_v2) +#define cuMemcpy3D __CUDA_API_PTDS(cuMemcpy3D_v2) +#define cuMemcpyHtoDAsync __CUDA_API_PTSZ(cuMemcpyHtoDAsync_v2) +#define cuMemcpyDtoHAsync __CUDA_API_PTSZ(cuMemcpyDtoHAsync_v2) +#define cuMemcpyDtoDAsync __CUDA_API_PTSZ(cuMemcpyDtoDAsync_v2) +#define cuMemcpy2DAsync __CUDA_API_PTSZ(cuMemcpy2DAsync_v2) +#define cuMemcpy3DAsync __CUDA_API_PTSZ(cuMemcpy3DAsync_v2) +#define cuMemsetD8 __CUDA_API_PTDS(cuMemsetD8_v2) +#define cuMemsetD16 __CUDA_API_PTDS(cuMemsetD16_v2) +#define cuMemsetD32 __CUDA_API_PTDS(cuMemsetD32_v2) +#define cuMemsetD2D8 __CUDA_API_PTDS(cuMemsetD2D8_v2) +#define cuMemsetD2D16 __CUDA_API_PTDS(cuMemsetD2D16_v2) +#define cuMemsetD2D32 __CUDA_API_PTDS(cuMemsetD2D32_v2) +#define cuArrayCreate cuArrayCreate_v2 +#define cuArrayGetDescriptor cuArrayGetDescriptor_v2 +#define cuArray3DCreate cuArray3DCreate_v2 +#define cuArray3DGetDescriptor cuArray3DGetDescriptor_v2 +#define cuTexRefSetAddress cuTexRefSetAddress_v2 +#define cuTexRefGetAddress cuTexRefGetAddress_v2 +#define cuGraphicsResourceGetMappedPointer cuGraphicsResourceGetMappedPointer_v2 +#define cuCtxDestroy cuCtxDestroy_v2 +#define cuCtxPopCurrent cuCtxPopCurrent_v2 +#define cuCtxPushCurrent cuCtxPushCurrent_v2 +#define cuStreamDestroy cuStreamDestroy_v2 +#define cuEventDestroy cuEventDestroy_v2 +#define cuTexRefSetAddress2D cuTexRefSetAddress2D_v3 +#define cuLinkCreate cuLinkCreate_v2 +#define cuLinkAddData cuLinkAddData_v2 +#define cuLinkAddFile cuLinkAddFile_v2 +#define cuMemHostRegister cuMemHostRegister_v2 +#define cuGraphicsResourceSetMapFlags cuGraphicsResourceSetMapFlags_v2 +#define cuStreamBeginCapture __CUDA_API_PTSZ(cuStreamBeginCapture_v2) +#define cuDevicePrimaryCtxRelease cuDevicePrimaryCtxRelease_v2 +#define cuDevicePrimaryCtxReset cuDevicePrimaryCtxReset_v2 +#define cuDevicePrimaryCtxSetFlags cuDevicePrimaryCtxSetFlags_v2 +#define cuDeviceGetUuid_v2 cuDeviceGetUuid_v2 +#define cuIpcOpenMemHandle cuIpcOpenMemHandle_v2 + +#define cuGraphInstantiate cuGraphInstantiateWithFlags + +#define cuGraphExecUpdate cuGraphExecUpdate_v2 +#define cuGetProcAddress cuGetProcAddress_v2 +#define cuGraphAddKernelNode cuGraphAddKernelNode_v2 +#define cuGraphKernelNodeGetParams cuGraphKernelNodeGetParams_v2 +#define cuGraphKernelNodeSetParams cuGraphKernelNodeSetParams_v2 +#define cuGraphExecKernelNodeSetParams cuGraphExecKernelNodeSetParams_v2 + +#define cuStreamWriteValue32 __CUDA_API_PTSZ(cuStreamWriteValue32_v2) +#define cuStreamWaitValue32 __CUDA_API_PTSZ(cuStreamWaitValue32_v2) +#define cuStreamWriteValue64 __CUDA_API_PTSZ(cuStreamWriteValue64_v2) +#define cuStreamWaitValue64 __CUDA_API_PTSZ(cuStreamWaitValue64_v2) +#define cuStreamBatchMemOp __CUDA_API_PTSZ(cuStreamBatchMemOp_v2) +#define cuStreamGetCaptureInfo __CUDA_API_PTSZ(cuStreamGetCaptureInfo_v2) +#define cuStreamGetCaptureInfo_v2 __CUDA_API_PTSZ(cuStreamGetCaptureInfo_v2) + +#if defined(__CUDA_API_PER_THREAD_DEFAULT_STREAM) + #define cuMemcpy __CUDA_API_PTDS(cuMemcpy) + #define cuMemcpyAsync __CUDA_API_PTSZ(cuMemcpyAsync) + #define cuMemcpyPeer __CUDA_API_PTDS(cuMemcpyPeer) + #define cuMemcpyPeerAsync __CUDA_API_PTSZ(cuMemcpyPeerAsync) + #define cuMemcpy3DPeer __CUDA_API_PTDS(cuMemcpy3DPeer) + #define cuMemcpy3DPeerAsync __CUDA_API_PTSZ(cuMemcpy3DPeerAsync) + #define cuMemPrefetchAsync __CUDA_API_PTSZ(cuMemPrefetchAsync) + #define cuMemPrefetchAsync_v2 __CUDA_API_PTSZ(cuMemPrefetchAsync_v2) + + #define cuMemsetD8Async __CUDA_API_PTSZ(cuMemsetD8Async) + #define cuMemsetD16Async __CUDA_API_PTSZ(cuMemsetD16Async) + #define cuMemsetD32Async __CUDA_API_PTSZ(cuMemsetD32Async) + #define cuMemsetD2D8Async __CUDA_API_PTSZ(cuMemsetD2D8Async) + #define cuMemsetD2D16Async __CUDA_API_PTSZ(cuMemsetD2D16Async) + #define cuMemsetD2D32Async __CUDA_API_PTSZ(cuMemsetD2D32Async) + + #define cuStreamGetPriority __CUDA_API_PTSZ(cuStreamGetPriority) + #define cuStreamGetId __CUDA_API_PTSZ(cuStreamGetId) + #define cuStreamGetFlags __CUDA_API_PTSZ(cuStreamGetFlags) + #define cuStreamGetCtx __CUDA_API_PTSZ(cuStreamGetCtx) + #define cuStreamGetCtx_v2 __CUDA_API_PTSZ(cuStreamGetCtx_v2) + #define cuStreamWaitEvent __CUDA_API_PTSZ(cuStreamWaitEvent) + #define cuStreamEndCapture __CUDA_API_PTSZ(cuStreamEndCapture) + #define cuStreamIsCapturing __CUDA_API_PTSZ(cuStreamIsCapturing) + #define cuStreamGetCaptureInfo_v3 __CUDA_API_PTSZ(cuStreamGetCaptureInfo_v3) + #define cuStreamUpdateCaptureDependencies __CUDA_API_PTSZ(cuStreamUpdateCaptureDependencies) + #define cuStreamUpdateCaptureDependencies_v2 __CUDA_API_PTSZ(cuStreamUpdateCaptureDependencies_v2) + #define cuStreamAddCallback __CUDA_API_PTSZ(cuStreamAddCallback) + #define cuStreamAttachMemAsync __CUDA_API_PTSZ(cuStreamAttachMemAsync) + #define cuStreamQuery __CUDA_API_PTSZ(cuStreamQuery) + #define cuStreamSynchronize __CUDA_API_PTSZ(cuStreamSynchronize) + #define cuEventRecord __CUDA_API_PTSZ(cuEventRecord) + #define cuEventRecordWithFlags __CUDA_API_PTSZ(cuEventRecordWithFlags) + #define cuLaunchKernel __CUDA_API_PTSZ(cuLaunchKernel) + #define cuLaunchKernelEx __CUDA_API_PTSZ(cuLaunchKernelEx) + #define cuLaunchHostFunc __CUDA_API_PTSZ(cuLaunchHostFunc) + #define cuGraphicsMapResources __CUDA_API_PTSZ(cuGraphicsMapResources) + #define cuGraphicsUnmapResources __CUDA_API_PTSZ(cuGraphicsUnmapResources) + + + #define cuLaunchCooperativeKernel __CUDA_API_PTSZ(cuLaunchCooperativeKernel) + + #define cuSignalExternalSemaphoresAsync __CUDA_API_PTSZ(cuSignalExternalSemaphoresAsync) + #define cuWaitExternalSemaphoresAsync __CUDA_API_PTSZ(cuWaitExternalSemaphoresAsync) + + #define cuGraphInstantiateWithParams __CUDA_API_PTSZ(cuGraphInstantiateWithParams) + #define cuGraphUpload __CUDA_API_PTSZ(cuGraphUpload) + #define cuGraphLaunch __CUDA_API_PTSZ(cuGraphLaunch) + #define cuStreamCopyAttributes __CUDA_API_PTSZ(cuStreamCopyAttributes) + #define cuStreamGetAttribute __CUDA_API_PTSZ(cuStreamGetAttribute) + #define cuStreamSetAttribute __CUDA_API_PTSZ(cuStreamSetAttribute) + #define cuMemMapArrayAsync __CUDA_API_PTSZ(cuMemMapArrayAsync) + + #define cuMemFreeAsync __CUDA_API_PTSZ(cuMemFreeAsync) + #define cuMemAllocAsync __CUDA_API_PTSZ(cuMemAllocAsync) + #define cuMemAllocFromPoolAsync __CUDA_API_PTSZ(cuMemAllocFromPoolAsync) + + #define cuStreamBeginCaptureToGraph __CUDA_API_PTSZ(cuStreamBeginCaptureToGraph) + +#endif + +/** + * \file cuda.h + * \brief Header file for the CUDA Toolkit application programming interface. + * + * \file cudaGL.h + * \brief Header file for the OpenGL interoperability functions of the + * low-level CUDA driver application programming interface. + * + * \file cudaD3D9.h + * \brief Header file for the Direct3D 9 interoperability functions of the + * low-level CUDA driver application programming interface. + */ + +/** + * \defgroup CUDA_TYPES Data types used by CUDA driver + * @{ + */ + +/** + * CUDA API version number + */ +#define CUDA_VERSION 12060 + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * CUDA device pointer + * CUdeviceptr is defined as an unsigned integer type whose size matches the size of a pointer on the target platform. + */ +#if defined(_WIN64) || defined(__LP64__) +typedef unsigned long long CUdeviceptr_v2; +#else +typedef unsigned int CUdeviceptr_v2; +#endif +typedef CUdeviceptr_v2 CUdeviceptr; /**< CUDA device pointer */ + +typedef int CUdevice_v1; /**< CUDA device */ +typedef CUdevice_v1 CUdevice; /**< CUDA device */ +typedef struct CUctx_st *CUcontext; /**< A regular context handle */ +typedef struct CUmod_st *CUmodule; /**< CUDA module */ +typedef struct CUfunc_st *CUfunction; /**< CUDA function */ +typedef struct CUlib_st *CUlibrary; /**< CUDA library */ +typedef struct CUkern_st *CUkernel; /**< CUDA kernel */ +typedef struct CUarray_st *CUarray; /**< CUDA array */ +typedef struct CUmipmappedArray_st *CUmipmappedArray; /**< CUDA mipmapped array */ +typedef struct CUtexref_st *CUtexref; /**< CUDA texture reference */ +typedef struct CUsurfref_st *CUsurfref; /**< CUDA surface reference */ +typedef struct CUevent_st *CUevent; /**< CUDA event */ +typedef struct CUstream_st *CUstream; /**< CUDA stream */ +typedef struct CUgraphicsResource_st *CUgraphicsResource; /**< CUDA graphics interop resource */ +typedef unsigned long long CUtexObject_v1; /**< An opaque value that represents a CUDA texture object */ +typedef CUtexObject_v1 CUtexObject; /**< An opaque value that represents a CUDA texture object */ +typedef unsigned long long CUsurfObject_v1; /**< An opaque value that represents a CUDA surface object */ +typedef CUsurfObject_v1 CUsurfObject; /**< An opaque value that represents a CUDA surface object */ +typedef struct CUextMemory_st *CUexternalMemory; /**< CUDA external memory */ +typedef struct CUextSemaphore_st *CUexternalSemaphore; /**< CUDA external semaphore */ +typedef struct CUgraph_st *CUgraph; /**< CUDA graph */ +typedef struct CUgraphNode_st *CUgraphNode; /**< CUDA graph node */ +typedef struct CUgraphExec_st *CUgraphExec; /**< CUDA executable graph */ +typedef struct CUmemPoolHandle_st *CUmemoryPool; /**< CUDA memory pool */ +typedef struct CUuserObject_st *CUuserObject; /**< CUDA user object for graphs */ +typedef cuuint64_t CUgraphConditionalHandle; /**< CUDA graph conditional handle */ +typedef struct CUgraphDeviceUpdatableNode_st *CUgraphDeviceNode; /**< CUDA graph device node handle */ +typedef struct CUasyncCallbackEntry_st *CUasyncCallbackHandle; /**< CUDA async notification callback handle */ +/*! + * \typedef typedef struct CUgreenCtx_st* CUgreenCtx + * A green context handle. This handle can be used safely from only one CPU thread at a time. + * Created via ::cuGreenCtxCreate + */ +typedef struct CUgreenCtx_st *CUgreenCtx; + +#ifndef CU_UUID_HAS_BEEN_DEFINED +#define CU_UUID_HAS_BEEN_DEFINED +typedef struct CUuuid_st { /**< CUDA definition of UUID */ + char bytes[16]; +} CUuuid; +#endif + +/** + * CUDA IPC handle size + */ +#define CU_IPC_HANDLE_SIZE 64 + +/** + * Fabric handle - An opaque handle representing a memory allocation + * that can be exported to processes in same or different nodes. For IPC + * between processes on different nodes they must be connected via the + * NVSwitch fabric. + */ +typedef struct CUmemFabricHandle_st { + unsigned char data[CU_IPC_HANDLE_SIZE]; +} CUmemFabricHandle_v1; +typedef CUmemFabricHandle_v1 CUmemFabricHandle; + +/** + * CUDA IPC event handle + */ +typedef struct CUipcEventHandle_st { + char reserved[CU_IPC_HANDLE_SIZE]; +} CUipcEventHandle_v1; +typedef CUipcEventHandle_v1 CUipcEventHandle; + +/** + * CUDA IPC mem handle + */ +typedef struct CUipcMemHandle_st { + char reserved[CU_IPC_HANDLE_SIZE]; +} CUipcMemHandle_v1; +typedef CUipcMemHandle_v1 CUipcMemHandle; + +/** + * CUDA Ipc Mem Flags + */ +typedef enum CUipcMem_flags_enum { + CU_IPC_MEM_LAZY_ENABLE_PEER_ACCESS = 0x1 /**< Automatically enable peer access between remote devices as needed */ +} CUipcMem_flags; + + +/** + * CUDA Mem Attach Flags + */ +typedef enum CUmemAttach_flags_enum { + CU_MEM_ATTACH_GLOBAL = 0x1, /**< Memory can be accessed by any stream on any device */ + CU_MEM_ATTACH_HOST = 0x2, /**< Memory cannot be accessed by any stream on any device */ + CU_MEM_ATTACH_SINGLE = 0x4 /**< Memory can only be accessed by a single stream on the associated device */ +} CUmemAttach_flags; + +/** + * Context creation flags + */ +typedef enum CUctx_flags_enum { + CU_CTX_SCHED_AUTO = 0x00, /**< Automatic scheduling */ + CU_CTX_SCHED_SPIN = 0x01, /**< Set spin as default scheduling */ + CU_CTX_SCHED_YIELD = 0x02, /**< Set yield as default scheduling */ + CU_CTX_SCHED_BLOCKING_SYNC = 0x04, /**< Set blocking synchronization as default scheduling */ + CU_CTX_BLOCKING_SYNC = 0x04, /**< Set blocking synchronization as default scheduling + * \deprecated This flag was deprecated as of CUDA 4.0 + * and was replaced with ::CU_CTX_SCHED_BLOCKING_SYNC. */ + CU_CTX_SCHED_MASK = 0x07, + CU_CTX_MAP_HOST = 0x08, /**< \deprecated This flag was deprecated as of CUDA 11.0 + * and it no longer has any effect. All contexts + * as of CUDA 3.2 behave as though the flag is enabled. */ + CU_CTX_LMEM_RESIZE_TO_MAX = 0x10, /**< Keep local memory allocation after launch */ + CU_CTX_COREDUMP_ENABLE = 0x20, /**< Trigger coredumps from exceptions in this context */ + CU_CTX_USER_COREDUMP_ENABLE= 0x40, /**< Enable user pipe to trigger coredumps in this context */ + CU_CTX_SYNC_MEMOPS = 0x80, /**< Ensure synchronous memory operations on this context will synchronize */ + CU_CTX_FLAGS_MASK = 0xFF +} CUctx_flags; + +/** + * Event sched flags + */ +typedef enum CUevent_sched_flags_enum { + CU_EVENT_SCHED_AUTO = 0x00, /**< Automatic scheduling */ + CU_EVENT_SCHED_SPIN = 0x01, /**< Set spin as default scheduling */ + CU_EVENT_SCHED_YIELD = 0x02, /**< Set yield as default scheduling */ + CU_EVENT_SCHED_BLOCKING_SYNC = 0x04, /**< Set blocking synchronization as default scheduling */ +} CUevent_sched_flags; + +/** + * NVCL event scheduling flags + */ +typedef enum cl_event_flags_enum { + NVCL_EVENT_SCHED_AUTO = 0x00, /**< Automatic scheduling */ + NVCL_EVENT_SCHED_SPIN = 0x01, /**< Set spin as default scheduling */ + NVCL_EVENT_SCHED_YIELD = 0x02, /**< Set yield as default scheduling */ + NVCL_EVENT_SCHED_BLOCKING_SYNC = 0x04, /**< Set blocking synchronization as default scheduling */ +} cl_event_flags; + +/** + * NVCL context scheduling flags + */ +typedef enum cl_context_flags_enum { + NVCL_CTX_SCHED_AUTO = 0x00, /**< Automatic scheduling */ + NVCL_CTX_SCHED_SPIN = 0x01, /**< Set spin as default scheduling */ + NVCL_CTX_SCHED_YIELD = 0x02, /**< Set yield as default scheduling */ + NVCL_CTX_SCHED_BLOCKING_SYNC = 0x04, /**< Set blocking synchronization as default scheduling */ +} cl_context_flags; + + +/** + * Stream creation flags + */ +typedef enum CUstream_flags_enum { + CU_STREAM_DEFAULT = 0x0, /**< Default stream flag */ + CU_STREAM_NON_BLOCKING = 0x1 /**< Stream does not synchronize with stream 0 (the NULL stream) */ +} CUstream_flags; + +/** + * Legacy stream handle + * + * Stream handle that can be passed as a CUstream to use an implicit stream + * with legacy synchronization behavior. + * + * See details of the \link_sync_behavior + */ +#define CU_STREAM_LEGACY ((CUstream)0x1) + +/** + * Per-thread stream handle + * + * Stream handle that can be passed as a CUstream to use an implicit stream + * with per-thread synchronization behavior. + * + * See details of the \link_sync_behavior + */ +#define CU_STREAM_PER_THREAD ((CUstream)0x2) + +/** + * Event creation flags + */ +typedef enum CUevent_flags_enum { + CU_EVENT_DEFAULT = 0x0, /**< Default event flag */ + CU_EVENT_BLOCKING_SYNC = 0x1, /**< Event uses blocking synchronization */ + CU_EVENT_DISABLE_TIMING = 0x2, /**< Event will not record timing data */ + CU_EVENT_INTERPROCESS = 0x4 /**< Event is suitable for interprocess use. CU_EVENT_DISABLE_TIMING must be set */ +} CUevent_flags; + +/** + * Event record flags + */ +typedef enum CUevent_record_flags_enum { + CU_EVENT_RECORD_DEFAULT = 0x0, /**< Default event record flag */ + CU_EVENT_RECORD_EXTERNAL = 0x1 /**< When using stream capture, create an event record node + * instead of the default behavior. This flag is invalid + * when used outside of capture. */ +} CUevent_record_flags; + +/** + * Event wait flags + */ +typedef enum CUevent_wait_flags_enum { + CU_EVENT_WAIT_DEFAULT = 0x0, /**< Default event wait flag */ + CU_EVENT_WAIT_EXTERNAL = 0x1 /**< When using stream capture, create an event wait node + * instead of the default behavior. This flag is invalid + * when used outside of capture.*/ +} CUevent_wait_flags; + +/** + * Flags for ::cuStreamWaitValue32 and ::cuStreamWaitValue64 + */ +typedef enum CUstreamWaitValue_flags_enum { + CU_STREAM_WAIT_VALUE_GEQ = 0x0, /**< Wait until (int32_t)(*addr - value) >= 0 (or int64_t for 64 bit + values). Note this is a cyclic comparison which ignores wraparound. + (Default behavior.) */ + CU_STREAM_WAIT_VALUE_EQ = 0x1, /**< Wait until *addr == value. */ + CU_STREAM_WAIT_VALUE_AND = 0x2, /**< Wait until (*addr & value) != 0. */ + CU_STREAM_WAIT_VALUE_NOR = 0x3, /**< Wait until ~(*addr | value) != 0. Support for this operation can be + queried with ::cuDeviceGetAttribute() and + ::CU_DEVICE_ATTRIBUTE_CAN_USE_STREAM_WAIT_VALUE_NOR.*/ + CU_STREAM_WAIT_VALUE_FLUSH = 1<<30 /**< Follow the wait operation with a flush of outstanding remote writes. This + means that, if a remote write operation is guaranteed to have reached the + device before the wait can be satisfied, that write is guaranteed to be + visible to downstream device work. The device is permitted to reorder + remote writes internally. For example, this flag would be required if + two remote writes arrive in a defined order, the wait is satisfied by the + second write, and downstream work needs to observe the first write. + Support for this operation is restricted to selected platforms and can be + queried with ::CU_DEVICE_ATTRIBUTE_CAN_FLUSH_REMOTE_WRITES.*/ +} CUstreamWaitValue_flags; + +/** + * Flags for ::cuStreamWriteValue32 + */ +typedef enum CUstreamWriteValue_flags_enum { + CU_STREAM_WRITE_VALUE_DEFAULT = 0x0, /**< Default behavior */ + CU_STREAM_WRITE_VALUE_NO_MEMORY_BARRIER = 0x1 /**< Permits the write to be reordered with writes which were issued + before it, as a performance optimization. Normally, + ::cuStreamWriteValue32 will provide a memory fence before the + write, which has similar semantics to + __threadfence_system() but is scoped to the stream + rather than a CUDA thread. + This flag is not supported in the v2 API. */ +} CUstreamWriteValue_flags; + +/** + * Operations for ::cuStreamBatchMemOp + */ +typedef enum CUstreamBatchMemOpType_enum { + CU_STREAM_MEM_OP_WAIT_VALUE_32 = 1, /**< Represents a ::cuStreamWaitValue32 operation */ + CU_STREAM_MEM_OP_WRITE_VALUE_32 = 2, /**< Represents a ::cuStreamWriteValue32 operation */ + CU_STREAM_MEM_OP_WAIT_VALUE_64 = 4, /**< Represents a ::cuStreamWaitValue64 operation */ + CU_STREAM_MEM_OP_WRITE_VALUE_64 = 5, /**< Represents a ::cuStreamWriteValue64 operation */ + CU_STREAM_MEM_OP_BARRIER = 6, /**< Insert a memory barrier of the specified type */ + CU_STREAM_MEM_OP_FLUSH_REMOTE_WRITES = 3 /**< This has the same effect as ::CU_STREAM_WAIT_VALUE_FLUSH, but as a + standalone operation. */ +} CUstreamBatchMemOpType; + +/** + * Flags for ::cuStreamMemoryBarrier + */ +typedef enum CUstreamMemoryBarrier_flags_enum { + CU_STREAM_MEMORY_BARRIER_TYPE_SYS = 0x0, /**< System-wide memory barrier. */ + CU_STREAM_MEMORY_BARRIER_TYPE_GPU = 0x1 /**< Limit memory barrier scope to the GPU. */ +} CUstreamMemoryBarrier_flags; + +/** + * Per-operation parameters for ::cuStreamBatchMemOp + */ +typedef union CUstreamBatchMemOpParams_union { + CUstreamBatchMemOpType operation; + struct CUstreamMemOpWaitValueParams_st { + CUstreamBatchMemOpType operation; + CUdeviceptr address; + union { + cuuint32_t value; + cuuint64_t value64; + }; + unsigned int flags; + CUdeviceptr alias; /**< For driver internal use. Initial value is unimportant. */ + } waitValue; + struct CUstreamMemOpWriteValueParams_st { + CUstreamBatchMemOpType operation; + CUdeviceptr address; + union { + cuuint32_t value; + cuuint64_t value64; + }; + unsigned int flags; + CUdeviceptr alias; /**< For driver internal use. Initial value is unimportant. */ + } writeValue; + struct CUstreamMemOpFlushRemoteWritesParams_st { + CUstreamBatchMemOpType operation; + unsigned int flags; + } flushRemoteWrites; + struct CUstreamMemOpMemoryBarrierParams_st { /**< Only supported in the _v2 API */ + CUstreamBatchMemOpType operation; + unsigned int flags; + } memoryBarrier; + cuuint64_t pad[6]; +} CUstreamBatchMemOpParams_v1; +typedef CUstreamBatchMemOpParams_v1 CUstreamBatchMemOpParams; + +typedef struct CUDA_BATCH_MEM_OP_NODE_PARAMS_v1_st { + CUcontext ctx; + unsigned int count; + CUstreamBatchMemOpParams *paramArray; + unsigned int flags; +} CUDA_BATCH_MEM_OP_NODE_PARAMS_v1; +typedef CUDA_BATCH_MEM_OP_NODE_PARAMS_v1 CUDA_BATCH_MEM_OP_NODE_PARAMS; + +/** + * Batch memory operation node parameters + */ +typedef struct CUDA_BATCH_MEM_OP_NODE_PARAMS_v2_st { + CUcontext ctx; /**< Context to use for the operations. */ + unsigned int count; /**< Number of operations in paramArray. */ + CUstreamBatchMemOpParams *paramArray; /**< Array of batch memory operations. */ + unsigned int flags; /**< Flags to control the node. */ +} CUDA_BATCH_MEM_OP_NODE_PARAMS_v2; + +/** + * Occupancy calculator flag + */ +typedef enum CUoccupancy_flags_enum { + CU_OCCUPANCY_DEFAULT = 0x0, /**< Default behavior */ + CU_OCCUPANCY_DISABLE_CACHING_OVERRIDE = 0x1 /**< Assume global caching is enabled and cannot be automatically turned off */ +} CUoccupancy_flags; + +/** + * Flags for ::cuStreamUpdateCaptureDependencies + */ +typedef enum CUstreamUpdateCaptureDependencies_flags_enum { + CU_STREAM_ADD_CAPTURE_DEPENDENCIES = 0x0, /**< Add new nodes to the dependency set */ + CU_STREAM_SET_CAPTURE_DEPENDENCIES = 0x1 /**< Replace the dependency set with the new nodes */ +} CUstreamUpdateCaptureDependencies_flags; + +/** +* Types of async notification that can be sent +*/ +typedef enum CUasyncNotificationType_enum { + CU_ASYNC_NOTIFICATION_TYPE_OVER_BUDGET = 0x1 +} CUasyncNotificationType; + +/** +* Information passed to the user via the async notification callback +*/ +typedef struct CUasyncNotificationInfo_st { + CUasyncNotificationType type; + union { + struct { + unsigned long long bytesOverBudget; + } overBudget; + } info; +} CUasyncNotificationInfo; + +/** + * CUDA async notification callback + * \param info Information describing what actions to take as a result of this trim notification. + * \param userData Pointer to user defined data provided at registration. + * \param callback The callback handle associated with this specific callback. + */ +typedef void (*CUasyncCallback)(CUasyncNotificationInfo *info, void *userData, CUasyncCallbackHandle callback); + +/** + * Array formats + */ +typedef enum CUarray_format_enum { + CU_AD_FORMAT_UNSIGNED_INT8 = 0x01, /**< Unsigned 8-bit integers */ + CU_AD_FORMAT_UNSIGNED_INT16 = 0x02, /**< Unsigned 16-bit integers */ + CU_AD_FORMAT_UNSIGNED_INT32 = 0x03, /**< Unsigned 32-bit integers */ + CU_AD_FORMAT_SIGNED_INT8 = 0x08, /**< Signed 8-bit integers */ + CU_AD_FORMAT_SIGNED_INT16 = 0x09, /**< Signed 16-bit integers */ + CU_AD_FORMAT_SIGNED_INT32 = 0x0a, /**< Signed 32-bit integers */ + CU_AD_FORMAT_HALF = 0x10, /**< 16-bit floating point */ + CU_AD_FORMAT_FLOAT = 0x20, /**< 32-bit floating point */ + CU_AD_FORMAT_NV12 = 0xb0, /**< 8-bit YUV planar format, with 4:2:0 sampling */ + CU_AD_FORMAT_UNORM_INT8X1 = 0xc0, /**< 1 channel unsigned 8-bit normalized integer */ + CU_AD_FORMAT_UNORM_INT8X2 = 0xc1, /**< 2 channel unsigned 8-bit normalized integer */ + CU_AD_FORMAT_UNORM_INT8X4 = 0xc2, /**< 4 channel unsigned 8-bit normalized integer */ + CU_AD_FORMAT_UNORM_INT16X1 = 0xc3, /**< 1 channel unsigned 16-bit normalized integer */ + CU_AD_FORMAT_UNORM_INT16X2 = 0xc4, /**< 2 channel unsigned 16-bit normalized integer */ + CU_AD_FORMAT_UNORM_INT16X4 = 0xc5, /**< 4 channel unsigned 16-bit normalized integer */ + CU_AD_FORMAT_SNORM_INT8X1 = 0xc6, /**< 1 channel signed 8-bit normalized integer */ + CU_AD_FORMAT_SNORM_INT8X2 = 0xc7, /**< 2 channel signed 8-bit normalized integer */ + CU_AD_FORMAT_SNORM_INT8X4 = 0xc8, /**< 4 channel signed 8-bit normalized integer */ + CU_AD_FORMAT_SNORM_INT16X1 = 0xc9, /**< 1 channel signed 16-bit normalized integer */ + CU_AD_FORMAT_SNORM_INT16X2 = 0xca, /**< 2 channel signed 16-bit normalized integer */ + CU_AD_FORMAT_SNORM_INT16X4 = 0xcb, /**< 4 channel signed 16-bit normalized integer */ + CU_AD_FORMAT_BC1_UNORM = 0x91, /**< 4 channel unsigned normalized block-compressed (BC1 compression) format */ + CU_AD_FORMAT_BC1_UNORM_SRGB = 0x92, /**< 4 channel unsigned normalized block-compressed (BC1 compression) format with sRGB encoding*/ + CU_AD_FORMAT_BC2_UNORM = 0x93, /**< 4 channel unsigned normalized block-compressed (BC2 compression) format */ + CU_AD_FORMAT_BC2_UNORM_SRGB = 0x94, /**< 4 channel unsigned normalized block-compressed (BC2 compression) format with sRGB encoding*/ + CU_AD_FORMAT_BC3_UNORM = 0x95, /**< 4 channel unsigned normalized block-compressed (BC3 compression) format */ + CU_AD_FORMAT_BC3_UNORM_SRGB = 0x96, /**< 4 channel unsigned normalized block-compressed (BC3 compression) format with sRGB encoding*/ + CU_AD_FORMAT_BC4_UNORM = 0x97, /**< 1 channel unsigned normalized block-compressed (BC4 compression) format */ + CU_AD_FORMAT_BC4_SNORM = 0x98, /**< 1 channel signed normalized block-compressed (BC4 compression) format */ + CU_AD_FORMAT_BC5_UNORM = 0x99, /**< 2 channel unsigned normalized block-compressed (BC5 compression) format */ + CU_AD_FORMAT_BC5_SNORM = 0x9a, /**< 2 channel signed normalized block-compressed (BC5 compression) format */ + CU_AD_FORMAT_BC6H_UF16 = 0x9b, /**< 3 channel unsigned half-float block-compressed (BC6H compression) format */ + CU_AD_FORMAT_BC6H_SF16 = 0x9c, /**< 3 channel signed half-float block-compressed (BC6H compression) format */ + CU_AD_FORMAT_BC7_UNORM = 0x9d, /**< 4 channel unsigned normalized block-compressed (BC7 compression) format */ + CU_AD_FORMAT_BC7_UNORM_SRGB = 0x9e, /**< 4 channel unsigned normalized block-compressed (BC7 compression) format with sRGB encoding */ + CU_AD_FORMAT_P010 = 0x9f, /**< 10-bit YUV planar format, with 4:2:0 sampling */ + CU_AD_FORMAT_P016 = 0xa1, /**< 16-bit YUV planar format, with 4:2:0 sampling */ + CU_AD_FORMAT_NV16 = 0xa2, /**< 8-bit YUV planar format, with 4:2:2 sampling */ + CU_AD_FORMAT_P210 = 0xa3, /**< 10-bit YUV planar format, with 4:2:2 sampling */ + CU_AD_FORMAT_P216 = 0xa4, /**< 16-bit YUV planar format, with 4:2:2 sampling */ + CU_AD_FORMAT_YUY2 = 0xa5, /**< 2 channel, 8-bit YUV packed planar format, with 4:2:2 sampling */ + CU_AD_FORMAT_Y210 = 0xa6, /**< 2 channel, 10-bit YUV packed planar format, with 4:2:2 sampling */ + CU_AD_FORMAT_Y216 = 0xa7, /**< 2 channel, 16-bit YUV packed planar format, with 4:2:2 sampling */ + CU_AD_FORMAT_AYUV = 0xa8, /**< 4 channel, 8-bit YUV packed planar format, with 4:4:4 sampling */ + CU_AD_FORMAT_Y410 = 0xa9, /**< 10-bit YUV packed planar format, with 4:4:4 sampling */ + CU_AD_FORMAT_Y416 = 0xb1, /**< 4 channel, 12-bit YUV packed planar format, with 4:4:4 sampling */ + CU_AD_FORMAT_Y444_PLANAR8 = 0xb2, /**< 3 channel 8-bit YUV planar format, with 4:4:4 sampling */ + CU_AD_FORMAT_Y444_PLANAR10 = 0xb3, /**< 3 channel 10-bit YUV planar format, with 4:4:4 sampling */ + CU_AD_FORMAT_MAX = 0x7FFFFFFF +} CUarray_format; + +/** + * Texture reference addressing modes + */ +typedef enum CUaddress_mode_enum { + CU_TR_ADDRESS_MODE_WRAP = 0, /**< Wrapping address mode */ + CU_TR_ADDRESS_MODE_CLAMP = 1, /**< Clamp to edge address mode */ + CU_TR_ADDRESS_MODE_MIRROR = 2, /**< Mirror address mode */ + CU_TR_ADDRESS_MODE_BORDER = 3 /**< Border address mode */ +} CUaddress_mode; + +/** + * Texture reference filtering modes + */ +typedef enum CUfilter_mode_enum { + CU_TR_FILTER_MODE_POINT = 0, /**< Point filter mode */ + CU_TR_FILTER_MODE_LINEAR = 1 /**< Linear filter mode */ +} CUfilter_mode; + +/** + * Device properties + */ +typedef enum CUdevice_attribute_enum { + CU_DEVICE_ATTRIBUTE_MAX_THREADS_PER_BLOCK = 1, /**< Maximum number of threads per block */ + CU_DEVICE_ATTRIBUTE_MAX_BLOCK_DIM_X = 2, /**< Maximum block dimension X */ + CU_DEVICE_ATTRIBUTE_MAX_BLOCK_DIM_Y = 3, /**< Maximum block dimension Y */ + CU_DEVICE_ATTRIBUTE_MAX_BLOCK_DIM_Z = 4, /**< Maximum block dimension Z */ + CU_DEVICE_ATTRIBUTE_MAX_GRID_DIM_X = 5, /**< Maximum grid dimension X */ + CU_DEVICE_ATTRIBUTE_MAX_GRID_DIM_Y = 6, /**< Maximum grid dimension Y */ + CU_DEVICE_ATTRIBUTE_MAX_GRID_DIM_Z = 7, /**< Maximum grid dimension Z */ + CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK = 8, /**< Maximum shared memory available per block in bytes */ + CU_DEVICE_ATTRIBUTE_SHARED_MEMORY_PER_BLOCK = 8, /**< Deprecated, use CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK */ + CU_DEVICE_ATTRIBUTE_TOTAL_CONSTANT_MEMORY = 9, /**< Memory available on device for __constant__ variables in a CUDA C kernel in bytes */ + CU_DEVICE_ATTRIBUTE_WARP_SIZE = 10, /**< Warp size in threads */ + CU_DEVICE_ATTRIBUTE_MAX_PITCH = 11, /**< Maximum pitch in bytes allowed by memory copies */ + CU_DEVICE_ATTRIBUTE_MAX_REGISTERS_PER_BLOCK = 12, /**< Maximum number of 32-bit registers available per block */ + CU_DEVICE_ATTRIBUTE_REGISTERS_PER_BLOCK = 12, /**< Deprecated, use CU_DEVICE_ATTRIBUTE_MAX_REGISTERS_PER_BLOCK */ + CU_DEVICE_ATTRIBUTE_CLOCK_RATE = 13, /**< Typical clock frequency in kilohertz */ + CU_DEVICE_ATTRIBUTE_TEXTURE_ALIGNMENT = 14, /**< Alignment requirement for textures */ + CU_DEVICE_ATTRIBUTE_GPU_OVERLAP = 15, /**< Device can possibly copy memory and execute a kernel concurrently. Deprecated. Use instead CU_DEVICE_ATTRIBUTE_ASYNC_ENGINE_COUNT. */ + CU_DEVICE_ATTRIBUTE_MULTIPROCESSOR_COUNT = 16, /**< Number of multiprocessors on device */ + CU_DEVICE_ATTRIBUTE_KERNEL_EXEC_TIMEOUT = 17, /**< Specifies whether there is a run time limit on kernels */ + CU_DEVICE_ATTRIBUTE_INTEGRATED = 18, /**< Device is integrated with host memory */ + CU_DEVICE_ATTRIBUTE_CAN_MAP_HOST_MEMORY = 19, /**< Device can map host memory into CUDA address space */ + CU_DEVICE_ATTRIBUTE_COMPUTE_MODE = 20, /**< Compute mode (See ::CUcomputemode for details) */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_WIDTH = 21, /**< Maximum 1D texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_WIDTH = 22, /**< Maximum 2D texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_HEIGHT = 23, /**< Maximum 2D texture height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_WIDTH = 24, /**< Maximum 3D texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_HEIGHT = 25, /**< Maximum 3D texture height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_DEPTH = 26, /**< Maximum 3D texture depth */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_WIDTH = 27, /**< Maximum 2D layered texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_HEIGHT = 28, /**< Maximum 2D layered texture height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_LAYERS = 29, /**< Maximum layers in a 2D layered texture */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_ARRAY_WIDTH = 27, /**< Deprecated, use CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_WIDTH */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_ARRAY_HEIGHT = 28, /**< Deprecated, use CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_HEIGHT */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_ARRAY_NUMSLICES = 29, /**< Deprecated, use CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_LAYERS */ + CU_DEVICE_ATTRIBUTE_SURFACE_ALIGNMENT = 30, /**< Alignment requirement for surfaces */ + CU_DEVICE_ATTRIBUTE_CONCURRENT_KERNELS = 31, /**< Device can possibly execute multiple kernels concurrently */ + CU_DEVICE_ATTRIBUTE_ECC_ENABLED = 32, /**< Device has ECC support enabled */ + CU_DEVICE_ATTRIBUTE_PCI_BUS_ID = 33, /**< PCI bus ID of the device */ + CU_DEVICE_ATTRIBUTE_PCI_DEVICE_ID = 34, /**< PCI device ID of the device */ + CU_DEVICE_ATTRIBUTE_TCC_DRIVER = 35, /**< Device is using TCC driver model */ + CU_DEVICE_ATTRIBUTE_MEMORY_CLOCK_RATE = 36, /**< Peak memory clock frequency in kilohertz */ + CU_DEVICE_ATTRIBUTE_GLOBAL_MEMORY_BUS_WIDTH = 37, /**< Global memory bus width in bits */ + CU_DEVICE_ATTRIBUTE_L2_CACHE_SIZE = 38, /**< Size of L2 cache in bytes */ + CU_DEVICE_ATTRIBUTE_MAX_THREADS_PER_MULTIPROCESSOR = 39, /**< Maximum resident threads per multiprocessor */ + CU_DEVICE_ATTRIBUTE_ASYNC_ENGINE_COUNT = 40, /**< Number of asynchronous engines */ + CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING = 41, /**< Device shares a unified address space with the host */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LAYERED_WIDTH = 42, /**< Maximum 1D layered texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LAYERED_LAYERS = 43, /**< Maximum layers in a 1D layered texture */ + CU_DEVICE_ATTRIBUTE_CAN_TEX2D_GATHER = 44, /**< Deprecated, do not use. */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_GATHER_WIDTH = 45, /**< Maximum 2D texture width if CUDA_ARRAY3D_TEXTURE_GATHER is set */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_GATHER_HEIGHT = 46, /**< Maximum 2D texture height if CUDA_ARRAY3D_TEXTURE_GATHER is set */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_WIDTH_ALTERNATE = 47, /**< Alternate maximum 3D texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_HEIGHT_ALTERNATE = 48, /**< Alternate maximum 3D texture height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_DEPTH_ALTERNATE = 49, /**< Alternate maximum 3D texture depth */ + CU_DEVICE_ATTRIBUTE_PCI_DOMAIN_ID = 50, /**< PCI domain ID of the device */ + CU_DEVICE_ATTRIBUTE_TEXTURE_PITCH_ALIGNMENT = 51, /**< Pitch alignment requirement for textures */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURECUBEMAP_WIDTH = 52, /**< Maximum cubemap texture width/height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURECUBEMAP_LAYERED_WIDTH = 53, /**< Maximum cubemap layered texture width/height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURECUBEMAP_LAYERED_LAYERS = 54, /**< Maximum layers in a cubemap layered texture */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE1D_WIDTH = 55, /**< Maximum 1D surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_WIDTH = 56, /**< Maximum 2D surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_HEIGHT = 57, /**< Maximum 2D surface height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE3D_WIDTH = 58, /**< Maximum 3D surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE3D_HEIGHT = 59, /**< Maximum 3D surface height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE3D_DEPTH = 60, /**< Maximum 3D surface depth */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE1D_LAYERED_WIDTH = 61, /**< Maximum 1D layered surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE1D_LAYERED_LAYERS = 62, /**< Maximum layers in a 1D layered surface */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_LAYERED_WIDTH = 63, /**< Maximum 2D layered surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_LAYERED_HEIGHT = 64, /**< Maximum 2D layered surface height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_LAYERED_LAYERS = 65, /**< Maximum layers in a 2D layered surface */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACECUBEMAP_WIDTH = 66, /**< Maximum cubemap surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACECUBEMAP_LAYERED_WIDTH = 67, /**< Maximum cubemap layered surface width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACECUBEMAP_LAYERED_LAYERS = 68, /**< Maximum layers in a cubemap layered surface */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LINEAR_WIDTH = 69, /**< Deprecated, do not use. Use cudaDeviceGetTexture1DLinearMaxWidth() or cuDeviceGetTexture1DLinearMaxWidth() instead. */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_WIDTH = 70, /**< Maximum 2D linear texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_HEIGHT = 71, /**< Maximum 2D linear texture height */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_PITCH = 72, /**< Maximum 2D linear texture pitch in bytes */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_MIPMAPPED_WIDTH = 73, /**< Maximum mipmapped 2D texture width */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_MIPMAPPED_HEIGHT = 74, /**< Maximum mipmapped 2D texture height */ + CU_DEVICE_ATTRIBUTE_COMPUTE_CAPABILITY_MAJOR = 75, /**< Major compute capability version number */ + CU_DEVICE_ATTRIBUTE_COMPUTE_CAPABILITY_MINOR = 76, /**< Minor compute capability version number */ + CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_MIPMAPPED_WIDTH = 77, /**< Maximum mipmapped 1D texture width */ + CU_DEVICE_ATTRIBUTE_STREAM_PRIORITIES_SUPPORTED = 78, /**< Device supports stream priorities */ + CU_DEVICE_ATTRIBUTE_GLOBAL_L1_CACHE_SUPPORTED = 79, /**< Device supports caching globals in L1 */ + CU_DEVICE_ATTRIBUTE_LOCAL_L1_CACHE_SUPPORTED = 80, /**< Device supports caching locals in L1 */ + CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_MULTIPROCESSOR = 81, /**< Maximum shared memory available per multiprocessor in bytes */ + CU_DEVICE_ATTRIBUTE_MAX_REGISTERS_PER_MULTIPROCESSOR = 82, /**< Maximum number of 32-bit registers available per multiprocessor */ + CU_DEVICE_ATTRIBUTE_MANAGED_MEMORY = 83, /**< Device can allocate managed memory on this system */ + CU_DEVICE_ATTRIBUTE_MULTI_GPU_BOARD = 84, /**< Device is on a multi-GPU board */ + CU_DEVICE_ATTRIBUTE_MULTI_GPU_BOARD_GROUP_ID = 85, /**< Unique id for a group of devices on the same multi-GPU board */ + CU_DEVICE_ATTRIBUTE_HOST_NATIVE_ATOMIC_SUPPORTED = 86, /**< Link between the device and the host supports native atomic operations (this is a placeholder attribute, and is not supported on any current hardware)*/ + CU_DEVICE_ATTRIBUTE_SINGLE_TO_DOUBLE_PRECISION_PERF_RATIO = 87, /**< Ratio of single precision performance (in floating-point operations per second) to double precision performance */ + CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS = 88, /**< Device supports coherently accessing pageable memory without calling cudaHostRegister on it */ + CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS = 89, /**< Device can coherently access managed memory concurrently with the CPU */ + CU_DEVICE_ATTRIBUTE_COMPUTE_PREEMPTION_SUPPORTED = 90, /**< Device supports compute preemption. */ + CU_DEVICE_ATTRIBUTE_CAN_USE_HOST_POINTER_FOR_REGISTERED_MEM = 91, /**< Device can access host registered memory at the same virtual address as the CPU */ + CU_DEVICE_ATTRIBUTE_CAN_USE_STREAM_MEM_OPS_V1 = 92, /**< Deprecated, along with v1 MemOps API, ::cuStreamBatchMemOp and related APIs are supported. */ + CU_DEVICE_ATTRIBUTE_CAN_USE_64_BIT_STREAM_MEM_OPS_V1 = 93, /**< Deprecated, along with v1 MemOps API, 64-bit operations are supported in ::cuStreamBatchMemOp and related APIs. */ + CU_DEVICE_ATTRIBUTE_CAN_USE_STREAM_WAIT_VALUE_NOR_V1 = 94, /**< Deprecated, along with v1 MemOps API, ::CU_STREAM_WAIT_VALUE_NOR is supported. */ + CU_DEVICE_ATTRIBUTE_COOPERATIVE_LAUNCH = 95, /**< Device supports launching cooperative kernels via ::cuLaunchCooperativeKernel */ + CU_DEVICE_ATTRIBUTE_COOPERATIVE_MULTI_DEVICE_LAUNCH = 96, /**< Deprecated, ::cuLaunchCooperativeKernelMultiDevice is deprecated. */ + CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK_OPTIN = 97, /**< Maximum optin shared memory per block */ + CU_DEVICE_ATTRIBUTE_CAN_FLUSH_REMOTE_WRITES = 98, /**< The ::CU_STREAM_WAIT_VALUE_FLUSH flag and the ::CU_STREAM_MEM_OP_FLUSH_REMOTE_WRITES MemOp are supported on the device. See \ref CUDA_MEMOP for additional details. */ + CU_DEVICE_ATTRIBUTE_HOST_REGISTER_SUPPORTED = 99, /**< Device supports host memory registration via ::cudaHostRegister. */ + CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES = 100, /**< Device accesses pageable memory via the host's page tables. */ + CU_DEVICE_ATTRIBUTE_DIRECT_MANAGED_MEM_ACCESS_FROM_HOST = 101, /**< The host can directly access managed memory on the device without migration. */ + CU_DEVICE_ATTRIBUTE_VIRTUAL_ADDRESS_MANAGEMENT_SUPPORTED = 102, /**< Deprecated, Use CU_DEVICE_ATTRIBUTE_VIRTUAL_MEMORY_MANAGEMENT_SUPPORTED*/ + CU_DEVICE_ATTRIBUTE_VIRTUAL_MEMORY_MANAGEMENT_SUPPORTED = 102, /**< Device supports virtual memory management APIs like ::cuMemAddressReserve, ::cuMemCreate, ::cuMemMap and related APIs */ + CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_POSIX_FILE_DESCRIPTOR_SUPPORTED = 103, /**< Device supports exporting memory to a posix file descriptor with ::cuMemExportToShareableHandle, if requested via ::cuMemCreate */ + CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_WIN32_HANDLE_SUPPORTED = 104, /**< Device supports exporting memory to a Win32 NT handle with ::cuMemExportToShareableHandle, if requested via ::cuMemCreate */ + CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_WIN32_KMT_HANDLE_SUPPORTED = 105, /**< Device supports exporting memory to a Win32 KMT handle with ::cuMemExportToShareableHandle, if requested via ::cuMemCreate */ + CU_DEVICE_ATTRIBUTE_MAX_BLOCKS_PER_MULTIPROCESSOR = 106, /**< Maximum number of blocks per multiprocessor */ + CU_DEVICE_ATTRIBUTE_GENERIC_COMPRESSION_SUPPORTED = 107, /**< Device supports compression of memory */ + CU_DEVICE_ATTRIBUTE_MAX_PERSISTING_L2_CACHE_SIZE = 108, /**< Maximum L2 persisting lines capacity setting in bytes. */ + CU_DEVICE_ATTRIBUTE_MAX_ACCESS_POLICY_WINDOW_SIZE = 109, /**< Maximum value of CUaccessPolicyWindow::num_bytes. */ + CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_WITH_CUDA_VMM_SUPPORTED = 110, /**< Device supports specifying the GPUDirect RDMA flag with ::cuMemCreate */ + CU_DEVICE_ATTRIBUTE_RESERVED_SHARED_MEMORY_PER_BLOCK = 111, /**< Shared memory reserved by CUDA driver per block in bytes */ + CU_DEVICE_ATTRIBUTE_SPARSE_CUDA_ARRAY_SUPPORTED = 112, /**< Device supports sparse CUDA arrays and sparse CUDA mipmapped arrays */ + CU_DEVICE_ATTRIBUTE_READ_ONLY_HOST_REGISTER_SUPPORTED = 113, /**< Device supports using the ::cuMemHostRegister flag ::CU_MEMHOSTERGISTER_READ_ONLY to register memory that must be mapped as read-only to the GPU */ + CU_DEVICE_ATTRIBUTE_TIMELINE_SEMAPHORE_INTEROP_SUPPORTED = 114, /**< External timeline semaphore interop is supported on the device */ + CU_DEVICE_ATTRIBUTE_MEMORY_POOLS_SUPPORTED = 115, /**< Device supports using the ::cuMemAllocAsync and ::cuMemPool family of APIs */ + CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_SUPPORTED = 116, /**< Device supports GPUDirect RDMA APIs, like nvidia_p2p_get_pages (see https://docs.nvidia.com/cuda/gpudirect-rdma for more information) */ + CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_FLUSH_WRITES_OPTIONS = 117, /**< The returned attribute shall be interpreted as a bitmask, where the individual bits are described by the ::CUflushGPUDirectRDMAWritesOptions enum */ + CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_WRITES_ORDERING = 118, /**< GPUDirect RDMA writes to the device do not need to be flushed for consumers within the scope indicated by the returned attribute. See ::CUGPUDirectRDMAWritesOrdering for the numerical values returned here. */ + CU_DEVICE_ATTRIBUTE_MEMPOOL_SUPPORTED_HANDLE_TYPES = 119, /**< Handle types supported with mempool based IPC */ + CU_DEVICE_ATTRIBUTE_CLUSTER_LAUNCH = 120, /**< Indicates device supports cluster launch */ + CU_DEVICE_ATTRIBUTE_DEFERRED_MAPPING_CUDA_ARRAY_SUPPORTED = 121, /**< Device supports deferred mapping CUDA arrays and CUDA mipmapped arrays */ + CU_DEVICE_ATTRIBUTE_CAN_USE_64_BIT_STREAM_MEM_OPS = 122, /**< 64-bit operations are supported in ::cuStreamBatchMemOp and related MemOp APIs. */ + CU_DEVICE_ATTRIBUTE_CAN_USE_STREAM_WAIT_VALUE_NOR = 123, /**< ::CU_STREAM_WAIT_VALUE_NOR is supported by MemOp APIs. */ + CU_DEVICE_ATTRIBUTE_DMA_BUF_SUPPORTED = 124, /**< Device supports buffer sharing with dma_buf mechanism. */ + CU_DEVICE_ATTRIBUTE_IPC_EVENT_SUPPORTED = 125, /**< Device supports IPC Events. */ + CU_DEVICE_ATTRIBUTE_MEM_SYNC_DOMAIN_COUNT = 126, /**< Number of memory domains the device supports. */ + CU_DEVICE_ATTRIBUTE_TENSOR_MAP_ACCESS_SUPPORTED = 127, /**< Device supports accessing memory using Tensor Map. */ + CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_FABRIC_SUPPORTED = 128, /**< Device supports exporting memory to a fabric handle with cuMemExportToShareableHandle() or requested with cuMemCreate() */ + CU_DEVICE_ATTRIBUTE_UNIFIED_FUNCTION_POINTERS = 129, /**< Device supports unified function pointers. */ + CU_DEVICE_ATTRIBUTE_NUMA_CONFIG = 130, /**< NUMA configuration of a device: value is of type ::CUdeviceNumaConfig enum */ + CU_DEVICE_ATTRIBUTE_NUMA_ID = 131, /**< NUMA node ID of the GPU memory */ + CU_DEVICE_ATTRIBUTE_MULTICAST_SUPPORTED = 132, /**< Device supports switch multicast and reduction operations. */ + CU_DEVICE_ATTRIBUTE_MPS_ENABLED = 133, /**< Indicates if contexts created on this device will be shared via MPS */ + CU_DEVICE_ATTRIBUTE_HOST_NUMA_ID = 134, /**< NUMA ID of the host node closest to the device. Returns -1 when system does not support NUMA. */ + CU_DEVICE_ATTRIBUTE_D3D12_CIG_SUPPORTED = 135, /**< Device supports CIG with D3D12. */ + CU_DEVICE_ATTRIBUTE_MAX +} CUdevice_attribute; + +/** + * Legacy device properties + */ +typedef struct CUdevprop_st { + int maxThreadsPerBlock; /**< Maximum number of threads per block */ + int maxThreadsDim[3]; /**< Maximum size of each dimension of a block */ + int maxGridSize[3]; /**< Maximum size of each dimension of a grid */ + int sharedMemPerBlock; /**< Shared memory available per block in bytes */ + int totalConstantMemory; /**< Constant memory available on device in bytes */ + int SIMDWidth; /**< Warp size in threads */ + int memPitch; /**< Maximum pitch in bytes allowed by memory copies */ + int regsPerBlock; /**< 32-bit registers available per block */ + int clockRate; /**< Clock frequency in kilohertz */ + int textureAlign; /**< Alignment requirement for textures */ +} CUdevprop_v1; +typedef CUdevprop_v1 CUdevprop; + +/** + * Pointer information + */ +typedef enum CUpointer_attribute_enum { + CU_POINTER_ATTRIBUTE_CONTEXT = 1, /**< The ::CUcontext on which a pointer was allocated or registered */ + CU_POINTER_ATTRIBUTE_MEMORY_TYPE = 2, /**< The ::CUmemorytype describing the physical location of a pointer */ + CU_POINTER_ATTRIBUTE_DEVICE_POINTER = 3, /**< The address at which a pointer's memory may be accessed on the device */ + CU_POINTER_ATTRIBUTE_HOST_POINTER = 4, /**< The address at which a pointer's memory may be accessed on the host */ + CU_POINTER_ATTRIBUTE_P2P_TOKENS = 5, /**< A pair of tokens for use with the nv-p2p.h Linux kernel interface */ + CU_POINTER_ATTRIBUTE_SYNC_MEMOPS = 6, /**< Synchronize every synchronous memory operation initiated on this region */ + CU_POINTER_ATTRIBUTE_BUFFER_ID = 7, /**< A process-wide unique ID for an allocated memory region*/ + CU_POINTER_ATTRIBUTE_IS_MANAGED = 8, /**< Indicates if the pointer points to managed memory */ + CU_POINTER_ATTRIBUTE_DEVICE_ORDINAL = 9, /**< A device ordinal of a device on which a pointer was allocated or registered */ + CU_POINTER_ATTRIBUTE_IS_LEGACY_CUDA_IPC_CAPABLE = 10, /**< 1 if this pointer maps to an allocation that is suitable for ::cudaIpcGetMemHandle, 0 otherwise **/ + CU_POINTER_ATTRIBUTE_RANGE_START_ADDR = 11, /**< Starting address for this requested pointer */ + CU_POINTER_ATTRIBUTE_RANGE_SIZE = 12, /**< Size of the address range for this requested pointer */ + CU_POINTER_ATTRIBUTE_MAPPED = 13, /**< 1 if this pointer is in a valid address range that is mapped to a backing allocation, 0 otherwise **/ + CU_POINTER_ATTRIBUTE_ALLOWED_HANDLE_TYPES = 14, /**< Bitmask of allowed ::CUmemAllocationHandleType for this allocation **/ + CU_POINTER_ATTRIBUTE_IS_GPU_DIRECT_RDMA_CAPABLE = 15, /**< 1 if the memory this pointer is referencing can be used with the GPUDirect RDMA API **/ + CU_POINTER_ATTRIBUTE_ACCESS_FLAGS = 16, /**< Returns the access flags the device associated with the current context has on the corresponding memory referenced by the pointer given */ + CU_POINTER_ATTRIBUTE_MEMPOOL_HANDLE = 17, /**< Returns the mempool handle for the allocation if it was allocated from a mempool. Otherwise returns NULL. **/ + CU_POINTER_ATTRIBUTE_MAPPING_SIZE = 18, /**< Size of the actual underlying mapping that the pointer belongs to **/ + CU_POINTER_ATTRIBUTE_MAPPING_BASE_ADDR = 19, /**< The start address of the mapping that the pointer belongs to **/ + CU_POINTER_ATTRIBUTE_MEMORY_BLOCK_ID = 20 /**< A process-wide unique id corresponding to the physical allocation the pointer belongs to **/ +} CUpointer_attribute; + +/** + * Function properties + */ +typedef enum CUfunction_attribute_enum { + /** + * The maximum number of threads per block, beyond which a launch of the + * function would fail. This number depends on both the function and the + * device on which the function is currently loaded. + */ + CU_FUNC_ATTRIBUTE_MAX_THREADS_PER_BLOCK = 0, + + /** + * The size in bytes of statically-allocated shared memory required by + * this function. This does not include dynamically-allocated shared + * memory requested by the user at runtime. + */ + CU_FUNC_ATTRIBUTE_SHARED_SIZE_BYTES = 1, + + /** + * The size in bytes of user-allocated constant memory required by this + * function. + */ + CU_FUNC_ATTRIBUTE_CONST_SIZE_BYTES = 2, + + /** + * The size in bytes of local memory used by each thread of this function. + */ + CU_FUNC_ATTRIBUTE_LOCAL_SIZE_BYTES = 3, + + /** + * The number of registers used by each thread of this function. + */ + CU_FUNC_ATTRIBUTE_NUM_REGS = 4, + + /** + * The PTX virtual architecture version for which the function was + * compiled. This value is the major PTX version * 10 + the minor PTX + * version, so a PTX version 1.3 function would return the value 13. + * Note that this may return the undefined value of 0 for cubins + * compiled prior to CUDA 3.0. + */ + CU_FUNC_ATTRIBUTE_PTX_VERSION = 5, + + /** + * The binary architecture version for which the function was compiled. + * This value is the major binary version * 10 + the minor binary version, + * so a binary version 1.3 function would return the value 13. Note that + * this will return a value of 10 for legacy cubins that do not have a + * properly-encoded binary architecture version. + */ + CU_FUNC_ATTRIBUTE_BINARY_VERSION = 6, + + /** + * The attribute to indicate whether the function has been compiled with + * user specified option "-Xptxas --dlcm=ca" set . + */ + CU_FUNC_ATTRIBUTE_CACHE_MODE_CA = 7, + + /** + * The maximum size in bytes of dynamically-allocated shared memory that can be used by + * this function. If the user-specified dynamic shared memory size is larger than this + * value, the launch will fail. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES = 8, + + /** + * On devices where the L1 cache and shared memory use the same hardware resources, + * this sets the shared memory carveout preference, in percent of the total shared memory. + * Refer to ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_MULTIPROCESSOR. + * This is only a hint, and the driver can choose a different ratio if required to execute the function. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT = 9, + + /** + * If this attribute is set, the kernel must launch with a valid cluster + * size specified. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_CLUSTER_SIZE_MUST_BE_SET = 10, + + /** + * The required cluster width in blocks. The values must either all be 0 or + * all be positive. The validity of the cluster dimensions is otherwise + * checked at launch time. + * + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_WIDTH = 11, + + /** + * The required cluster height in blocks. The values must either all be 0 or + * all be positive. The validity of the cluster dimensions is otherwise + * checked at launch time. + * + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime should return CUDA_ERROR_NOT_PERMITTED. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_HEIGHT = 12, + + /** + * The required cluster depth in blocks. The values must either all be 0 or + * all be positive. The validity of the cluster dimensions is otherwise + * checked at launch time. + * + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime should return CUDA_ERROR_NOT_PERMITTED. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_DEPTH = 13, + + /** + * Whether the function can be launched with non-portable cluster size. 1 is + * allowed, 0 is disallowed. A non-portable cluster size may only function + * on the specific SKUs the program is tested on. The launch might fail if + * the program is run on a different hardware platform. + * + * CUDA API provides cudaOccupancyMaxActiveClusters to assist with checking + * whether the desired size can be launched on the current device. + * + * Portable Cluster Size + * + * A portable cluster size is guaranteed to be functional on all compute + * capabilities higher than the target compute capability. The portable + * cluster size for sm_90 is 8 blocks per cluster. This value may increase + * for future compute capabilities. + * + * The specific hardware unit may support higher cluster sizes that’s not + * guaranteed to be portable. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_NON_PORTABLE_CLUSTER_SIZE_ALLOWED = 14, + + /** + * The block scheduling policy of a function. The value type is + * CUclusterSchedulingPolicy / cudaClusterSchedulingPolicy. + * See ::cuFuncSetAttribute, ::cuKernelSetAttribute + */ + CU_FUNC_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE = 15, + + CU_FUNC_ATTRIBUTE_MAX +} CUfunction_attribute; + +/** + * Function cache configurations + */ +typedef enum CUfunc_cache_enum { + CU_FUNC_CACHE_PREFER_NONE = 0x00, /**< no preference for shared memory or L1 (default) */ + CU_FUNC_CACHE_PREFER_SHARED = 0x01, /**< prefer larger shared memory and smaller L1 cache */ + CU_FUNC_CACHE_PREFER_L1 = 0x02, /**< prefer larger L1 cache and smaller shared memory */ + CU_FUNC_CACHE_PREFER_EQUAL = 0x03 /**< prefer equal sized L1 cache and shared memory */ +} CUfunc_cache; + +/** + * \deprecated + * + * Shared memory configurations + */ +typedef enum CUsharedconfig_enum { + CU_SHARED_MEM_CONFIG_DEFAULT_BANK_SIZE = 0x00, /**< set default shared memory bank size */ + CU_SHARED_MEM_CONFIG_FOUR_BYTE_BANK_SIZE = 0x01, /**< set shared memory bank width to four bytes */ + CU_SHARED_MEM_CONFIG_EIGHT_BYTE_BANK_SIZE = 0x02 /**< set shared memory bank width to eight bytes */ +} CUsharedconfig; + +/** + * Shared memory carveout configurations. These may be passed to ::cuFuncSetAttribute or ::cuKernelSetAttribute + */ +typedef enum CUshared_carveout_enum { + CU_SHAREDMEM_CARVEOUT_DEFAULT = -1, /**< No preference for shared memory or L1 (default) */ + CU_SHAREDMEM_CARVEOUT_MAX_SHARED = 100, /**< Prefer maximum available shared memory, minimum L1 cache */ + CU_SHAREDMEM_CARVEOUT_MAX_L1 = 0 /**< Prefer maximum available L1 cache, minimum shared memory */ +} CUshared_carveout; + +/** + * Memory types + */ +typedef enum CUmemorytype_enum { + CU_MEMORYTYPE_HOST = 0x01, /**< Host memory */ + CU_MEMORYTYPE_DEVICE = 0x02, /**< Device memory */ + CU_MEMORYTYPE_ARRAY = 0x03, /**< Array memory */ + CU_MEMORYTYPE_UNIFIED = 0x04 /**< Unified device or host memory */ +} CUmemorytype; + +/** + * Compute Modes + */ +typedef enum CUcomputemode_enum { + CU_COMPUTEMODE_DEFAULT = 0, /**< Default compute mode (Multiple contexts allowed per device) */ + CU_COMPUTEMODE_PROHIBITED = 2, /**< Compute-prohibited mode (No contexts can be created on this device at this time) */ + CU_COMPUTEMODE_EXCLUSIVE_PROCESS = 3 /**< Compute-exclusive-process mode (Only one context used by a single process can be present on this device at a time) */ +} CUcomputemode; + +/** + * Memory advise values + */ +typedef enum CUmem_advise_enum { + CU_MEM_ADVISE_SET_READ_MOSTLY = 1, /**< Data will mostly be read and only occasionally be written to */ + CU_MEM_ADVISE_UNSET_READ_MOSTLY = 2, /**< Undo the effect of ::CU_MEM_ADVISE_SET_READ_MOSTLY */ + CU_MEM_ADVISE_SET_PREFERRED_LOCATION = 3, /**< Set the preferred location for the data as the specified device */ + CU_MEM_ADVISE_UNSET_PREFERRED_LOCATION = 4, /**< Clear the preferred location for the data */ + CU_MEM_ADVISE_SET_ACCESSED_BY = 5, /**< Data will be accessed by the specified device, so prevent page faults as much as possible */ + CU_MEM_ADVISE_UNSET_ACCESSED_BY = 6 /**< Let the Unified Memory subsystem decide on the page faulting policy for the specified device */ +} CUmem_advise; + +typedef enum CUmem_range_attribute_enum { + CU_MEM_RANGE_ATTRIBUTE_READ_MOSTLY = 1, /**< Whether the range will mostly be read and only occasionally be written to */ + CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION = 2, /**< The preferred location of the range */ + CU_MEM_RANGE_ATTRIBUTE_ACCESSED_BY = 3, /**< Memory range has ::CU_MEM_ADVISE_SET_ACCESSED_BY set for specified device */ + CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION = 4 /**< The last location to which the range was prefetched */ + , CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_TYPE = 5 /**< The preferred location type of the range */ + , CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_ID = 6 /**< The preferred location id of the range */ + , CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_TYPE = 7 /**< The last location type to which the range was prefetched */ + , CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_ID = 8 /**< The last location id to which the range was prefetched */ +} CUmem_range_attribute; + +/** + * Online compiler and linker options + */ +typedef enum CUjit_option_enum +{ + /** + * Max number of registers that a thread may use.\n + * Option type: unsigned int\n + * Applies to: compiler only + */ + CU_JIT_MAX_REGISTERS = 0, + + /** + * IN: Specifies minimum number of threads per block to target compilation + * for\n + * OUT: Returns the number of threads the compiler actually targeted. + * This restricts the resource utilization of the compiler (e.g. max + * registers) such that a block with the given number of threads should be + * able to launch based on register limitations. Note, this option does not + * currently take into account any other resource limitations, such as + * shared memory utilization.\n + * Cannot be combined with ::CU_JIT_TARGET.\n + * Option type: unsigned int\n + * Applies to: compiler only + */ + CU_JIT_THREADS_PER_BLOCK = 1, + + /** + * Overwrites the option value with the total wall clock time, in + * milliseconds, spent in the compiler and linker\n + * Option type: float\n + * Applies to: compiler and linker + */ + CU_JIT_WALL_TIME = 2, + + /** + * Pointer to a buffer in which to print any log messages + * that are informational in nature (the buffer size is specified via + * option ::CU_JIT_INFO_LOG_BUFFER_SIZE_BYTES)\n + * Option type: char *\n + * Applies to: compiler and linker + */ + CU_JIT_INFO_LOG_BUFFER = 3, + + /** + * IN: Log buffer size in bytes. Log messages will be capped at this size + * (including null terminator)\n + * OUT: Amount of log buffer filled with messages\n + * Option type: unsigned int\n + * Applies to: compiler and linker + */ + CU_JIT_INFO_LOG_BUFFER_SIZE_BYTES = 4, + + /** + * Pointer to a buffer in which to print any log messages that + * reflect errors (the buffer size is specified via option + * ::CU_JIT_ERROR_LOG_BUFFER_SIZE_BYTES)\n + * Option type: char *\n + * Applies to: compiler and linker + */ + CU_JIT_ERROR_LOG_BUFFER = 5, + + /** + * IN: Log buffer size in bytes. Log messages will be capped at this size + * (including null terminator)\n + * OUT: Amount of log buffer filled with messages\n + * Option type: unsigned int\n + * Applies to: compiler and linker + */ + CU_JIT_ERROR_LOG_BUFFER_SIZE_BYTES = 6, + + /** + * Level of optimizations to apply to generated code (0 - 4), with 4 + * being the default and highest level of optimizations.\n + * Option type: unsigned int\n + * Applies to: compiler only + */ + CU_JIT_OPTIMIZATION_LEVEL = 7, + + /** + * No option value required. Determines the target based on the current + * attached context (default)\n + * Option type: No option value needed\n + * Applies to: compiler and linker + */ + CU_JIT_TARGET_FROM_CUCONTEXT = 8, + + /** + * Target is chosen based on supplied ::CUjit_target. Cannot be + * combined with ::CU_JIT_THREADS_PER_BLOCK.\n + * Option type: unsigned int for enumerated type ::CUjit_target\n + * Applies to: compiler and linker + */ + CU_JIT_TARGET = 9, + + /** + * Specifies choice of fallback strategy if matching cubin is not found. + * Choice is based on supplied ::CUjit_fallback. This option cannot be + * used with cuLink* APIs as the linker requires exact matches.\n + * Option type: unsigned int for enumerated type ::CUjit_fallback\n + * Applies to: compiler only + */ + CU_JIT_FALLBACK_STRATEGY = 10, + + /** + * Specifies whether to create debug information in output (-g) + * (0: false, default)\n + * Option type: int\n + * Applies to: compiler and linker + */ + CU_JIT_GENERATE_DEBUG_INFO = 11, + + /** + * Generate verbose log messages (0: false, default)\n + * Option type: int\n + * Applies to: compiler and linker + */ + CU_JIT_LOG_VERBOSE = 12, + + /** + * Generate line number information (-lineinfo) (0: false, default)\n + * Option type: int\n + * Applies to: compiler only + */ + CU_JIT_GENERATE_LINE_INFO = 13, + + /** + * Specifies whether to enable caching explicitly (-dlcm) \n + * Choice is based on supplied ::CUjit_cacheMode_enum.\n + * Option type: unsigned int for enumerated type ::CUjit_cacheMode_enum\n + * Applies to: compiler only + */ + CU_JIT_CACHE_MODE = 14, + + /** + * \deprecated + * This jit option is deprecated and should not be used. + */ + CU_JIT_NEW_SM3X_OPT = 15, + + /** + * This jit option is used for internal purpose only. + */ + CU_JIT_FAST_COMPILE = 16, + + /** + * Array of device symbol names that will be relocated to the corresponding + * host addresses stored in ::CU_JIT_GLOBAL_SYMBOL_ADDRESSES.\n + * Must contain ::CU_JIT_GLOBAL_SYMBOL_COUNT entries.\n + * When loading a device module, driver will relocate all encountered + * unresolved symbols to the host addresses.\n + * It is only allowed to register symbols that correspond to unresolved + * global variables.\n + * It is illegal to register the same device symbol at multiple addresses.\n + * Option type: const char **\n + * Applies to: dynamic linker only + */ + CU_JIT_GLOBAL_SYMBOL_NAMES = 17, + + /** + * Array of host addresses that will be used to relocate corresponding + * device symbols stored in ::CU_JIT_GLOBAL_SYMBOL_NAMES.\n + * Must contain ::CU_JIT_GLOBAL_SYMBOL_COUNT entries.\n + * Option type: void **\n + * Applies to: dynamic linker only + */ + CU_JIT_GLOBAL_SYMBOL_ADDRESSES = 18, + + /** + * Number of entries in ::CU_JIT_GLOBAL_SYMBOL_NAMES and + * ::CU_JIT_GLOBAL_SYMBOL_ADDRESSES arrays.\n + * Option type: unsigned int\n + * Applies to: dynamic linker only + */ + CU_JIT_GLOBAL_SYMBOL_COUNT = 19, + + /** + * \deprecated + * Enable link-time optimization (-dlto) for device code (Disabled by default).\n + * This option is not supported on 32-bit platforms.\n + * Option type: int\n + * Applies to: compiler and linker + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_LTO = 20, + + /** + * \deprecated + * Control single-precision denormals (-ftz) support (0: false, default). + * 1 : flushes denormal values to zero + * 0 : preserves denormal values + * Option type: int\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_FTZ = 21, + + /** + * \deprecated + * Control single-precision floating-point division and reciprocals + * (-prec-div) support (1: true, default). + * 1 : Enables the IEEE round-to-nearest mode + * 0 : Enables the fast approximation mode + * Option type: int\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_PREC_DIV = 22, + + /** + * \deprecated + * Control single-precision floating-point square root + * (-prec-sqrt) support (1: true, default). + * 1 : Enables the IEEE round-to-nearest mode + * 0 : Enables the fast approximation mode + * Option type: int\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_PREC_SQRT = 23, + + /** + * \deprecated + * Enable/Disable the contraction of floating-point multiplies + * and adds/subtracts into floating-point multiply-add (-fma) + * operations (1: Enable, default; 0: Disable). + * Option type: int\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_FMA = 24, + + /** + * \deprecated + * Array of kernel names that should be preserved at link time while others + * can be removed.\n + * Must contain ::CU_JIT_REFERENCED_KERNEL_COUNT entries.\n + * Note that kernel names can be mangled by the compiler in which case the + * mangled name needs to be specified.\n + * Wildcard "*" can be used to represent zero or more characters instead of + * specifying the full or mangled name.\n + * It is important to note that the wildcard "*" is also added implicitly. + * For example, specifying "foo" will match "foobaz", "barfoo", "barfoobaz" and + * thus preserve all kernels with those names. This can be avoided by providing + * a more specific name like "barfoobaz".\n + * Option type: const char **\n + * Applies to: dynamic linker only + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_REFERENCED_KERNEL_NAMES = 25, + + /** + * \deprecated + * Number of entries in ::CU_JIT_REFERENCED_KERNEL_NAMES array.\n + * Option type: unsigned int\n + * Applies to: dynamic linker only + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_REFERENCED_KERNEL_COUNT = 26, + + /** + * \deprecated + * Array of variable names (__device__ and/or __constant__) that should be + * preserved at link time while others can be removed.\n + * Must contain ::CU_JIT_REFERENCED_VARIABLE_COUNT entries.\n + * Note that variable names can be mangled by the compiler in which case the + * mangled name needs to be specified.\n + * Wildcard "*" can be used to represent zero or more characters instead of + * specifying the full or mangled name.\n + * It is important to note that the wildcard "*" is also added implicitly. + * For example, specifying "foo" will match "foobaz", "barfoo", "barfoobaz" and + * thus preserve all variables with those names. This can be avoided by providing + * a more specific name like "barfoobaz".\n + * Option type: const char **\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_REFERENCED_VARIABLE_NAMES = 27, + + /** + * \deprecated + * Number of entries in ::CU_JIT_REFERENCED_VARIABLE_NAMES array.\n + * Option type: unsigned int\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_REFERENCED_VARIABLE_COUNT = 28, + + /** + * \deprecated + * This option serves as a hint to enable the JIT compiler/linker + * to remove constant (__constant__) and device (__device__) variables + * unreferenced in device code (Disabled by default).\n + * Note that host references to constant and device variables using APIs like + * ::cuModuleGetGlobal() with this option specified may result in undefined behavior unless + * the variables are explicitly specified using ::CU_JIT_REFERENCED_VARIABLE_NAMES.\n + * Option type: int\n + * Applies to: link-time optimization specified with CU_JIT_LTO + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_OPTIMIZE_UNUSED_DEVICE_VARIABLES = 29, + + /** + * Generate position independent code (0: false)\n + * Option type: int\n + * Applies to: compiler only + */ + CU_JIT_POSITION_INDEPENDENT_CODE = 30, + + /** + * This option hints to the JIT compiler the minimum number of CTAs from the + * kernel’s grid to be mapped to a SM. This option is ignored when used together + * with ::CU_JIT_MAX_REGISTERS or ::CU_JIT_THREADS_PER_BLOCK. + * Optimizations based on this option need ::CU_JIT_MAX_THREADS_PER_BLOCK to + * be specified as well. For kernels already using PTX directive .minnctapersm, + * this option will be ignored by default. Use ::CU_JIT_OVERRIDE_DIRECTIVE_VALUES + * to let this option take precedence over the PTX directive. + * Option type: unsigned int\n + * Applies to: compiler only + */ + CU_JIT_MIN_CTA_PER_SM = 31, + + /** + * Maximum number threads in a thread block, computed as the product of + * the maximum extent specifed for each dimension of the block. This limit + * is guaranteed not to be exeeded in any invocation of the kernel. Exceeding + * the the maximum number of threads results in runtime error or kernel launch + * failure. For kernels already using PTX directive .maxntid, this option will + * be ignored by default. Use ::CU_JIT_OVERRIDE_DIRECTIVE_VALUES to let this + * option take precedence over the PTX directive. + * Option type: int\n + * Applies to: compiler only + */ + CU_JIT_MAX_THREADS_PER_BLOCK = 32, + + /** + * This option lets the values specified using ::CU_JIT_MAX_REGISTERS, + * ::CU_JIT_THREADS_PER_BLOCK, ::CU_JIT_MAX_THREADS_PER_BLOCK and + * ::CU_JIT_MIN_CTA_PER_SM take precedence over any PTX directives. + * (0: Disable, default; 1: Enable) + * Option type: int\n + * Applies to: compiler only + */ + CU_JIT_OVERRIDE_DIRECTIVE_VALUES = 33, + CU_JIT_NUM_OPTIONS + +} CUjit_option; + +/* + * Indicates that compute device class supports accelerated features. + */ +#define CU_COMPUTE_ACCELERATED_TARGET_BASE 0x10000 + +/** + * Online compilation targets + */ +typedef enum CUjit_target_enum +{ + CU_TARGET_COMPUTE_30 = 30, /**< Compute device class 3.0 */ + CU_TARGET_COMPUTE_32 = 32, /**< Compute device class 3.2 */ + CU_TARGET_COMPUTE_35 = 35, /**< Compute device class 3.5 */ + CU_TARGET_COMPUTE_37 = 37, /**< Compute device class 3.7 */ + CU_TARGET_COMPUTE_50 = 50, /**< Compute device class 5.0 */ + CU_TARGET_COMPUTE_52 = 52, /**< Compute device class 5.2 */ + CU_TARGET_COMPUTE_53 = 53, /**< Compute device class 5.3 */ + CU_TARGET_COMPUTE_60 = 60, /**< Compute device class 6.0.*/ + CU_TARGET_COMPUTE_61 = 61, /**< Compute device class 6.1.*/ + CU_TARGET_COMPUTE_62 = 62, /**< Compute device class 6.2.*/ + CU_TARGET_COMPUTE_70 = 70, /**< Compute device class 7.0.*/ + CU_TARGET_COMPUTE_72 = 72, /**< Compute device class 7.2.*/ + CU_TARGET_COMPUTE_75 = 75, /**< Compute device class 7.5.*/ + CU_TARGET_COMPUTE_80 = 80, /**< Compute device class 8.0.*/ + CU_TARGET_COMPUTE_86 = 86, /**< Compute device class 8.6.*/ + CU_TARGET_COMPUTE_87 = 87, /**< Compute device class 8.7.*/ + CU_TARGET_COMPUTE_89 = 89, /**< Compute device class 8.9.*/ + CU_TARGET_COMPUTE_90 = 90, /**< Compute device class 9.0.*/ + + /**< Compute device class 9.0. with accelerated features.*/ + CU_TARGET_COMPUTE_90A = CU_COMPUTE_ACCELERATED_TARGET_BASE + CU_TARGET_COMPUTE_90, +} CUjit_target; + +/** + * Cubin matching fallback strategies + */ +typedef enum CUjit_fallback_enum +{ + CU_PREFER_PTX = 0, /**< Prefer to compile ptx if exact binary match not found */ + + CU_PREFER_BINARY /**< Prefer to fall back to compatible binary code if exact match not found */ + +} CUjit_fallback; + +/** + * Caching modes for dlcm + */ +typedef enum CUjit_cacheMode_enum +{ + CU_JIT_CACHE_OPTION_NONE = 0, /**< Compile with no -dlcm flag specified */ + CU_JIT_CACHE_OPTION_CG, /**< Compile with L1 cache disabled */ + CU_JIT_CACHE_OPTION_CA /**< Compile with L1 cache enabled */ +} CUjit_cacheMode; + +/** + * Device code formats + */ +typedef enum CUjitInputType_enum +{ + /** + * Compiled device-class-specific device code\n + * Applicable options: none + */ + CU_JIT_INPUT_CUBIN = 0, + + /** + * PTX source code\n + * Applicable options: PTX compiler options + */ + CU_JIT_INPUT_PTX = 1, + + /** + * Bundle of multiple cubins and/or PTX of some device code\n + * Applicable options: PTX compiler options, ::CU_JIT_FALLBACK_STRATEGY + */ + CU_JIT_INPUT_FATBINARY = 2, + + /** + * Host object with embedded device code\n + * Applicable options: PTX compiler options, ::CU_JIT_FALLBACK_STRATEGY + */ + CU_JIT_INPUT_OBJECT = 3, + + /** + * Archive of host objects with embedded device code\n + * Applicable options: PTX compiler options, ::CU_JIT_FALLBACK_STRATEGY + */ + CU_JIT_INPUT_LIBRARY = 4, + + /** + * \deprecated + * High-level intermediate code for link-time optimization\n + * Applicable options: NVVM compiler options, PTX compiler options + * + * Only valid with LTO-IR compiled with toolkits prior to CUDA 12.0 + */ + CU_JIT_INPUT_NVVM = 5, + + CU_JIT_NUM_INPUT_TYPES = 6 +} CUjitInputType; + +typedef struct CUlinkState_st *CUlinkState; + +/** + * Flags to register a graphics resource + */ +typedef enum CUgraphicsRegisterFlags_enum { + CU_GRAPHICS_REGISTER_FLAGS_NONE = 0x00, + CU_GRAPHICS_REGISTER_FLAGS_READ_ONLY = 0x01, + CU_GRAPHICS_REGISTER_FLAGS_WRITE_DISCARD = 0x02, + CU_GRAPHICS_REGISTER_FLAGS_SURFACE_LDST = 0x04, + CU_GRAPHICS_REGISTER_FLAGS_TEXTURE_GATHER = 0x08 +} CUgraphicsRegisterFlags; + +/** + * Flags for mapping and unmapping interop resources + */ +typedef enum CUgraphicsMapResourceFlags_enum { + CU_GRAPHICS_MAP_RESOURCE_FLAGS_NONE = 0x00, + CU_GRAPHICS_MAP_RESOURCE_FLAGS_READ_ONLY = 0x01, + CU_GRAPHICS_MAP_RESOURCE_FLAGS_WRITE_DISCARD = 0x02 +} CUgraphicsMapResourceFlags; + +/** + * Array indices for cube faces + */ +typedef enum CUarray_cubemap_face_enum { + CU_CUBEMAP_FACE_POSITIVE_X = 0x00, /**< Positive X face of cubemap */ + CU_CUBEMAP_FACE_NEGATIVE_X = 0x01, /**< Negative X face of cubemap */ + CU_CUBEMAP_FACE_POSITIVE_Y = 0x02, /**< Positive Y face of cubemap */ + CU_CUBEMAP_FACE_NEGATIVE_Y = 0x03, /**< Negative Y face of cubemap */ + CU_CUBEMAP_FACE_POSITIVE_Z = 0x04, /**< Positive Z face of cubemap */ + CU_CUBEMAP_FACE_NEGATIVE_Z = 0x05 /**< Negative Z face of cubemap */ +} CUarray_cubemap_face; + +/** + * Limits + */ +typedef enum CUlimit_enum { + CU_LIMIT_STACK_SIZE = 0x00, /**< GPU thread stack size */ + CU_LIMIT_PRINTF_FIFO_SIZE = 0x01, /**< GPU printf FIFO size */ + CU_LIMIT_MALLOC_HEAP_SIZE = 0x02, /**< GPU malloc heap size */ + CU_LIMIT_DEV_RUNTIME_SYNC_DEPTH = 0x03, /**< GPU device runtime launch synchronize depth */ + CU_LIMIT_DEV_RUNTIME_PENDING_LAUNCH_COUNT = 0x04, /**< GPU device runtime pending launch count */ + CU_LIMIT_MAX_L2_FETCH_GRANULARITY = 0x05, /**< A value between 0 and 128 that indicates the maximum fetch granularity of L2 (in Bytes). This is a hint */ + CU_LIMIT_PERSISTING_L2_CACHE_SIZE = 0x06, /**< A size in bytes for L2 persisting lines cache size */ + CU_LIMIT_SHMEM_SIZE = 0x07, /**< A maximum size in bytes of shared memory available to CUDA kernels on a CIG context. Can only be queried, cannot be set */ + CU_LIMIT_CIG_ENABLED = 0x08, /**< A non-zero value indicates this CUDA context is a CIG-enabled context. Can only be queried, cannot be set */ + CU_LIMIT_CIG_SHMEM_FALLBACK_ENABLED = 0x09, /**< When set to a non-zero value, CUDA will fail to launch a kernel on a CIG context, instead of using the fallback path, if the kernel uses more shared memory than available */ + CU_LIMIT_MAX +} CUlimit; + +/** + * Resource types + */ +typedef enum CUresourcetype_enum { + CU_RESOURCE_TYPE_ARRAY = 0x00, /**< Array resource */ + CU_RESOURCE_TYPE_MIPMAPPED_ARRAY = 0x01, /**< Mipmapped array resource */ + CU_RESOURCE_TYPE_LINEAR = 0x02, /**< Linear resource */ + CU_RESOURCE_TYPE_PITCH2D = 0x03 /**< Pitch 2D resource */ +} CUresourcetype; + +#ifdef _WIN32 +#define CUDA_CB __stdcall +#else +#define CUDA_CB +#endif + +/** + * CUDA host function + * \param userData Argument value passed to the function + */ +typedef void (CUDA_CB *CUhostFn)(void *userData); + +/** + * Specifies performance hint with ::CUaccessPolicyWindow for hitProp and missProp members. + */ +typedef enum CUaccessProperty_enum { + CU_ACCESS_PROPERTY_NORMAL = 0, /**< Normal cache persistence. */ + CU_ACCESS_PROPERTY_STREAMING = 1, /**< Streaming access is less likely to persit from cache. */ + CU_ACCESS_PROPERTY_PERSISTING = 2 /**< Persisting access is more likely to persist in cache.*/ +} CUaccessProperty; + +/** + * Specifies an access policy for a window, a contiguous extent of memory + * beginning at base_ptr and ending at base_ptr + num_bytes. + * num_bytes is limited by CU_DEVICE_ATTRIBUTE_MAX_ACCESS_POLICY_WINDOW_SIZE. + * Partition into many segments and assign segments such that: + * sum of "hit segments" / window == approx. ratio. + * sum of "miss segments" / window == approx 1-ratio. + * Segments and ratio specifications are fitted to the capabilities of + * the architecture. + * Accesses in a hit segment apply the hitProp access policy. + * Accesses in a miss segment apply the missProp access policy. + */ +typedef struct CUaccessPolicyWindow_st { + void *base_ptr; /**< Starting address of the access policy window. CUDA driver may align it. */ + size_t num_bytes; /**< Size in bytes of the window policy. CUDA driver may restrict the maximum size and alignment. */ + float hitRatio; /**< hitRatio specifies percentage of lines assigned hitProp, rest are assigned missProp. */ + CUaccessProperty hitProp; /**< ::CUaccessProperty set for hit. */ + CUaccessProperty missProp; /**< ::CUaccessProperty set for miss. Must be either NORMAL or STREAMING */ +} CUaccessPolicyWindow_v1; +/** + * Access policy window + */ +typedef CUaccessPolicyWindow_v1 CUaccessPolicyWindow; + +/** + * GPU kernel node parameters + */ +typedef struct CUDA_KERNEL_NODE_PARAMS_st { + CUfunction func; /**< Kernel to launch */ + unsigned int gridDimX; /**< Width of grid in blocks */ + unsigned int gridDimY; /**< Height of grid in blocks */ + unsigned int gridDimZ; /**< Depth of grid in blocks */ + unsigned int blockDimX; /**< X dimension of each thread block */ + unsigned int blockDimY; /**< Y dimension of each thread block */ + unsigned int blockDimZ; /**< Z dimension of each thread block */ + unsigned int sharedMemBytes; /**< Dynamic shared-memory size per thread block in bytes */ + void **kernelParams; /**< Array of pointers to kernel parameters */ + void **extra; /**< Extra options */ +} CUDA_KERNEL_NODE_PARAMS_v1; + +/** + * GPU kernel node parameters + */ +typedef struct CUDA_KERNEL_NODE_PARAMS_v2_st { + CUfunction func; /**< Kernel to launch */ + unsigned int gridDimX; /**< Width of grid in blocks */ + unsigned int gridDimY; /**< Height of grid in blocks */ + unsigned int gridDimZ; /**< Depth of grid in blocks */ + unsigned int blockDimX; /**< X dimension of each thread block */ + unsigned int blockDimY; /**< Y dimension of each thread block */ + unsigned int blockDimZ; /**< Z dimension of each thread block */ + unsigned int sharedMemBytes; /**< Dynamic shared-memory size per thread block in bytes */ + void **kernelParams; /**< Array of pointers to kernel parameters */ + void **extra; /**< Extra options */ + CUkernel kern; /**< Kernel to launch, will only be referenced if func is NULL */ + CUcontext ctx; /**< Context for the kernel task to run in. The value NULL will indicate the current context should be used by the api. This field is ignored if func is set. */ +} CUDA_KERNEL_NODE_PARAMS_v2; +typedef CUDA_KERNEL_NODE_PARAMS_v2 CUDA_KERNEL_NODE_PARAMS; + +/** + * GPU kernel node parameters + */ +typedef struct CUDA_KERNEL_NODE_PARAMS_v3_st { + CUfunction func; /**< Kernel to launch */ + unsigned int gridDimX; /**< Width of grid in blocks */ + unsigned int gridDimY; /**< Height of grid in blocks */ + unsigned int gridDimZ; /**< Depth of grid in blocks */ + unsigned int blockDimX; /**< X dimension of each thread block */ + unsigned int blockDimY; /**< Y dimension of each thread block */ + unsigned int blockDimZ; /**< Z dimension of each thread block */ + unsigned int sharedMemBytes; /**< Dynamic shared-memory size per thread block in bytes */ + void **kernelParams; /**< Array of pointers to kernel parameters */ + void **extra; /**< Extra options */ + CUkernel kern; /**< Kernel to launch, will only be referenced if func is NULL */ + CUcontext ctx; /**< Context for the kernel task to run in. The value NULL will indicate the current context should be used by the api. This field is ignored if func is set. */ +} CUDA_KERNEL_NODE_PARAMS_v3; + +/** + * Memset node parameters + */ +typedef struct CUDA_MEMSET_NODE_PARAMS_st { + CUdeviceptr dst; /**< Destination device pointer */ + size_t pitch; /**< Pitch of destination device pointer. Unused if height is 1 */ + unsigned int value; /**< Value to be set */ + unsigned int elementSize; /**< Size of each element in bytes. Must be 1, 2, or 4. */ + size_t width; /**< Width of the row in elements */ + size_t height; /**< Number of rows */ +} CUDA_MEMSET_NODE_PARAMS_v1; +typedef CUDA_MEMSET_NODE_PARAMS_v1 CUDA_MEMSET_NODE_PARAMS; + +/** + * Memset node parameters + */ +typedef struct CUDA_MEMSET_NODE_PARAMS_v2_st { + CUdeviceptr dst; /**< Destination device pointer */ + size_t pitch; /**< Pitch of destination device pointer. Unused if height is 1 */ + unsigned int value; /**< Value to be set */ + unsigned int elementSize; /**< Size of each element in bytes. Must be 1, 2, or 4. */ + size_t width; /**< Width of the row in elements */ + size_t height; /**< Number of rows */ + CUcontext ctx; /**< Context on which to run the node */ +} CUDA_MEMSET_NODE_PARAMS_v2; + +/** + * Host node parameters + */ +typedef struct CUDA_HOST_NODE_PARAMS_st { + CUhostFn fn; /**< The function to call when the node executes */ + void* userData; /**< Argument to pass to the function */ +} CUDA_HOST_NODE_PARAMS_v1; +typedef CUDA_HOST_NODE_PARAMS_v1 CUDA_HOST_NODE_PARAMS; + +/** + * Host node parameters + */ +typedef struct CUDA_HOST_NODE_PARAMS_v2_st { + CUhostFn fn; /**< The function to call when the node executes */ + void* userData; /**< Argument to pass to the function */ +} CUDA_HOST_NODE_PARAMS_v2; + +/** + * Conditional node handle flags + */ +#define CU_GRAPH_COND_ASSIGN_DEFAULT 0x1 /**< Default value is applied when graph is launched. */ + +/** + * Conditional node types + */ +typedef enum CUgraphConditionalNodeType_enum { + CU_GRAPH_COND_TYPE_IF = 0, /**< Conditional 'if' Node. Body executed once if condition value is non-zero. */ + CU_GRAPH_COND_TYPE_WHILE = 1, /**< Conditional 'while' Node. Body executed repeatedly while condition value is non-zero. */ +} CUgraphConditionalNodeType; + +/** + * Conditional node parameters + */ +typedef struct CUDA_CONDITIONAL_NODE_PARAMS { + CUgraphConditionalHandle handle; /**< Conditional node handle. + Handles must be created in advance of creating the node + using ::cuGraphConditionalHandleCreate. */ + CUgraphConditionalNodeType type; /**< Type of conditional node. */ + unsigned int size; /**< Size of graph output array. Must be 1. */ + CUgraph *phGraph_out; /**< CUDA-owned array populated with conditional node child graphs during creation of the node. + Valid for the lifetime of the conditional node. + The contents of the graph(s) are subject to the following constraints: + + - Allowed node types are kernel nodes, empty nodes, child graphs, memsets, + memcopies, and conditionals. This applies recursively to child graphs and conditional bodies. + - All kernels, including kernels in nested conditionals or child graphs at any level, + must belong to the same CUDA context. + + These graphs may be populated using graph node creation APIs or ::cuStreamBeginCaptureToGraph. */ + CUcontext ctx; /**< Context on which to run the node. Must match context used to create the handle and all body nodes. */ +} CUDA_CONDITIONAL_NODE_PARAMS; + +/** + * Graph node types + */ +typedef enum CUgraphNodeType_enum { + CU_GRAPH_NODE_TYPE_KERNEL = 0, /**< GPU kernel node */ + CU_GRAPH_NODE_TYPE_MEMCPY = 1, /**< Memcpy node */ + CU_GRAPH_NODE_TYPE_MEMSET = 2, /**< Memset node */ + CU_GRAPH_NODE_TYPE_HOST = 3, /**< Host (executable) node */ + CU_GRAPH_NODE_TYPE_GRAPH = 4, /**< Node which executes an embedded graph */ + CU_GRAPH_NODE_TYPE_EMPTY = 5, /**< Empty (no-op) node */ + CU_GRAPH_NODE_TYPE_WAIT_EVENT = 6, /**< External event wait node */ + CU_GRAPH_NODE_TYPE_EVENT_RECORD = 7, /**< External event record node */ + CU_GRAPH_NODE_TYPE_EXT_SEMAS_SIGNAL = 8, /**< External semaphore signal node */ + CU_GRAPH_NODE_TYPE_EXT_SEMAS_WAIT = 9, /**< External semaphore wait node */ + CU_GRAPH_NODE_TYPE_MEM_ALLOC = 10,/**< Memory Allocation Node */ + CU_GRAPH_NODE_TYPE_MEM_FREE = 11,/**< Memory Free Node */ + CU_GRAPH_NODE_TYPE_BATCH_MEM_OP = 12,/**< Batch MemOp Node */ + CU_GRAPH_NODE_TYPE_CONDITIONAL = 13 /**< Conditional Node + + May be used to implement a conditional execution path or loop + inside of a graph. The graph(s) contained within the body of the conditional node + can be selectively executed or iterated upon based on the value of a conditional + variable. + + Handles must be created in advance of creating the node + using ::cuGraphConditionalHandleCreate. + + The following restrictions apply to graphs which contain conditional nodes: + The graph cannot be used in a child node. + Only one instantiation of the graph may exist at any point in time. + The graph cannot be cloned. + + To set the control value, supply a default value when creating the handle and/or + call ::cudaGraphSetConditional from device code.*/ +} CUgraphNodeType; + +/** + * Type annotations that can be applied to graph edges as part of ::CUgraphEdgeData. + */ +typedef enum CUgraphDependencyType_enum { + CU_GRAPH_DEPENDENCY_TYPE_DEFAULT = 0, /**< This is an ordinary dependency. */ + CU_GRAPH_DEPENDENCY_TYPE_PROGRAMMATIC = 1 /**< This dependency type allows the downstream node to + use \c cudaGridDependencySynchronize(). It may only be used + between kernel nodes, and must be used with either the + ::CU_GRAPH_KERNEL_NODE_PORT_PROGRAMMATIC or + ::CU_GRAPH_KERNEL_NODE_PORT_LAUNCH_ORDER outgoing port. */ +} CUgraphDependencyType; + +/** + * This port activates when the kernel has finished executing. + */ +#define CU_GRAPH_KERNEL_NODE_PORT_DEFAULT 0 +/** + * This port activates when all blocks of the kernel have performed cudaTriggerProgrammaticLaunchCompletion() + * or have terminated. It must be used with edge type ::CU_GRAPH_DEPENDENCY_TYPE_PROGRAMMATIC. See also + * ::CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_EVENT. + */ +#define CU_GRAPH_KERNEL_NODE_PORT_PROGRAMMATIC 1 +/** + * This port activates when all blocks of the kernel have begun execution. See also + * ::CU_LAUNCH_ATTRIBUTE_LAUNCH_COMPLETION_EVENT. + */ +#define CU_GRAPH_KERNEL_NODE_PORT_LAUNCH_ORDER 2 + +/** + * Optional annotation for edges in a CUDA graph. Note, all edges implicitly have annotations and + * default to a zero-initialized value if not specified. A zero-initialized struct indicates a + * standard full serialization of two nodes with memory visibility. + */ +typedef struct CUgraphEdgeData_st { + unsigned char from_port; /**< This indicates when the dependency is triggered from the upstream + node on the edge. The meaning is specfic to the node type. A value + of 0 in all cases means full completion of the upstream node, with + memory visibility to the downstream node or portion thereof + (indicated by \c to_port). +
    + Only kernel nodes define non-zero ports. A kernel node + can use the following output port types: + ::CU_GRAPH_KERNEL_NODE_PORT_DEFAULT, ::CU_GRAPH_KERNEL_NODE_PORT_PROGRAMMATIC, + or ::CU_GRAPH_KERNEL_NODE_PORT_LAUNCH_ORDER. */ + unsigned char to_port; /**< This indicates what portion of the downstream node is dependent on + the upstream node or portion thereof (indicated by \c from_port). The + meaning is specific to the node type. A value of 0 in all cases means + the entirety of the downstream node is dependent on the upstream work. +
    + Currently no node types define non-zero ports. Accordingly, this field + must be set to zero. */ + unsigned char type; /**< This should be populated with a value from ::CUgraphDependencyType. (It + is typed as char due to compiler-specific layout of bitfields.) See + ::CUgraphDependencyType. */ + unsigned char reserved[5]; /**< These bytes are unused and must be zeroed. This ensures + compatibility if additional fields are added in the future. */ +} CUgraphEdgeData; + +/** + * Graph instantiation results +*/ +typedef enum CUgraphInstantiateResult_enum +{ + CUDA_GRAPH_INSTANTIATE_SUCCESS = 0, /**< Instantiation succeeded */ + CUDA_GRAPH_INSTANTIATE_ERROR = 1, /**< Instantiation failed for an unexpected reason which is described in the return value of the function */ + CUDA_GRAPH_INSTANTIATE_INVALID_STRUCTURE = 2, /**< Instantiation failed due to invalid structure, such as cycles */ + CUDA_GRAPH_INSTANTIATE_NODE_OPERATION_NOT_SUPPORTED = 3, /**< Instantiation for device launch failed because the graph contained an unsupported operation */ + CUDA_GRAPH_INSTANTIATE_MULTIPLE_CTXS_NOT_SUPPORTED = 4 /**< Instantiation for device launch failed due to the nodes belonging to different contexts */ +} CUgraphInstantiateResult; + +/** + * Graph instantiation parameters + */ +typedef struct CUDA_GRAPH_INSTANTIATE_PARAMS_st +{ + cuuint64_t flags; /**< Instantiation flags */ + CUstream hUploadStream; /**< Upload stream */ + CUgraphNode hErrNode_out; /**< The node which caused instantiation to fail, if any */ + CUgraphInstantiateResult result_out; /**< Whether instantiation was successful. If it failed, the reason why */ +} CUDA_GRAPH_INSTANTIATE_PARAMS; + +typedef enum CUsynchronizationPolicy_enum { + CU_SYNC_POLICY_AUTO = 1, + CU_SYNC_POLICY_SPIN = 2, + CU_SYNC_POLICY_YIELD = 3, + CU_SYNC_POLICY_BLOCKING_SYNC = 4 +} CUsynchronizationPolicy; + +/** + * Cluster scheduling policies. These may be passed to ::cuFuncSetAttribute or ::cuKernelSetAttribute + */ +typedef enum CUclusterSchedulingPolicy_enum { + CU_CLUSTER_SCHEDULING_POLICY_DEFAULT = 0, /**< the default policy */ + CU_CLUSTER_SCHEDULING_POLICY_SPREAD = 1, /**< spread the blocks within a cluster to the SMs */ + CU_CLUSTER_SCHEDULING_POLICY_LOAD_BALANCING = 2 /**< allow the hardware to load-balance the blocks in a cluster to the SMs */ +} CUclusterSchedulingPolicy; + +/** + * Memory Synchronization Domain + * + * A kernel can be launched in a specified memory synchronization domain that affects all memory operations issued by + * that kernel. A memory barrier issued in one domain will only order memory operations in that domain, thus eliminating + * latency increase from memory barriers ordering unrelated traffic. + * + * By default, kernels are launched in domain 0. Kernel launched with ::CU_LAUNCH_MEM_SYNC_DOMAIN_REMOTE will have a + * different domain ID. User may also alter the domain ID with ::CUlaunchMemSyncDomainMap for a specific stream / + * graph node / kernel launch. See ::CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN, ::cuStreamSetAttribute, ::cuLaunchKernelEx, + * ::cuGraphKernelNodeSetAttribute. + * + * Memory operations done in kernels launched in different domains are considered system-scope distanced. In other + * words, a GPU scoped memory synchronization is not sufficient for memory order to be observed by kernels in another + * memory synchronization domain even if they are on the same GPU. + */ +typedef enum CUlaunchMemSyncDomain_enum { + CU_LAUNCH_MEM_SYNC_DOMAIN_DEFAULT = 0, /**< Launch kernels in the default domain */ + CU_LAUNCH_MEM_SYNC_DOMAIN_REMOTE = 1 /**< Launch kernels in the remote domain */ +} CUlaunchMemSyncDomain; + +/** + * Memory Synchronization Domain map + * + * See ::cudaLaunchMemSyncDomain. + * + * By default, kernels are launched in domain 0. Kernel launched with ::CU_LAUNCH_MEM_SYNC_DOMAIN_REMOTE will have a + * different domain ID. User may also alter the domain ID with ::CUlaunchMemSyncDomainMap for a specific stream / + * graph node / kernel launch. See ::CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP. + * + * Domain ID range is available through ::CU_DEVICE_ATTRIBUTE_MEM_SYNC_DOMAIN_COUNT. + */ +typedef struct CUlaunchMemSyncDomainMap_st { + unsigned char default_; /**< The default domain ID to use for designated kernels */ + unsigned char remote; /**< The remote domain ID to use for designated kernels */ +} CUlaunchMemSyncDomainMap; + +/** + * Launch attributes enum; used as id field of ::CUlaunchAttribute + */ +typedef enum CUlaunchAttributeID_enum { + CU_LAUNCH_ATTRIBUTE_IGNORE = 0 /**< Ignored entry, for convenient composition */ + , CU_LAUNCH_ATTRIBUTE_ACCESS_POLICY_WINDOW = 1 /**< Valid for streams, graph nodes, launches. See + ::CUlaunchAttributeValue::accessPolicyWindow. */ + , CU_LAUNCH_ATTRIBUTE_COOPERATIVE = 2 /**< Valid for graph nodes, launches. See + ::CUlaunchAttributeValue::cooperative. */ + , CU_LAUNCH_ATTRIBUTE_SYNCHRONIZATION_POLICY = 3 /**< Valid for streams. See + ::CUlaunchAttributeValue::syncPolicy. */ + , CU_LAUNCH_ATTRIBUTE_CLUSTER_DIMENSION = 4 /**< Valid for graph nodes, launches. See ::CUlaunchAttributeValue::clusterDim. */ + , CU_LAUNCH_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE = 5 /**< Valid for graph nodes, launches. See ::CUlaunchAttributeValue::clusterSchedulingPolicyPreference. */ + , CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_STREAM_SERIALIZATION = 6 /**< Valid for launches. Setting + ::CUlaunchAttributeValue::programmaticStreamSerializationAllowed + to non-0 signals that the kernel will use programmatic + means to resolve its stream dependency, so that the + CUDA runtime should opportunistically allow the grid's + execution to overlap with the previous kernel in the + stream, if that kernel requests the overlap. The + dependent launches can choose to wait on the + dependency using the programmatic sync + (cudaGridDependencySynchronize() or equivalent PTX + instructions). */ + , CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_EVENT = 7 /**< Valid for launches. Set + ::CUlaunchAttributeValue::programmaticEvent to + record the event. Event recorded through this + launch attribute is guaranteed to only trigger + after all block in the associated kernel trigger + the event. A block can trigger the event through + PTX launchdep.release or CUDA builtin function + cudaTriggerProgrammaticLaunchCompletion(). A + trigger can also be inserted at the beginning of + each block's execution if triggerAtBlockStart is + set to non-0. The dependent launches can choose to + wait on the dependency using the programmatic sync + (cudaGridDependencySynchronize() or equivalent PTX + instructions). Note that dependents (including the + CPU thread calling cuEventSynchronize()) are not + guaranteed to observe the release precisely when + it is released. For example, cuEventSynchronize() + may only observe the event trigger long after the + associated kernel has completed. This recording + type is primarily meant for establishing + programmatic dependency between device tasks. Note + also this type of dependency allows, but does not + guarantee, concurrent execution of tasks. +
    + The event supplied must not be an interprocess or + interop event. The event must disable timing (i.e. + must be created with the ::CU_EVENT_DISABLE_TIMING + flag set). + */ + , CU_LAUNCH_ATTRIBUTE_PRIORITY = 8 /**< Valid for streams, graph nodes, launches. See + ::CUlaunchAttributeValue::priority. */ + , CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP = 9 /**< Valid for streams, graph nodes, launches. See + ::CUlaunchAttributeValue::memSyncDomainMap. */ + , CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN = 10 /**< Valid for streams, graph nodes, launches. See + ::CUlaunchAttributeValue::memSyncDomain. */ + , CU_LAUNCH_ATTRIBUTE_LAUNCH_COMPLETION_EVENT = 12 /**< Valid for launches. Set + ::CUlaunchAttributeValue::launchCompletionEvent to record the + event. +
    + Nominally, the event is triggered once all blocks of the kernel + have begun execution. Currently this is a best effort. If a kernel + B has a launch completion dependency on a kernel A, B may wait + until A is complete. Alternatively, blocks of B may begin before + all blocks of A have begun, for example if B can claim execution + resources unavailable to A (e.g. they run on different GPUs) or + if B is a higher priority than A. + Exercise caution if such an ordering inversion could lead + to deadlock. +
    + A launch completion event is nominally similar to a programmatic + event with \c triggerAtBlockStart set except that it is not + visible to \c cudaGridDependencySynchronize() and can be used with + compute capability less than 9.0. +
    + The event supplied must not be an interprocess or interop + event. The event must disable timing (i.e. must be created + with the ::CU_EVENT_DISABLE_TIMING flag set). */ + , CU_LAUNCH_ATTRIBUTE_DEVICE_UPDATABLE_KERNEL_NODE = 13 /**< Valid for graph nodes, launches. This attribute is graphs-only, + and passing it to a launch in a non-capturing stream will result + in an error. +
    + ::CUlaunchAttributeValue::deviceUpdatableKernelNode::deviceUpdatable can + only be set to 0 or 1. Setting the field to 1 indicates that the + corresponding kernel node should be device-updatable. On success, a handle + will be returned via + ::CUlaunchAttributeValue::deviceUpdatableKernelNode::devNode which can be + passed to the various device-side update functions to update the node's + kernel parameters from within another kernel. For more information on the + types of device updates that can be made, as well as the relevant limitations + thereof, see ::cudaGraphKernelNodeUpdatesApply. +
    + Nodes which are device-updatable have additional restrictions compared to + regular kernel nodes. Firstly, device-updatable nodes cannot be removed + from their graph via ::cuGraphDestroyNode. Additionally, once opted-in + to this functionality, a node cannot opt out, and any attempt to set the + deviceUpdatable attribute to 0 will result in an error. Device-updatable + kernel nodes also cannot have their attributes copied to/from another kernel + node via ::cuGraphKernelNodeCopyAttributes. Graphs containing one or more + device-updatable nodes also do not allow multiple instantiation, and neither + the graph nor its instantiated version can be passed to ::cuGraphExecUpdate. +
    + If a graph contains device-updatable nodes and updates those nodes from the device + from within the graph, the graph must be uploaded with ::cuGraphUpload before it + is launched. For such a graph, if host-side executable graph updates are made to the + device-updatable nodes, the graph must be uploaded before it is launched again. */ + , CU_LAUNCH_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT = 14 /**< Valid for launches. On devices where the L1 cache and shared memory use the + same hardware resources, setting ::CUlaunchAttributeValue::sharedMemCarveout to a + percentage between 0-100 signals the CUDA driver to set the shared memory carveout + preference, in percent of the total shared memory for that kernel launch. + This attribute takes precedence over ::CU_FUNC_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT. + This is only a hint, and the CUDA driver can choose a different configuration if + required for the launch. */ +#if defined(__CUDA_API_VERSION_INTERNAL) && !defined(__CUDA_API_VERSION_INTERNAL_ODR) + , CU_LAUNCH_ATTRIBUTE_MAX +#endif +} CUlaunchAttributeID; + +/** + * Launch attributes union; used as value field of ::CUlaunchAttribute + */ +typedef union CUlaunchAttributeValue_union { + char pad[64]; /* Pad to 64 bytes */ + CUaccessPolicyWindow accessPolicyWindow; /**< Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_ACCESS_POLICY_WINDOW. */ + int cooperative; /**< Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_COOPERATIVE. Nonzero indicates a cooperative + kernel (see ::cuLaunchCooperativeKernel). */ + CUsynchronizationPolicy syncPolicy; /**< Value of launch attribute + ::CU_LAUNCH_ATTRIBUTE_SYNCHRONIZATION_POLICY. ::CUsynchronizationPolicy for + work queued up in this stream */ + + /** + * Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_CLUSTER_DIMENSION that + * represents the desired cluster dimensions for the kernel. Opaque type + * with the following fields: + * - \p x - The X dimension of the cluster, in blocks. Must be a divisor + * of the grid X dimension. + * - \p y - The Y dimension of the cluster, in blocks. Must be a divisor + * of the grid Y dimension. + * - \p z - The Z dimension of the cluster, in blocks. Must be a divisor + * of the grid Z dimension. + */ + struct { + unsigned int x; + unsigned int y; + unsigned int z; + } clusterDim; + CUclusterSchedulingPolicy clusterSchedulingPolicyPreference; /**< Value of launch attribute + ::CU_LAUNCH_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE. Cluster + scheduling policy preference for the kernel. */ + int programmaticStreamSerializationAllowed; /**< Value of launch attribute + ::CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_STREAM_SERIALIZATION. */ + /** + * Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_EVENT + * with the following fields: + * - \p CUevent event - Event to fire when all blocks trigger it. + * - \p Event record flags, see ::cuEventRecordWithFlags. Does not accept :CU_EVENT_RECORD_EXTERNAL. + * - \p triggerAtBlockStart - If this is set to non-0, each block launch will automatically trigger the event. + */ + struct { + CUevent event; + int flags; + int triggerAtBlockStart; + } programmaticEvent; + /** + * Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_LAUNCH_COMPLETION_EVENT + * with the following fields: + * - \p CUevent event - Event to fire when the last block launches + * - \p int flags; - Event record flags, see ::cuEventRecordWithFlags. Does not accept ::CU_EVENT_RECORD_EXTERNAL. + */ + struct { + CUevent event; + int flags; + } launchCompletionEvent; + int priority; /**< Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_PRIORITY. Execution priority of the kernel. */ + CUlaunchMemSyncDomainMap memSyncDomainMap; /**< Value of launch attribute + ::CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP. See + ::CUlaunchMemSyncDomainMap. */ + CUlaunchMemSyncDomain memSyncDomain; /**< Value of launch attribute + ::CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN. See::CUlaunchMemSyncDomain */ + + /** + * Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_DEVICE_UPDATABLE_KERNEL_NODE. + * with the following fields: + * - \p int deviceUpdatable - Whether or not the resulting kernel node should be device-updatable. + * - \p CUgraphDeviceNode devNode - Returns a handle to pass to the various device-side update functions. + */ + struct { + int deviceUpdatable; + CUgraphDeviceNode devNode; + } deviceUpdatableKernelNode; + unsigned int sharedMemCarveout; /**< Value of launch attribute ::CU_LAUNCH_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT. */ +} CUlaunchAttributeValue; + +/** + * Launch attribute + */ +typedef struct CUlaunchAttribute_st { + CUlaunchAttributeID id; /**< Attribute to set */ + char pad[8 - sizeof(CUlaunchAttributeID)]; + CUlaunchAttributeValue value; /**< Value of the attribute */ +} CUlaunchAttribute; + +/** + * CUDA extensible launch configuration + */ +typedef struct CUlaunchConfig_st { + unsigned int gridDimX; /**< Width of grid in blocks */ + unsigned int gridDimY; /**< Height of grid in blocks */ + unsigned int gridDimZ; /**< Depth of grid in blocks */ + unsigned int blockDimX; /**< X dimension of each thread block */ + unsigned int blockDimY; /**< Y dimension of each thread block */ + unsigned int blockDimZ; /**< Z dimension of each thread block */ + unsigned int sharedMemBytes; /**< Dynamic shared-memory size per thread block in bytes */ + CUstream hStream; /**< Stream identifier */ + CUlaunchAttribute *attrs; /**< List of attributes; nullable if ::CUlaunchConfig::numAttrs == 0 */ + unsigned int numAttrs; /**< Number of attributes populated in ::CUlaunchConfig::attrs */ +} CUlaunchConfig; + +typedef CUlaunchAttributeID CUkernelNodeAttrID; +#define CU_KERNEL_NODE_ATTRIBUTE_ACCESS_POLICY_WINDOW CU_LAUNCH_ATTRIBUTE_ACCESS_POLICY_WINDOW +#define CU_KERNEL_NODE_ATTRIBUTE_COOPERATIVE CU_LAUNCH_ATTRIBUTE_COOPERATIVE +#define CU_KERNEL_NODE_ATTRIBUTE_CLUSTER_DIMENSION CU_LAUNCH_ATTRIBUTE_CLUSTER_DIMENSION +#define CU_KERNEL_NODE_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE CU_LAUNCH_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE +#define CU_KERNEL_NODE_ATTRIBUTE_PRIORITY CU_LAUNCH_ATTRIBUTE_PRIORITY +#define CU_KERNEL_NODE_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP +#define CU_KERNEL_NODE_ATTRIBUTE_MEM_SYNC_DOMAIN CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN +#define CU_KERNEL_NODE_ATTRIBUTE_DEVICE_UPDATABLE_KERNEL_NODE CU_LAUNCH_ATTRIBUTE_DEVICE_UPDATABLE_KERNEL_NODE +#define CU_KERNEL_NODE_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT CU_LAUNCH_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT + +typedef CUlaunchAttributeValue CUkernelNodeAttrValue_v1; +typedef CUkernelNodeAttrValue_v1 CUkernelNodeAttrValue; + +/** + * Possible stream capture statuses returned by ::cuStreamIsCapturing + */ +typedef enum CUstreamCaptureStatus_enum { + CU_STREAM_CAPTURE_STATUS_NONE = 0, /**< Stream is not capturing */ + CU_STREAM_CAPTURE_STATUS_ACTIVE = 1, /**< Stream is actively capturing */ + CU_STREAM_CAPTURE_STATUS_INVALIDATED = 2 /**< Stream is part of a capture sequence that + has been invalidated, but not terminated */ +} CUstreamCaptureStatus; + +/** + * Possible modes for stream capture thread interactions. For more details see + * ::cuStreamBeginCapture and ::cuThreadExchangeStreamCaptureMode + */ +typedef enum CUstreamCaptureMode_enum { + CU_STREAM_CAPTURE_MODE_GLOBAL = 0, + CU_STREAM_CAPTURE_MODE_THREAD_LOCAL = 1, + CU_STREAM_CAPTURE_MODE_RELAXED = 2 +} CUstreamCaptureMode; + +typedef CUlaunchAttributeID CUstreamAttrID; +#define CU_STREAM_ATTRIBUTE_ACCESS_POLICY_WINDOW CU_LAUNCH_ATTRIBUTE_ACCESS_POLICY_WINDOW +#define CU_STREAM_ATTRIBUTE_SYNCHRONIZATION_POLICY CU_LAUNCH_ATTRIBUTE_SYNCHRONIZATION_POLICY +#define CU_STREAM_ATTRIBUTE_PRIORITY CU_LAUNCH_ATTRIBUTE_PRIORITY +#define CU_STREAM_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP +#define CU_STREAM_ATTRIBUTE_MEM_SYNC_DOMAIN CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN + +typedef CUlaunchAttributeValue CUstreamAttrValue_v1; +typedef CUstreamAttrValue_v1 CUstreamAttrValue; + +/** + * Flags to specify search options. For more details see ::cuGetProcAddress + */ +typedef enum CUdriverProcAddress_flags_enum { + CU_GET_PROC_ADDRESS_DEFAULT = 0, /**< Default search mode for driver symbols. */ + CU_GET_PROC_ADDRESS_LEGACY_STREAM = 1 << 0, /**< Search for legacy versions of driver symbols. */ + CU_GET_PROC_ADDRESS_PER_THREAD_DEFAULT_STREAM = 1 << 1 /**< Search for per-thread versions of driver symbols. */ +} CUdriverProcAddress_flags; + +/** + * Flags to indicate search status. For more details see ::cuGetProcAddress + */ +typedef enum CUdriverProcAddressQueryResult_enum { + CU_GET_PROC_ADDRESS_SUCCESS = 0, /**< Symbol was succesfully found */ + CU_GET_PROC_ADDRESS_SYMBOL_NOT_FOUND = 1, /**< Symbol was not found in search */ + CU_GET_PROC_ADDRESS_VERSION_NOT_SUFFICIENT = 2 /**< Symbol was found but version supplied was not sufficient */ +} CUdriverProcAddressQueryResult; + +/** + * Execution Affinity Types + */ +typedef enum CUexecAffinityType_enum { + CU_EXEC_AFFINITY_TYPE_SM_COUNT = 0, /**< Create a context with limited SMs. */ + CU_EXEC_AFFINITY_TYPE_MAX +} CUexecAffinityType; + +/** + * Value for ::CU_EXEC_AFFINITY_TYPE_SM_COUNT + */ +typedef struct CUexecAffinitySmCount_st { + unsigned int val; /**< The number of SMs the context is limited to use. */ +} CUexecAffinitySmCount_v1; +typedef CUexecAffinitySmCount_v1 CUexecAffinitySmCount; + +/** + * Execution Affinity Parameters + */ +typedef struct CUexecAffinityParam_st { + CUexecAffinityType type; + union { + CUexecAffinitySmCount smCount; /** Value for ::CU_EXEC_AFFINITY_TYPE_SM_COUNT */ + } param; +} CUexecAffinityParam_v1; +/** + * Execution Affinity Parameters + */ +typedef CUexecAffinityParam_v1 CUexecAffinityParam; + +typedef enum CUcigDataType_enum { + CIG_DATA_TYPE_D3D12_COMMAND_QUEUE = 0x1, /** D3D12 Command Queue Handle */ +} CUcigDataType; + +/** +* CIG Context Create Params +*/ +typedef struct CUctxCigParam_st { + CUcigDataType sharedDataType; + void* sharedData; +} CUctxCigParam; + +/** +* Params for creating CUDA context +* Exactly one of execAffinityParams and cigParams +* must be non-NULL. +*/ +typedef struct CUctxCreateParams_st { + CUexecAffinityParam *execAffinityParams; + int numExecAffinityParams; + CUctxCigParam *cigParams; +} CUctxCreateParams; + +/** + * Library options to be specified with ::cuLibraryLoadData() or ::cuLibraryLoadFromFile() + */ +typedef enum CUlibraryOption_enum +{ + CU_LIBRARY_HOST_UNIVERSAL_FUNCTION_AND_DATA_TABLE = 0, + + /** + * Specifes that the argument \p code passed to ::cuLibraryLoadData() will be preserved. + * Specifying this option will let the driver know that \p code can be accessed at any point + * until ::cuLibraryUnload(). The default behavior is for the driver to allocate and + * maintain its own copy of \p code. Note that this is only a memory usage optimization + * hint and the driver can choose to ignore it if required. + * Specifying this option with ::cuLibraryLoadFromFile() is invalid and + * will return ::CUDA_ERROR_INVALID_VALUE. + */ + CU_LIBRARY_BINARY_IS_PRESERVED = 1, + + CU_LIBRARY_NUM_OPTIONS +} CUlibraryOption; + +typedef struct CUlibraryHostUniversalFunctionAndDataTable_st +{ + void *functionTable; + size_t functionWindowSize; + void *dataTable; + size_t dataWindowSize; +} CUlibraryHostUniversalFunctionAndDataTable; + +/** + * Error codes + */ +typedef enum cudaError_enum { + /** + * The API call returned with no errors. In the case of query calls, this + * also means that the operation being queried is complete (see + * ::cuEventQuery() and ::cuStreamQuery()). + */ + CUDA_SUCCESS = 0, + + /** + * This indicates that one or more of the parameters passed to the API call + * is not within an acceptable range of values. + */ + CUDA_ERROR_INVALID_VALUE = 1, + + /** + * The API call failed because it was unable to allocate enough memory or + * other resources to perform the requested operation. + */ + CUDA_ERROR_OUT_OF_MEMORY = 2, + + /** + * This indicates that the CUDA driver has not been initialized with + * ::cuInit() or that initialization has failed. + */ + CUDA_ERROR_NOT_INITIALIZED = 3, + + /** + * This indicates that the CUDA driver is in the process of shutting down. + */ + CUDA_ERROR_DEINITIALIZED = 4, + + /** + * This indicates profiler is not initialized for this run. This can + * happen when the application is running with external profiling tools + * like visual profiler. + */ + CUDA_ERROR_PROFILER_DISABLED = 5, + + /** + * \deprecated + * This error return is deprecated as of CUDA 5.0. It is no longer an error + * to attempt to enable/disable the profiling via ::cuProfilerStart or + * ::cuProfilerStop without initialization. + */ + CUDA_ERROR_PROFILER_NOT_INITIALIZED = 6, + + /** + * \deprecated + * This error return is deprecated as of CUDA 5.0. It is no longer an error + * to call cuProfilerStart() when profiling is already enabled. + */ + CUDA_ERROR_PROFILER_ALREADY_STARTED = 7, + + /** + * \deprecated + * This error return is deprecated as of CUDA 5.0. It is no longer an error + * to call cuProfilerStop() when profiling is already disabled. + */ + CUDA_ERROR_PROFILER_ALREADY_STOPPED = 8, + + /** + * This indicates that the CUDA driver that the application has loaded is a + * stub library. Applications that run with the stub rather than a real + * driver loaded will result in CUDA API returning this error. + */ + CUDA_ERROR_STUB_LIBRARY = 34, + + /** + * This indicates that requested CUDA device is unavailable at the current + * time. Devices are often unavailable due to use of + * ::CU_COMPUTEMODE_EXCLUSIVE_PROCESS or ::CU_COMPUTEMODE_PROHIBITED. + */ + CUDA_ERROR_DEVICE_UNAVAILABLE = 46, + + /** + * This indicates that no CUDA-capable devices were detected by the installed + * CUDA driver. + */ + CUDA_ERROR_NO_DEVICE = 100, + + /** + * This indicates that the device ordinal supplied by the user does not + * correspond to a valid CUDA device or that the action requested is + * invalid for the specified device. + */ + CUDA_ERROR_INVALID_DEVICE = 101, + + /** + * This error indicates that the Grid license is not applied. + */ + CUDA_ERROR_DEVICE_NOT_LICENSED = 102, + + /** + * This indicates that the device kernel image is invalid. This can also + * indicate an invalid CUDA module. + */ + CUDA_ERROR_INVALID_IMAGE = 200, + + /** + * This most frequently indicates that there is no context bound to the + * current thread. This can also be returned if the context passed to an + * API call is not a valid handle (such as a context that has had + * ::cuCtxDestroy() invoked on it). This can also be returned if a user + * mixes different API versions (i.e. 3010 context with 3020 API calls). + * See ::cuCtxGetApiVersion() for more details. + * This can also be returned if the green context passed to an API call + * was not converted to a ::CUcontext using ::cuCtxFromGreenCtx API. + */ + CUDA_ERROR_INVALID_CONTEXT = 201, + + /** + * This indicated that the context being supplied as a parameter to the + * API call was already the active context. + * \deprecated + * This error return is deprecated as of CUDA 3.2. It is no longer an + * error to attempt to push the active context via ::cuCtxPushCurrent(). + */ + CUDA_ERROR_CONTEXT_ALREADY_CURRENT = 202, + + /** + * This indicates that a map or register operation has failed. + */ + CUDA_ERROR_MAP_FAILED = 205, + + /** + * This indicates that an unmap or unregister operation has failed. + */ + CUDA_ERROR_UNMAP_FAILED = 206, + + /** + * This indicates that the specified array is currently mapped and thus + * cannot be destroyed. + */ + CUDA_ERROR_ARRAY_IS_MAPPED = 207, + + /** + * This indicates that the resource is already mapped. + */ + CUDA_ERROR_ALREADY_MAPPED = 208, + + /** + * This indicates that there is no kernel image available that is suitable + * for the device. This can occur when a user specifies code generation + * options for a particular CUDA source file that do not include the + * corresponding device configuration. + */ + CUDA_ERROR_NO_BINARY_FOR_GPU = 209, + + /** + * This indicates that a resource has already been acquired. + */ + CUDA_ERROR_ALREADY_ACQUIRED = 210, + + /** + * This indicates that a resource is not mapped. + */ + CUDA_ERROR_NOT_MAPPED = 211, + + /** + * This indicates that a mapped resource is not available for access as an + * array. + */ + CUDA_ERROR_NOT_MAPPED_AS_ARRAY = 212, + + /** + * This indicates that a mapped resource is not available for access as a + * pointer. + */ + CUDA_ERROR_NOT_MAPPED_AS_POINTER = 213, + + /** + * This indicates that an uncorrectable ECC error was detected during + * execution. + */ + CUDA_ERROR_ECC_UNCORRECTABLE = 214, + + /** + * This indicates that the ::CUlimit passed to the API call is not + * supported by the active device. + */ + CUDA_ERROR_UNSUPPORTED_LIMIT = 215, + + /** + * This indicates that the ::CUcontext passed to the API call can + * only be bound to a single CPU thread at a time but is already + * bound to a CPU thread. + */ + CUDA_ERROR_CONTEXT_ALREADY_IN_USE = 216, + + /** + * This indicates that peer access is not supported across the given + * devices. + */ + CUDA_ERROR_PEER_ACCESS_UNSUPPORTED = 217, + + /** + * This indicates that a PTX JIT compilation failed. + */ + CUDA_ERROR_INVALID_PTX = 218, + + /** + * This indicates an error with OpenGL or DirectX context. + */ + CUDA_ERROR_INVALID_GRAPHICS_CONTEXT = 219, + + /** + * This indicates that an uncorrectable NVLink error was detected during the + * execution. + */ + CUDA_ERROR_NVLINK_UNCORRECTABLE = 220, + + /** + * This indicates that the PTX JIT compiler library was not found. + */ + CUDA_ERROR_JIT_COMPILER_NOT_FOUND = 221, + + /** + * This indicates that the provided PTX was compiled with an unsupported toolchain. + */ + + CUDA_ERROR_UNSUPPORTED_PTX_VERSION = 222, + + /** + * This indicates that the PTX JIT compilation was disabled. + */ + CUDA_ERROR_JIT_COMPILATION_DISABLED = 223, + + /** + * This indicates that the ::CUexecAffinityType passed to the API call is not + * supported by the active device. + */ + CUDA_ERROR_UNSUPPORTED_EXEC_AFFINITY = 224, + + /** + * This indicates that the code to be compiled by the PTX JIT contains + * unsupported call to cudaDeviceSynchronize. + */ + CUDA_ERROR_UNSUPPORTED_DEVSIDE_SYNC = 225, + + /** + * This indicates that the device kernel source is invalid. This includes + * compilation/linker errors encountered in device code or user error. + */ + CUDA_ERROR_INVALID_SOURCE = 300, + + /** + * This indicates that the file specified was not found. + */ + CUDA_ERROR_FILE_NOT_FOUND = 301, + + /** + * This indicates that a link to a shared object failed to resolve. + */ + CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND = 302, + + /** + * This indicates that initialization of a shared object failed. + */ + CUDA_ERROR_SHARED_OBJECT_INIT_FAILED = 303, + + /** + * This indicates that an OS call failed. + */ + CUDA_ERROR_OPERATING_SYSTEM = 304, + + /** + * This indicates that a resource handle passed to the API call was not + * valid. Resource handles are opaque types like ::CUstream and ::CUevent. + */ + CUDA_ERROR_INVALID_HANDLE = 400, + + /** + * This indicates that a resource required by the API call is not in a + * valid state to perform the requested operation. + */ + CUDA_ERROR_ILLEGAL_STATE = 401, + + /** + * This indicates an attempt was made to introspect an object in a way that + * would discard semantically important information. This is either due to + * the object using funtionality newer than the API version used to + * introspect it or omission of optional return arguments. + */ + CUDA_ERROR_LOSSY_QUERY = 402, + + /** + * This indicates that a named symbol was not found. Examples of symbols + * are global/constant variable names, driver function names, texture names, + * and surface names. + */ + CUDA_ERROR_NOT_FOUND = 500, + + /** + * This indicates that asynchronous operations issued previously have not + * completed yet. This result is not actually an error, but must be indicated + * differently than ::CUDA_SUCCESS (which indicates completion). Calls that + * may return this value include ::cuEventQuery() and ::cuStreamQuery(). + */ + CUDA_ERROR_NOT_READY = 600, + + /** + * While executing a kernel, the device encountered a + * load or store instruction on an invalid memory address. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_ILLEGAL_ADDRESS = 700, + + /** + * This indicates that a launch did not occur because it did not have + * appropriate resources. This error usually indicates that the user has + * attempted to pass too many arguments to the device kernel, or the + * kernel launch specifies too many threads for the kernel's register + * count. Passing arguments of the wrong size (i.e. a 64-bit pointer + * when a 32-bit int is expected) is equivalent to passing too many + * arguments and can also result in this error. + */ + CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES = 701, + + /** + * This indicates that the device kernel took too long to execute. This can + * only occur if timeouts are enabled - see the device attribute + * ::CU_DEVICE_ATTRIBUTE_KERNEL_EXEC_TIMEOUT for more information. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_LAUNCH_TIMEOUT = 702, + + /** + * This error indicates a kernel launch that uses an incompatible texturing + * mode. + */ + CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING = 703, + + /** + * This error indicates that a call to ::cuCtxEnablePeerAccess() is + * trying to re-enable peer access to a context which has already + * had peer access to it enabled. + */ + CUDA_ERROR_PEER_ACCESS_ALREADY_ENABLED = 704, + + /** + * This error indicates that ::cuCtxDisablePeerAccess() is + * trying to disable peer access which has not been enabled yet + * via ::cuCtxEnablePeerAccess(). + */ + CUDA_ERROR_PEER_ACCESS_NOT_ENABLED = 705, + + /** + * This error indicates that the primary context for the specified device + * has already been initialized. + */ + CUDA_ERROR_PRIMARY_CONTEXT_ACTIVE = 708, + + /** + * This error indicates that the context current to the calling thread + * has been destroyed using ::cuCtxDestroy, or is a primary context which + * has not yet been initialized. + */ + CUDA_ERROR_CONTEXT_IS_DESTROYED = 709, + + /** + * A device-side assert triggered during kernel execution. The context + * cannot be used anymore, and must be destroyed. All existing device + * memory allocations from this context are invalid and must be + * reconstructed if the program is to continue using CUDA. + */ + CUDA_ERROR_ASSERT = 710, + + /** + * This error indicates that the hardware resources required to enable + * peer access have been exhausted for one or more of the devices + * passed to ::cuCtxEnablePeerAccess(). + */ + CUDA_ERROR_TOO_MANY_PEERS = 711, + + /** + * This error indicates that the memory range passed to ::cuMemHostRegister() + * has already been registered. + */ + CUDA_ERROR_HOST_MEMORY_ALREADY_REGISTERED = 712, + + /** + * This error indicates that the pointer passed to ::cuMemHostUnregister() + * does not correspond to any currently registered memory region. + */ + CUDA_ERROR_HOST_MEMORY_NOT_REGISTERED = 713, + + /** + * While executing a kernel, the device encountered a stack error. + * This can be due to stack corruption or exceeding the stack size limit. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_HARDWARE_STACK_ERROR = 714, + + /** + * While executing a kernel, the device encountered an illegal instruction. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_ILLEGAL_INSTRUCTION = 715, + + /** + * While executing a kernel, the device encountered a load or store instruction + * on a memory address which is not aligned. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_MISALIGNED_ADDRESS = 716, + + /** + * While executing a kernel, the device encountered an instruction + * which can only operate on memory locations in certain address spaces + * (global, shared, or local), but was supplied a memory address not + * belonging to an allowed address space. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_INVALID_ADDRESS_SPACE = 717, + + /** + * While executing a kernel, the device program counter wrapped its address space. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_INVALID_PC = 718, + + /** + * An exception occurred on the device while executing a kernel. Common + * causes include dereferencing an invalid device pointer and accessing + * out of bounds shared memory. Less common cases can be system specific - more + * information about these cases can be found in the system specific user guide. + * This leaves the process in an inconsistent state and any further CUDA work + * will return the same error. To continue using CUDA, the process must be terminated + * and relaunched. + */ + CUDA_ERROR_LAUNCH_FAILED = 719, + + /** + * This error indicates that the number of blocks launched per grid for a kernel that was + * launched via either ::cuLaunchCooperativeKernel or ::cuLaunchCooperativeKernelMultiDevice + * exceeds the maximum number of blocks as allowed by ::cuOccupancyMaxActiveBlocksPerMultiprocessor + * or ::cuOccupancyMaxActiveBlocksPerMultiprocessorWithFlags times the number of multiprocessors + * as specified by the device attribute ::CU_DEVICE_ATTRIBUTE_MULTIPROCESSOR_COUNT. + */ + CUDA_ERROR_COOPERATIVE_LAUNCH_TOO_LARGE = 720, + + /** + * This error indicates that the attempted operation is not permitted. + */ + CUDA_ERROR_NOT_PERMITTED = 800, + + /** + * This error indicates that the attempted operation is not supported + * on the current system or device. + */ + CUDA_ERROR_NOT_SUPPORTED = 801, + + /** + * This error indicates that the system is not yet ready to start any CUDA + * work. To continue using CUDA, verify the system configuration is in a + * valid state and all required driver daemons are actively running. + * More information about this error can be found in the system specific + * user guide. + */ + CUDA_ERROR_SYSTEM_NOT_READY = 802, + + /** + * This error indicates that there is a mismatch between the versions of + * the display driver and the CUDA driver. Refer to the compatibility documentation + * for supported versions. + */ + CUDA_ERROR_SYSTEM_DRIVER_MISMATCH = 803, + + /** + * This error indicates that the system was upgraded to run with forward compatibility + * but the visible hardware detected by CUDA does not support this configuration. + * Refer to the compatibility documentation for the supported hardware matrix or ensure + * that only supported hardware is visible during initialization via the CUDA_VISIBLE_DEVICES + * environment variable. + */ + CUDA_ERROR_COMPAT_NOT_SUPPORTED_ON_DEVICE = 804, + + /** + * This error indicates that the MPS client failed to connect to the MPS control daemon or the MPS server. + */ + CUDA_ERROR_MPS_CONNECTION_FAILED = 805, + + /** + * This error indicates that the remote procedural call between the MPS server and the MPS client failed. + */ + CUDA_ERROR_MPS_RPC_FAILURE = 806, + + /** + * This error indicates that the MPS server is not ready to accept new MPS client requests. + * This error can be returned when the MPS server is in the process of recovering from a fatal failure. + */ + CUDA_ERROR_MPS_SERVER_NOT_READY = 807, + + /** + * This error indicates that the hardware resources required to create MPS client have been exhausted. + */ + CUDA_ERROR_MPS_MAX_CLIENTS_REACHED = 808, + + /** + * This error indicates the the hardware resources required to support device connections have been exhausted. + */ + CUDA_ERROR_MPS_MAX_CONNECTIONS_REACHED = 809, + + /** + * This error indicates that the MPS client has been terminated by the server. To continue using CUDA, the process must be terminated and relaunched. + */ + CUDA_ERROR_MPS_CLIENT_TERMINATED = 810, + + /** + * This error indicates that the module is using CUDA Dynamic Parallelism, but the current configuration, like MPS, does not support it. + */ + CUDA_ERROR_CDP_NOT_SUPPORTED = 811, + + /** + * This error indicates that a module contains an unsupported interaction between different versions of CUDA Dynamic Parallelism. + */ + CUDA_ERROR_CDP_VERSION_MISMATCH = 812, + + /** + * This error indicates that the operation is not permitted when + * the stream is capturing. + */ + CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED = 900, + + /** + * This error indicates that the current capture sequence on the stream + * has been invalidated due to a previous error. + */ + CUDA_ERROR_STREAM_CAPTURE_INVALIDATED = 901, + + /** + * This error indicates that the operation would have resulted in a merge + * of two independent capture sequences. + */ + CUDA_ERROR_STREAM_CAPTURE_MERGE = 902, + + /** + * This error indicates that the capture was not initiated in this stream. + */ + CUDA_ERROR_STREAM_CAPTURE_UNMATCHED = 903, + + /** + * This error indicates that the capture sequence contains a fork that was + * not joined to the primary stream. + */ + CUDA_ERROR_STREAM_CAPTURE_UNJOINED = 904, + + /** + * This error indicates that a dependency would have been created which + * crosses the capture sequence boundary. Only implicit in-stream ordering + * dependencies are allowed to cross the boundary. + */ + CUDA_ERROR_STREAM_CAPTURE_ISOLATION = 905, + + /** + * This error indicates a disallowed implicit dependency on a current capture + * sequence from cudaStreamLegacy. + */ + CUDA_ERROR_STREAM_CAPTURE_IMPLICIT = 906, + + /** + * This error indicates that the operation is not permitted on an event which + * was last recorded in a capturing stream. + */ + CUDA_ERROR_CAPTURED_EVENT = 907, + + /** + * A stream capture sequence not initiated with the ::CU_STREAM_CAPTURE_MODE_RELAXED + * argument to ::cuStreamBeginCapture was passed to ::cuStreamEndCapture in a + * different thread. + */ + CUDA_ERROR_STREAM_CAPTURE_WRONG_THREAD = 908, + + /** + * This error indicates that the timeout specified for the wait operation has lapsed. + */ + CUDA_ERROR_TIMEOUT = 909, + + /** + * This error indicates that the graph update was not performed because it included + * changes which violated constraints specific to instantiated graph update. + */ + CUDA_ERROR_GRAPH_EXEC_UPDATE_FAILURE = 910, + + /** + * This indicates that an async error has occurred in a device outside of CUDA. + * If CUDA was waiting for an external device's signal before consuming shared data, + * the external device signaled an error indicating that the data is not valid for + * consumption. This leaves the process in an inconsistent state and any further CUDA + * work will return the same error. To continue using CUDA, the process must be + * terminated and relaunched. + */ + CUDA_ERROR_EXTERNAL_DEVICE = 911, + + /** + * Indicates a kernel launch error due to cluster misconfiguration. + */ + CUDA_ERROR_INVALID_CLUSTER_SIZE = 912, + + /** + * Indiciates a function handle is not loaded when calling an API that requires + * a loaded function. + */ + CUDA_ERROR_FUNCTION_NOT_LOADED = 913, + + /** + * This error indicates one or more resources passed in are not valid resource + * types for the operation. + */ + CUDA_ERROR_INVALID_RESOURCE_TYPE = 914, + + /** + * This error indicates one or more resources are insufficient or non-applicable for + * the operation. + */ + CUDA_ERROR_INVALID_RESOURCE_CONFIGURATION = 915, + + /** + * This indicates that an unknown internal error has occurred. + */ + CUDA_ERROR_UNKNOWN = 999 +} CUresult; + +/** + * P2P Attributes + */ +typedef enum CUdevice_P2PAttribute_enum { + CU_DEVICE_P2P_ATTRIBUTE_PERFORMANCE_RANK = 0x01, /**< A relative value indicating the performance of the link between two devices */ + CU_DEVICE_P2P_ATTRIBUTE_ACCESS_SUPPORTED = 0x02, /**< P2P Access is enable */ + CU_DEVICE_P2P_ATTRIBUTE_NATIVE_ATOMIC_SUPPORTED = 0x03, /**< Atomic operation over the link supported */ + CU_DEVICE_P2P_ATTRIBUTE_ACCESS_ACCESS_SUPPORTED = 0x04, /**< \deprecated use CU_DEVICE_P2P_ATTRIBUTE_CUDA_ARRAY_ACCESS_SUPPORTED instead */ + CU_DEVICE_P2P_ATTRIBUTE_CUDA_ARRAY_ACCESS_SUPPORTED = 0x04 /**< Accessing CUDA arrays over the link supported */ +} CUdevice_P2PAttribute; + +/** + * CUDA stream callback + * \param hStream The stream the callback was added to, as passed to ::cuStreamAddCallback. May be NULL. + * \param status ::CUDA_SUCCESS or any persistent error on the stream. + * \param userData User parameter provided at registration. + */ +typedef void (CUDA_CB *CUstreamCallback)(CUstream hStream, CUresult status, void *userData); + +/** + * Block size to per-block dynamic shared memory mapping for a certain + * kernel \param blockSize Block size of the kernel. + * + * \return The dynamic shared memory needed by a block. + */ +typedef size_t (CUDA_CB *CUoccupancyB2DSize)(int blockSize); + +/** + * If set, host memory is portable between CUDA contexts. + * Flag for ::cuMemHostAlloc() + */ +#define CU_MEMHOSTALLOC_PORTABLE 0x01 + +/** + * If set, host memory is mapped into CUDA address space and + * ::cuMemHostGetDevicePointer() may be called on the host pointer. + * Flag for ::cuMemHostAlloc() + */ +#define CU_MEMHOSTALLOC_DEVICEMAP 0x02 + +/** + * If set, host memory is allocated as write-combined - fast to write, + * faster to DMA, slow to read except via SSE4 streaming load instruction + * (MOVNTDQA). + * Flag for ::cuMemHostAlloc() + */ +#define CU_MEMHOSTALLOC_WRITECOMBINED 0x04 + +/** + * If set, host memory is portable between CUDA contexts. + * Flag for ::cuMemHostRegister() + */ +#define CU_MEMHOSTREGISTER_PORTABLE 0x01 + +/** + * If set, host memory is mapped into CUDA address space and + * ::cuMemHostGetDevicePointer() may be called on the host pointer. + * Flag for ::cuMemHostRegister() + */ +#define CU_MEMHOSTREGISTER_DEVICEMAP 0x02 + +/** + * If set, the passed memory pointer is treated as pointing to some + * memory-mapped I/O space, e.g. belonging to a third-party PCIe device. + * On Windows the flag is a no-op. + * On Linux that memory is marked as non cache-coherent for the GPU and + * is expected to be physically contiguous. It may return + * ::CUDA_ERROR_NOT_PERMITTED if run as an unprivileged user, + * ::CUDA_ERROR_NOT_SUPPORTED on older Linux kernel versions. + * On all other platforms, it is not supported and ::CUDA_ERROR_NOT_SUPPORTED + * is returned. + * Flag for ::cuMemHostRegister() + */ +#define CU_MEMHOSTREGISTER_IOMEMORY 0x04 + +/** +* If set, the passed memory pointer is treated as pointing to memory that is +* considered read-only by the device. On platforms without +* ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, this flag is +* required in order to register memory mapped to the CPU as read-only. Support +* for the use of this flag can be queried from the device attribute +* ::CU_DEVICE_ATTRIBUTE_READ_ONLY_HOST_REGISTER_SUPPORTED. Using this flag with +* a current context associated with a device that does not have this attribute +* set will cause ::cuMemHostRegister to error with ::CUDA_ERROR_NOT_SUPPORTED. +*/ +#define CU_MEMHOSTREGISTER_READ_ONLY 0x08 + +/** + * 2D memory copy parameters + */ +typedef struct CUDA_MEMCPY2D_st { + size_t srcXInBytes; /**< Source X in bytes */ + size_t srcY; /**< Source Y */ + + CUmemorytype srcMemoryType; /**< Source memory type (host, device, array) */ + const void *srcHost; /**< Source host pointer */ + CUdeviceptr srcDevice; /**< Source device pointer */ + CUarray srcArray; /**< Source array reference */ + size_t srcPitch; /**< Source pitch (ignored when src is array) */ + + size_t dstXInBytes; /**< Destination X in bytes */ + size_t dstY; /**< Destination Y */ + + CUmemorytype dstMemoryType; /**< Destination memory type (host, device, array) */ + void *dstHost; /**< Destination host pointer */ + CUdeviceptr dstDevice; /**< Destination device pointer */ + CUarray dstArray; /**< Destination array reference */ + size_t dstPitch; /**< Destination pitch (ignored when dst is array) */ + + size_t WidthInBytes; /**< Width of 2D memory copy in bytes */ + size_t Height; /**< Height of 2D memory copy */ +} CUDA_MEMCPY2D_v2; +typedef CUDA_MEMCPY2D_v2 CUDA_MEMCPY2D; + +/** + * 3D memory copy parameters + */ +typedef struct CUDA_MEMCPY3D_st { + size_t srcXInBytes; /**< Source X in bytes */ + size_t srcY; /**< Source Y */ + size_t srcZ; /**< Source Z */ + size_t srcLOD; /**< Source LOD */ + CUmemorytype srcMemoryType; /**< Source memory type (host, device, array) */ + const void *srcHost; /**< Source host pointer */ + CUdeviceptr srcDevice; /**< Source device pointer */ + CUarray srcArray; /**< Source array reference */ + void *reserved0; /**< Must be NULL */ + size_t srcPitch; /**< Source pitch (ignored when src is array) */ + size_t srcHeight; /**< Source height (ignored when src is array; may be 0 if Depth==1) */ + + size_t dstXInBytes; /**< Destination X in bytes */ + size_t dstY; /**< Destination Y */ + size_t dstZ; /**< Destination Z */ + size_t dstLOD; /**< Destination LOD */ + CUmemorytype dstMemoryType; /**< Destination memory type (host, device, array) */ + void *dstHost; /**< Destination host pointer */ + CUdeviceptr dstDevice; /**< Destination device pointer */ + CUarray dstArray; /**< Destination array reference */ + void *reserved1; /**< Must be NULL */ + size_t dstPitch; /**< Destination pitch (ignored when dst is array) */ + size_t dstHeight; /**< Destination height (ignored when dst is array; may be 0 if Depth==1) */ + + size_t WidthInBytes; /**< Width of 3D memory copy in bytes */ + size_t Height; /**< Height of 3D memory copy */ + size_t Depth; /**< Depth of 3D memory copy */ +} CUDA_MEMCPY3D_v2; +typedef CUDA_MEMCPY3D_v2 CUDA_MEMCPY3D; + +/** + * 3D memory cross-context copy parameters + */ +typedef struct CUDA_MEMCPY3D_PEER_st { + size_t srcXInBytes; /**< Source X in bytes */ + size_t srcY; /**< Source Y */ + size_t srcZ; /**< Source Z */ + size_t srcLOD; /**< Source LOD */ + CUmemorytype srcMemoryType; /**< Source memory type (host, device, array) */ + const void *srcHost; /**< Source host pointer */ + CUdeviceptr srcDevice; /**< Source device pointer */ + CUarray srcArray; /**< Source array reference */ + CUcontext srcContext; /**< Source context (ignored with srcMemoryType is ::CU_MEMORYTYPE_ARRAY) */ + size_t srcPitch; /**< Source pitch (ignored when src is array) */ + size_t srcHeight; /**< Source height (ignored when src is array; may be 0 if Depth==1) */ + + size_t dstXInBytes; /**< Destination X in bytes */ + size_t dstY; /**< Destination Y */ + size_t dstZ; /**< Destination Z */ + size_t dstLOD; /**< Destination LOD */ + CUmemorytype dstMemoryType; /**< Destination memory type (host, device, array) */ + void *dstHost; /**< Destination host pointer */ + CUdeviceptr dstDevice; /**< Destination device pointer */ + CUarray dstArray; /**< Destination array reference */ + CUcontext dstContext; /**< Destination context (ignored with dstMemoryType is ::CU_MEMORYTYPE_ARRAY) */ + size_t dstPitch; /**< Destination pitch (ignored when dst is array) */ + size_t dstHeight; /**< Destination height (ignored when dst is array; may be 0 if Depth==1) */ + + size_t WidthInBytes; /**< Width of 3D memory copy in bytes */ + size_t Height; /**< Height of 3D memory copy */ + size_t Depth; /**< Depth of 3D memory copy */ +} CUDA_MEMCPY3D_PEER_v1; +typedef CUDA_MEMCPY3D_PEER_v1 CUDA_MEMCPY3D_PEER; + +/** + * Memcpy node parameters + */ +typedef struct CUDA_MEMCPY_NODE_PARAMS_st { + int flags; /**< Must be zero */ + int reserved; /**< Must be zero */ + CUcontext copyCtx; /**< Context on which to run the node */ + CUDA_MEMCPY3D copyParams; /**< Parameters for the memory copy */ +} CUDA_MEMCPY_NODE_PARAMS; + +/** + * Array descriptor + */ +typedef struct CUDA_ARRAY_DESCRIPTOR_st +{ + size_t Width; /**< Width of array */ + size_t Height; /**< Height of array */ + + CUarray_format Format; /**< Array format */ + unsigned int NumChannels; /**< Channels per array element */ +} CUDA_ARRAY_DESCRIPTOR_v2; +typedef CUDA_ARRAY_DESCRIPTOR_v2 CUDA_ARRAY_DESCRIPTOR; + +/** + * 3D array descriptor + */ +typedef struct CUDA_ARRAY3D_DESCRIPTOR_st +{ + size_t Width; /**< Width of 3D array */ + size_t Height; /**< Height of 3D array */ + size_t Depth; /**< Depth of 3D array */ + + CUarray_format Format; /**< Array format */ + unsigned int NumChannels; /**< Channels per array element */ + unsigned int Flags; /**< Flags */ +} CUDA_ARRAY3D_DESCRIPTOR_v2; +typedef CUDA_ARRAY3D_DESCRIPTOR_v2 CUDA_ARRAY3D_DESCRIPTOR; + +/** + * Indicates that the layered sparse CUDA array or CUDA mipmapped array has a single mip tail region for all layers + */ +#define CU_ARRAY_SPARSE_PROPERTIES_SINGLE_MIPTAIL 0x1 + +/** + * CUDA array sparse properties + */ +typedef struct CUDA_ARRAY_SPARSE_PROPERTIES_st { + struct { + unsigned int width; /**< Width of sparse tile in elements */ + unsigned int height; /**< Height of sparse tile in elements */ + unsigned int depth; /**< Depth of sparse tile in elements */ + } tileExtent; + + /** + * First mip level at which the mip tail begins. + */ + unsigned int miptailFirstLevel; + /** + * Total size of the mip tail. + */ + unsigned long long miptailSize; + /** + * Flags will either be zero or ::CU_ARRAY_SPARSE_PROPERTIES_SINGLE_MIPTAIL + */ + unsigned int flags; + unsigned int reserved[4]; +} CUDA_ARRAY_SPARSE_PROPERTIES_v1; +typedef CUDA_ARRAY_SPARSE_PROPERTIES_v1 CUDA_ARRAY_SPARSE_PROPERTIES; + +/** + * CUDA array memory requirements + */ +typedef struct CUDA_ARRAY_MEMORY_REQUIREMENTS_st { + size_t size; /**< Total required memory size */ + size_t alignment; /**< alignment requirement */ + unsigned int reserved[4]; +} CUDA_ARRAY_MEMORY_REQUIREMENTS_v1; +typedef CUDA_ARRAY_MEMORY_REQUIREMENTS_v1 CUDA_ARRAY_MEMORY_REQUIREMENTS; + +/** + * CUDA Resource descriptor + */ +typedef struct CUDA_RESOURCE_DESC_st +{ + CUresourcetype resType; /**< Resource type */ + + union { + struct { + CUarray hArray; /**< CUDA array */ + } array; + struct { + CUmipmappedArray hMipmappedArray; /**< CUDA mipmapped array */ + } mipmap; + struct { + CUdeviceptr devPtr; /**< Device pointer */ + CUarray_format format; /**< Array format */ + unsigned int numChannels; /**< Channels per array element */ + size_t sizeInBytes; /**< Size in bytes */ + } linear; + struct { + CUdeviceptr devPtr; /**< Device pointer */ + CUarray_format format; /**< Array format */ + unsigned int numChannels; /**< Channels per array element */ + size_t width; /**< Width of the array in elements */ + size_t height; /**< Height of the array in elements */ + size_t pitchInBytes; /**< Pitch between two rows in bytes */ + } pitch2D; + struct { + int reserved[32]; + } reserved; + } res; + + unsigned int flags; /**< Flags (must be zero) */ +} CUDA_RESOURCE_DESC_v1; +typedef CUDA_RESOURCE_DESC_v1 CUDA_RESOURCE_DESC; + +/** + * Texture descriptor + */ +typedef struct CUDA_TEXTURE_DESC_st { + CUaddress_mode addressMode[3]; /**< Address modes */ + CUfilter_mode filterMode; /**< Filter mode */ + unsigned int flags; /**< Flags */ + unsigned int maxAnisotropy; /**< Maximum anisotropy ratio */ + CUfilter_mode mipmapFilterMode; /**< Mipmap filter mode */ + float mipmapLevelBias; /**< Mipmap level bias */ + float minMipmapLevelClamp; /**< Mipmap minimum level clamp */ + float maxMipmapLevelClamp; /**< Mipmap maximum level clamp */ + float borderColor[4]; /**< Border Color */ + int reserved[12]; +} CUDA_TEXTURE_DESC_v1; +typedef CUDA_TEXTURE_DESC_v1 CUDA_TEXTURE_DESC; + +/** + * Resource view format + */ +typedef enum CUresourceViewFormat_enum +{ + CU_RES_VIEW_FORMAT_NONE = 0x00, /**< No resource view format (use underlying resource format) */ + CU_RES_VIEW_FORMAT_UINT_1X8 = 0x01, /**< 1 channel unsigned 8-bit integers */ + CU_RES_VIEW_FORMAT_UINT_2X8 = 0x02, /**< 2 channel unsigned 8-bit integers */ + CU_RES_VIEW_FORMAT_UINT_4X8 = 0x03, /**< 4 channel unsigned 8-bit integers */ + CU_RES_VIEW_FORMAT_SINT_1X8 = 0x04, /**< 1 channel signed 8-bit integers */ + CU_RES_VIEW_FORMAT_SINT_2X8 = 0x05, /**< 2 channel signed 8-bit integers */ + CU_RES_VIEW_FORMAT_SINT_4X8 = 0x06, /**< 4 channel signed 8-bit integers */ + CU_RES_VIEW_FORMAT_UINT_1X16 = 0x07, /**< 1 channel unsigned 16-bit integers */ + CU_RES_VIEW_FORMAT_UINT_2X16 = 0x08, /**< 2 channel unsigned 16-bit integers */ + CU_RES_VIEW_FORMAT_UINT_4X16 = 0x09, /**< 4 channel unsigned 16-bit integers */ + CU_RES_VIEW_FORMAT_SINT_1X16 = 0x0a, /**< 1 channel signed 16-bit integers */ + CU_RES_VIEW_FORMAT_SINT_2X16 = 0x0b, /**< 2 channel signed 16-bit integers */ + CU_RES_VIEW_FORMAT_SINT_4X16 = 0x0c, /**< 4 channel signed 16-bit integers */ + CU_RES_VIEW_FORMAT_UINT_1X32 = 0x0d, /**< 1 channel unsigned 32-bit integers */ + CU_RES_VIEW_FORMAT_UINT_2X32 = 0x0e, /**< 2 channel unsigned 32-bit integers */ + CU_RES_VIEW_FORMAT_UINT_4X32 = 0x0f, /**< 4 channel unsigned 32-bit integers */ + CU_RES_VIEW_FORMAT_SINT_1X32 = 0x10, /**< 1 channel signed 32-bit integers */ + CU_RES_VIEW_FORMAT_SINT_2X32 = 0x11, /**< 2 channel signed 32-bit integers */ + CU_RES_VIEW_FORMAT_SINT_4X32 = 0x12, /**< 4 channel signed 32-bit integers */ + CU_RES_VIEW_FORMAT_FLOAT_1X16 = 0x13, /**< 1 channel 16-bit floating point */ + CU_RES_VIEW_FORMAT_FLOAT_2X16 = 0x14, /**< 2 channel 16-bit floating point */ + CU_RES_VIEW_FORMAT_FLOAT_4X16 = 0x15, /**< 4 channel 16-bit floating point */ + CU_RES_VIEW_FORMAT_FLOAT_1X32 = 0x16, /**< 1 channel 32-bit floating point */ + CU_RES_VIEW_FORMAT_FLOAT_2X32 = 0x17, /**< 2 channel 32-bit floating point */ + CU_RES_VIEW_FORMAT_FLOAT_4X32 = 0x18, /**< 4 channel 32-bit floating point */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC1 = 0x19, /**< Block compressed 1 */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC2 = 0x1a, /**< Block compressed 2 */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC3 = 0x1b, /**< Block compressed 3 */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC4 = 0x1c, /**< Block compressed 4 unsigned */ + CU_RES_VIEW_FORMAT_SIGNED_BC4 = 0x1d, /**< Block compressed 4 signed */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC5 = 0x1e, /**< Block compressed 5 unsigned */ + CU_RES_VIEW_FORMAT_SIGNED_BC5 = 0x1f, /**< Block compressed 5 signed */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC6H = 0x20, /**< Block compressed 6 unsigned half-float */ + CU_RES_VIEW_FORMAT_SIGNED_BC6H = 0x21, /**< Block compressed 6 signed half-float */ + CU_RES_VIEW_FORMAT_UNSIGNED_BC7 = 0x22 /**< Block compressed 7 */ +} CUresourceViewFormat; + +/** + * Resource view descriptor + */ +typedef struct CUDA_RESOURCE_VIEW_DESC_st +{ + CUresourceViewFormat format; /**< Resource view format */ + size_t width; /**< Width of the resource view */ + size_t height; /**< Height of the resource view */ + size_t depth; /**< Depth of the resource view */ + unsigned int firstMipmapLevel; /**< First defined mipmap level */ + unsigned int lastMipmapLevel; /**< Last defined mipmap level */ + unsigned int firstLayer; /**< First layer index */ + unsigned int lastLayer; /**< Last layer index */ + unsigned int reserved[16]; +} CUDA_RESOURCE_VIEW_DESC_v1; +typedef CUDA_RESOURCE_VIEW_DESC_v1 CUDA_RESOURCE_VIEW_DESC; + +/** + * Size of tensor map descriptor + */ +#define CU_TENSOR_MAP_NUM_QWORDS 16 + +/** + * Tensor map descriptor. Requires compiler support for aligning to 64 bytes. + */ +typedef struct CUtensorMap_st { +#if defined(__cplusplus) && (__cplusplus >= 201103L) + alignas(64) +#elif __STDC_VERSION__ >= 201112L + _Alignas(64) +#endif + cuuint64_t opaque[CU_TENSOR_MAP_NUM_QWORDS]; +} CUtensorMap; + +/** + * Tensor map data type + */ +typedef enum CUtensorMapDataType_enum { + CU_TENSOR_MAP_DATA_TYPE_UINT8 = 0, + CU_TENSOR_MAP_DATA_TYPE_UINT16, + CU_TENSOR_MAP_DATA_TYPE_UINT32, + CU_TENSOR_MAP_DATA_TYPE_INT32, + CU_TENSOR_MAP_DATA_TYPE_UINT64, + CU_TENSOR_MAP_DATA_TYPE_INT64, + CU_TENSOR_MAP_DATA_TYPE_FLOAT16, + CU_TENSOR_MAP_DATA_TYPE_FLOAT32, + CU_TENSOR_MAP_DATA_TYPE_FLOAT64, + CU_TENSOR_MAP_DATA_TYPE_BFLOAT16, + CU_TENSOR_MAP_DATA_TYPE_FLOAT32_FTZ, + CU_TENSOR_MAP_DATA_TYPE_TFLOAT32, + CU_TENSOR_MAP_DATA_TYPE_TFLOAT32_FTZ, +} CUtensorMapDataType; + +/** + * Tensor map interleave layout type + */ +typedef enum CUtensorMapInterleave_enum { + CU_TENSOR_MAP_INTERLEAVE_NONE = 0, + CU_TENSOR_MAP_INTERLEAVE_16B, + CU_TENSOR_MAP_INTERLEAVE_32B +} CUtensorMapInterleave; + +/** + * Tensor map swizzling mode of shared memory banks + */ +typedef enum CUtensorMapSwizzle_enum { + CU_TENSOR_MAP_SWIZZLE_NONE = 0, + CU_TENSOR_MAP_SWIZZLE_32B, + CU_TENSOR_MAP_SWIZZLE_64B, + CU_TENSOR_MAP_SWIZZLE_128B, +} CUtensorMapSwizzle; + +/** + * Tensor map L2 promotion type + */ +typedef enum CUtensorMapL2promotion_enum { + CU_TENSOR_MAP_L2_PROMOTION_NONE = 0, + CU_TENSOR_MAP_L2_PROMOTION_L2_64B, + CU_TENSOR_MAP_L2_PROMOTION_L2_128B, + CU_TENSOR_MAP_L2_PROMOTION_L2_256B +} CUtensorMapL2promotion; + +/** + * Tensor map out-of-bounds fill type + */ +typedef enum CUtensorMapFloatOOBfill_enum { + CU_TENSOR_MAP_FLOAT_OOB_FILL_NONE = 0, + CU_TENSOR_MAP_FLOAT_OOB_FILL_NAN_REQUEST_ZERO_FMA +} CUtensorMapFloatOOBfill; + +/** + * GPU Direct v3 tokens + */ +typedef struct CUDA_POINTER_ATTRIBUTE_P2P_TOKENS_st { + unsigned long long p2pToken; + unsigned int vaSpaceToken; +} CUDA_POINTER_ATTRIBUTE_P2P_TOKENS_v1; +typedef CUDA_POINTER_ATTRIBUTE_P2P_TOKENS_v1 CUDA_POINTER_ATTRIBUTE_P2P_TOKENS; + +/** +* Access flags that specify the level of access the current context's device has +* on the memory referenced. +*/ +typedef enum CUDA_POINTER_ATTRIBUTE_ACCESS_FLAGS_enum { + CU_POINTER_ATTRIBUTE_ACCESS_FLAG_NONE = 0x0, /**< No access, meaning the device cannot access this memory at all, thus must be staged through accessible memory in order to complete certain operations */ + CU_POINTER_ATTRIBUTE_ACCESS_FLAG_READ = 0x1, /**< Read-only access, meaning writes to this memory are considered invalid accesses and thus return error in that case. */ + CU_POINTER_ATTRIBUTE_ACCESS_FLAG_READWRITE = 0x3 /**< Read-write access, the device has full read-write access to the memory */ +} CUDA_POINTER_ATTRIBUTE_ACCESS_FLAGS; + +/** + * Kernel launch parameters + */ +typedef struct CUDA_LAUNCH_PARAMS_st { + CUfunction function; /**< Kernel to launch */ + unsigned int gridDimX; /**< Width of grid in blocks */ + unsigned int gridDimY; /**< Height of grid in blocks */ + unsigned int gridDimZ; /**< Depth of grid in blocks */ + unsigned int blockDimX; /**< X dimension of each thread block */ + unsigned int blockDimY; /**< Y dimension of each thread block */ + unsigned int blockDimZ; /**< Z dimension of each thread block */ + unsigned int sharedMemBytes; /**< Dynamic shared-memory size per thread block in bytes */ + CUstream hStream; /**< Stream identifier */ + void **kernelParams; /**< Array of pointers to kernel parameters */ +} CUDA_LAUNCH_PARAMS_v1; +typedef CUDA_LAUNCH_PARAMS_v1 CUDA_LAUNCH_PARAMS; + +/** + * External memory handle types + */ +typedef enum CUexternalMemoryHandleType_enum { + /** + * Handle is an opaque file descriptor + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD = 1, + /** + * Handle is an opaque shared NT handle + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32 = 2, + /** + * Handle is an opaque, globally shared handle + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT = 3, + /** + * Handle is a D3D12 heap object + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP = 4, + /** + * Handle is a D3D12 committed resource + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE = 5, + /** + * Handle is a shared NT handle to a D3D11 resource + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE = 6, + /** + * Handle is a globally shared handle to a D3D11 resource + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE_KMT = 7, + /** + * Handle is an NvSciBuf object + */ + CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF = 8 +} CUexternalMemoryHandleType; + +/** + * Indicates that the external memory object is a dedicated resource + */ +#define CUDA_EXTERNAL_MEMORY_DEDICATED 0x1 + +/** When the \p flags parameter of ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS + * contains this flag, it indicates that signaling an external semaphore object + * should skip performing appropriate memory synchronization operations over all + * the external memory objects that are imported as ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF, + * which otherwise are performed by default to ensure data coherency with other + * importers of the same NvSciBuf memory objects. + */ +#define CUDA_EXTERNAL_SEMAPHORE_SIGNAL_SKIP_NVSCIBUF_MEMSYNC 0x01 + +/** When the \p flags parameter of ::CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS + * contains this flag, it indicates that waiting on an external semaphore object + * should skip performing appropriate memory synchronization operations over all + * the external memory objects that are imported as ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF, + * which otherwise are performed by default to ensure data coherency with other + * importers of the same NvSciBuf memory objects. + */ +#define CUDA_EXTERNAL_SEMAPHORE_WAIT_SKIP_NVSCIBUF_MEMSYNC 0x02 + +/** + * When \p flags of ::cuDeviceGetNvSciSyncAttributes is set to this, + * it indicates that application needs signaler specific NvSciSyncAttr + * to be filled by ::cuDeviceGetNvSciSyncAttributes. + */ +#define CUDA_NVSCISYNC_ATTR_SIGNAL 0x1 + +/** + * When \p flags of ::cuDeviceGetNvSciSyncAttributes is set to this, + * it indicates that application needs waiter specific NvSciSyncAttr + * to be filled by ::cuDeviceGetNvSciSyncAttributes. + */ +#define CUDA_NVSCISYNC_ATTR_WAIT 0x2 +/** + * External memory handle descriptor + */ +typedef struct CUDA_EXTERNAL_MEMORY_HANDLE_DESC_st { + /** + * Type of the handle + */ + CUexternalMemoryHandleType type; + union { + /** + * File descriptor referencing the memory object. Valid + * when type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD + */ + int fd; + /** + * Win32 handle referencing the semaphore object. Valid when + * type is one of the following: + * - ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32 + * - ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT + * - ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP + * - ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE + * - ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE + * - ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE_KMT + * Exactly one of 'handle' and 'name' must be non-NULL. If + * type is one of the following: + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE_KMT + * then 'name' must be NULL. + */ + struct { + /** + * Valid NT handle. Must be NULL if 'name' is non-NULL + */ + void *handle; + /** + * Name of a valid memory object. + * Must be NULL if 'handle' is non-NULL. + */ + const void *name; + } win32; + /** + * A handle representing an NvSciBuf Object. Valid when type + * is ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF + */ + const void *nvSciBufObject; + } handle; + /** + * Size of the memory allocation + */ + unsigned long long size; + /** + * Flags must either be zero or ::CUDA_EXTERNAL_MEMORY_DEDICATED + */ + unsigned int flags; + unsigned int reserved[16]; +} CUDA_EXTERNAL_MEMORY_HANDLE_DESC_v1; +typedef CUDA_EXTERNAL_MEMORY_HANDLE_DESC_v1 CUDA_EXTERNAL_MEMORY_HANDLE_DESC; + +/** + * External memory buffer descriptor + */ +typedef struct CUDA_EXTERNAL_MEMORY_BUFFER_DESC_st { + /** + * Offset into the memory object where the buffer's base is + */ + unsigned long long offset; + /** + * Size of the buffer + */ + unsigned long long size; + /** + * Flags reserved for future use. Must be zero. + */ + unsigned int flags; + unsigned int reserved[16]; +} CUDA_EXTERNAL_MEMORY_BUFFER_DESC_v1; +typedef CUDA_EXTERNAL_MEMORY_BUFFER_DESC_v1 CUDA_EXTERNAL_MEMORY_BUFFER_DESC; + +/** + * External memory mipmap descriptor + */ +typedef struct CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC_st { + /** + * Offset into the memory object where the base level of the + * mipmap chain is. + */ + unsigned long long offset; + /** + * Format, dimension and type of base level of the mipmap chain + */ + CUDA_ARRAY3D_DESCRIPTOR arrayDesc; + /** + * Total number of levels in the mipmap chain + */ + unsigned int numLevels; + unsigned int reserved[16]; +} CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC_v1; +typedef CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC_v1 CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC; + +/** + * External semaphore handle types + */ +typedef enum CUexternalSemaphoreHandleType_enum { + /** + * Handle is an opaque file descriptor + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD = 1, + /** + * Handle is an opaque shared NT handle + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32 = 2, + /** + * Handle is an opaque, globally shared handle + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT = 3, + /** + * Handle is a shared NT handle referencing a D3D12 fence object + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE = 4, + /** + * Handle is a shared NT handle referencing a D3D11 fence object + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_FENCE = 5, + /** + * Opaque handle to NvSciSync Object + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC = 6, + /** + * Handle is a shared NT handle referencing a D3D11 keyed mutex object + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX = 7, + /** + * Handle is a globally shared handle referencing a D3D11 keyed mutex object + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX_KMT = 8, + /** + * Handle is an opaque file descriptor referencing a timeline semaphore + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_FD = 9, + /** + * Handle is an opaque shared NT handle referencing a timeline semaphore + */ + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_WIN32 = 10 +} CUexternalSemaphoreHandleType; + +/** + * External semaphore handle descriptor + */ +typedef struct CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC_st { + /** + * Type of the handle + */ + CUexternalSemaphoreHandleType type; + union { + /** + * File descriptor referencing the semaphore object. Valid + * when type is one of the following: + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_FD + */ + int fd; + /** + * Win32 handle referencing the semaphore object. Valid when + * type is one of the following: + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32 + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_FENCE + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_WIN32 + * Exactly one of 'handle' and 'name' must be non-NULL. If + * type is one of the following: + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT + * - ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX_KMT + * then 'name' must be NULL. + */ + struct { + /** + * Valid NT handle. Must be NULL if 'name' is non-NULL + */ + void *handle; + /** + * Name of a valid synchronization primitive. + * Must be NULL if 'handle' is non-NULL. + */ + const void *name; + } win32; + /** + * Valid NvSciSyncObj. Must be non NULL + */ + const void* nvSciSyncObj; + } handle; + /** + * Flags reserved for the future. Must be zero. + */ + unsigned int flags; + unsigned int reserved[16]; +} CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC_v1; +typedef CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC_v1 CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC; + +/** + * External semaphore signal parameters + */ +typedef struct CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS_st { + struct { + /** + * Parameters for fence objects + */ + struct { + /** + * Value of fence to be signaled + */ + unsigned long long value; + } fence; + union { + /** + * Pointer to NvSciSyncFence. Valid if ::CUexternalSemaphoreHandleType + * is of type ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC. + */ + void *fence; + unsigned long long reserved; + } nvSciSync; + /** + * Parameters for keyed mutex objects + */ + struct { + /** + * Value of key to release the mutex with + */ + unsigned long long key; + } keyedMutex; + unsigned int reserved[12]; + } params; + /** + * Only when ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS is used to + * signal a ::CUexternalSemaphore of type + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC, the valid flag is + * ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_SKIP_NVSCIBUF_MEMSYNC which indicates + * that while signaling the ::CUexternalSemaphore, no memory synchronization + * operations should be performed for any external memory object imported + * as ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF. + * For all other types of ::CUexternalSemaphore, flags must be zero. + */ + unsigned int flags; + unsigned int reserved[16]; +} CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS_v1; +typedef CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS_v1 CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS; + +/** + * External semaphore wait parameters + */ +typedef struct CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS_st { + struct { + /** + * Parameters for fence objects + */ + struct { + /** + * Value of fence to be waited on + */ + unsigned long long value; + } fence; + /** + * Pointer to NvSciSyncFence. Valid if CUexternalSemaphoreHandleType + * is of type CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC. + */ + union { + void *fence; + unsigned long long reserved; + } nvSciSync; + /** + * Parameters for keyed mutex objects + */ + struct { + /** + * Value of key to acquire the mutex with + */ + unsigned long long key; + /** + * Timeout in milliseconds to wait to acquire the mutex + */ + unsigned int timeoutMs; + } keyedMutex; + unsigned int reserved[10]; + } params; + /** + * Only when ::CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS is used to wait on + * a ::CUexternalSemaphore of type ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC, + * the valid flag is ::CUDA_EXTERNAL_SEMAPHORE_WAIT_SKIP_NVSCIBUF_MEMSYNC + * which indicates that while waiting for the ::CUexternalSemaphore, no memory + * synchronization operations should be performed for any external memory + * object imported as ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF. + * For all other types of ::CUexternalSemaphore, flags must be zero. + */ + unsigned int flags; + unsigned int reserved[16]; +} CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS_v1; +typedef CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS_v1 CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS; + +/** + * Semaphore signal node parameters + */ +typedef struct CUDA_EXT_SEM_SIGNAL_NODE_PARAMS_st { + CUexternalSemaphore* extSemArray; /**< Array of external semaphore handles. */ + const CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS* paramsArray; /**< Array of external semaphore signal parameters. */ + unsigned int numExtSems; /**< Number of handles and parameters supplied in extSemArray and paramsArray. */ +} CUDA_EXT_SEM_SIGNAL_NODE_PARAMS_v1; +typedef CUDA_EXT_SEM_SIGNAL_NODE_PARAMS_v1 CUDA_EXT_SEM_SIGNAL_NODE_PARAMS; + +/** + * Semaphore signal node parameters + */ +typedef struct CUDA_EXT_SEM_SIGNAL_NODE_PARAMS_v2_st { + CUexternalSemaphore* extSemArray; /**< Array of external semaphore handles. */ + const CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS* paramsArray; /**< Array of external semaphore signal parameters. */ + unsigned int numExtSems; /**< Number of handles and parameters supplied in extSemArray and paramsArray. */ +} CUDA_EXT_SEM_SIGNAL_NODE_PARAMS_v2; + +/** + * Semaphore wait node parameters + */ +typedef struct CUDA_EXT_SEM_WAIT_NODE_PARAMS_st { + CUexternalSemaphore* extSemArray; /**< Array of external semaphore handles. */ + const CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS* paramsArray; /**< Array of external semaphore wait parameters. */ + unsigned int numExtSems; /**< Number of handles and parameters supplied in extSemArray and paramsArray. */ +} CUDA_EXT_SEM_WAIT_NODE_PARAMS_v1; +typedef CUDA_EXT_SEM_WAIT_NODE_PARAMS_v1 CUDA_EXT_SEM_WAIT_NODE_PARAMS; + +/** + * Semaphore wait node parameters + */ +typedef struct CUDA_EXT_SEM_WAIT_NODE_PARAMS_v2_st { + CUexternalSemaphore* extSemArray; /**< Array of external semaphore handles. */ + const CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS* paramsArray; /**< Array of external semaphore wait parameters. */ + unsigned int numExtSems; /**< Number of handles and parameters supplied in extSemArray and paramsArray. */ +} CUDA_EXT_SEM_WAIT_NODE_PARAMS_v2; + +typedef unsigned long long CUmemGenericAllocationHandle_v1; +typedef CUmemGenericAllocationHandle_v1 CUmemGenericAllocationHandle; + +/** + * Flags for specifying particular handle types + */ +typedef enum CUmemAllocationHandleType_enum { + CU_MEM_HANDLE_TYPE_NONE = 0x0, /**< Does not allow any export mechanism. > */ + CU_MEM_HANDLE_TYPE_POSIX_FILE_DESCRIPTOR = 0x1, /**< Allows a file descriptor to be used for exporting. Permitted only on POSIX systems. (int) */ + CU_MEM_HANDLE_TYPE_WIN32 = 0x2, /**< Allows a Win32 NT handle to be used for exporting. (HANDLE) */ + CU_MEM_HANDLE_TYPE_WIN32_KMT = 0x4, /**< Allows a Win32 KMT handle to be used for exporting. (D3DKMT_HANDLE) */ + CU_MEM_HANDLE_TYPE_FABRIC = 0x8, /**< Allows a fabric handle to be used for exporting. (CUmemFabricHandle)*/ + CU_MEM_HANDLE_TYPE_MAX = 0x7FFFFFFF +} CUmemAllocationHandleType; + +/** + * Specifies the memory protection flags for mapping. + */ +typedef enum CUmemAccess_flags_enum { + CU_MEM_ACCESS_FLAGS_PROT_NONE = 0x0, /**< Default, make the address range not accessible */ + CU_MEM_ACCESS_FLAGS_PROT_READ = 0x1, /**< Make the address range read accessible */ + CU_MEM_ACCESS_FLAGS_PROT_READWRITE = 0x3, /**< Make the address range read-write accessible */ + CU_MEM_ACCESS_FLAGS_PROT_MAX = 0x7FFFFFFF +} CUmemAccess_flags; + +/** + * Specifies the type of location + */ +typedef enum CUmemLocationType_enum { + CU_MEM_LOCATION_TYPE_INVALID = 0x0, + CU_MEM_LOCATION_TYPE_DEVICE = 0x1, /**< Location is a device location, thus id is a device ordinal */ + CU_MEM_LOCATION_TYPE_HOST = 0x2, /**< Location is host, id is ignored */ + CU_MEM_LOCATION_TYPE_HOST_NUMA = 0x3, /**< Location is a host NUMA node, thus id is a host NUMA node id */ + CU_MEM_LOCATION_TYPE_HOST_NUMA_CURRENT = 0x4, /**< Location is a host NUMA node of the current thread, id is ignored */ + CU_MEM_LOCATION_TYPE_MAX = 0x7FFFFFFF +} CUmemLocationType; + +/** +* Defines the allocation types available +*/ +typedef enum CUmemAllocationType_enum { + CU_MEM_ALLOCATION_TYPE_INVALID = 0x0, + + /** This allocation type is 'pinned', i.e. cannot migrate from its current + * location while the application is actively using it + */ + CU_MEM_ALLOCATION_TYPE_PINNED = 0x1, + CU_MEM_ALLOCATION_TYPE_MAX = 0x7FFFFFFF +} CUmemAllocationType; + +/** +* Flag for requesting different optimal and required granularities for an allocation. +*/ +typedef enum CUmemAllocationGranularity_flags_enum { + CU_MEM_ALLOC_GRANULARITY_MINIMUM = 0x0, /**< Minimum required granularity for allocation */ + CU_MEM_ALLOC_GRANULARITY_RECOMMENDED = 0x1 /**< Recommended granularity for allocation for best performance */ +} CUmemAllocationGranularity_flags; + +/** +* Specifies the handle type for address range +*/ +typedef enum CUmemRangeHandleType_enum +{ + CU_MEM_RANGE_HANDLE_TYPE_DMA_BUF_FD = 0x1, + CU_MEM_RANGE_HANDLE_TYPE_MAX = 0x7FFFFFFF +} CUmemRangeHandleType; + +/** + * Sparse subresource types + */ +typedef enum CUarraySparseSubresourceType_enum { + CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_SPARSE_LEVEL = 0, + CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_MIPTAIL = 1 +} CUarraySparseSubresourceType; + +/** + * Memory operation types + */ +typedef enum CUmemOperationType_enum { + CU_MEM_OPERATION_TYPE_MAP = 1, + CU_MEM_OPERATION_TYPE_UNMAP = 2 +} CUmemOperationType; + +/** + * Memory handle types + */ +typedef enum CUmemHandleType_enum { + CU_MEM_HANDLE_TYPE_GENERIC = 0 +} CUmemHandleType; + +/** + * Specifies the CUDA array or CUDA mipmapped array memory mapping information + */ +typedef struct CUarrayMapInfo_st { + CUresourcetype resourceType; /**< Resource type */ + + union { + CUmipmappedArray mipmap; + CUarray array; + } resource; + + CUarraySparseSubresourceType subresourceType; /**< Sparse subresource type */ + + union { + struct { + unsigned int level; /**< For CUDA mipmapped arrays must a valid mipmap level. For CUDA arrays must be zero */ + unsigned int layer; /**< For CUDA layered arrays must be a valid layer index. Otherwise, must be zero */ + unsigned int offsetX; /**< Starting X offset in elements */ + unsigned int offsetY; /**< Starting Y offset in elements */ + unsigned int offsetZ; /**< Starting Z offset in elements */ + unsigned int extentWidth; /**< Width in elements */ + unsigned int extentHeight; /**< Height in elements */ + unsigned int extentDepth; /**< Depth in elements */ + } sparseLevel; + struct { + unsigned int layer; /**< For CUDA layered arrays must be a valid layer index. Otherwise, must be zero */ + unsigned long long offset; /**< Offset within mip tail */ + unsigned long long size; /**< Extent in bytes */ + } miptail; + } subresource; + + CUmemOperationType memOperationType; /**< Memory operation type */ + CUmemHandleType memHandleType; /**< Memory handle type */ + + union { + CUmemGenericAllocationHandle memHandle; + } memHandle; + + unsigned long long offset; /**< Offset within the memory */ + unsigned int deviceBitMask; /**< Device ordinal bit mask */ + unsigned int flags; /**< flags for future use, must be zero now. */ + unsigned int reserved[2]; /**< Reserved for future use, must be zero now. */ +} CUarrayMapInfo_v1; +typedef CUarrayMapInfo_v1 CUarrayMapInfo; + +/** + * Specifies a memory location. + */ +typedef struct CUmemLocation_st { + CUmemLocationType type; /**< Specifies the location type, which modifies the meaning of id. */ + int id; /**< identifier for a given this location's ::CUmemLocationType. */ +} CUmemLocation_v1; +typedef CUmemLocation_v1 CUmemLocation; + +/** + * Specifies compression attribute for an allocation. + */ +typedef enum CUmemAllocationCompType_enum { + CU_MEM_ALLOCATION_COMP_NONE = 0x0, /**< Allocating non-compressible memory */ + CU_MEM_ALLOCATION_COMP_GENERIC = 0x1 /**< Allocating compressible memory */ +} CUmemAllocationCompType; + +/** + * This flag if set indicates that the memory will be used as a tile pool. + */ +#define CU_MEM_CREATE_USAGE_TILE_POOL 0x1 + +/** +* Specifies the allocation properties for a allocation. +*/ +typedef struct CUmemAllocationProp_st { + /** Allocation type */ + CUmemAllocationType type; + /** requested ::CUmemAllocationHandleType */ + CUmemAllocationHandleType requestedHandleTypes; + /** Location of allocation */ + CUmemLocation location; + /** + * Windows-specific POBJECT_ATTRIBUTES required when + * ::CU_MEM_HANDLE_TYPE_WIN32 is specified. This object attributes structure + * includes security attributes that define + * the scope of which exported allocations may be transferred to other + * processes. In all other cases, this field is required to be zero. + */ + void *win32HandleMetaData; + struct { + /** + * Allocation hint for requesting compressible memory. + * On devices that support Compute Data Compression, compressible + * memory can be used to accelerate accesses to data with unstructured + * sparsity and other compressible data patterns. Applications are + * expected to query allocation property of the handle obtained with + * ::cuMemCreate using ::cuMemGetAllocationPropertiesFromHandle to + * validate if the obtained allocation is compressible or not. Note that + * compressed memory may not be mappable on all devices. + */ + unsigned char compressionType; + unsigned char gpuDirectRDMACapable; + /** Bitmask indicating intended usage for this allocation */ + unsigned short usage; + unsigned char reserved[4]; + } allocFlags; +} CUmemAllocationProp_v1; +typedef CUmemAllocationProp_v1 CUmemAllocationProp; + +/** +* Flags for querying different granularities for a multicast object +*/ +typedef enum CUmulticastGranularity_flags_enum { + CU_MULTICAST_GRANULARITY_MINIMUM = 0x0, /**< Minimum required granularity */ + CU_MULTICAST_GRANULARITY_RECOMMENDED = 0x1 /**< Recommended granularity for best performance */ +} CUmulticastGranularity_flags; + +/** +* Specifies the properties for a multicast object. +*/ +typedef struct CUmulticastObjectProp_st { + /** + * The number of devices in the multicast team that will bind memory to this + * object + */ + unsigned int numDevices; + /** + * The maximum amount of memory that can be bound to this multicast object + * per device + */ + size_t size; + /** + * Bitmask of exportable handle types (see ::CUmemAllocationHandleType) for + * this object + */ + unsigned long long handleTypes; + /** + * Flags for future use, must be zero now + */ + unsigned long long flags; +} CUmulticastObjectProp_v1; +typedef CUmulticastObjectProp_v1 CUmulticastObjectProp; + +/** + * Memory access descriptor + */ +typedef struct CUmemAccessDesc_st { + CUmemLocation location; /**< Location on which the request is to change it's accessibility */ + CUmemAccess_flags flags; /**< ::CUmemProt accessibility flags to set on the request */ +} CUmemAccessDesc_v1; +typedef CUmemAccessDesc_v1 CUmemAccessDesc; + +/** + * CUDA Graph Update error types + */ +typedef enum CUgraphExecUpdateResult_enum { + CU_GRAPH_EXEC_UPDATE_SUCCESS = 0x0, /**< The update succeeded */ + CU_GRAPH_EXEC_UPDATE_ERROR = 0x1, /**< The update failed for an unexpected reason which is described in the return value of the function */ + CU_GRAPH_EXEC_UPDATE_ERROR_TOPOLOGY_CHANGED = 0x2, /**< The update failed because the topology changed */ + CU_GRAPH_EXEC_UPDATE_ERROR_NODE_TYPE_CHANGED = 0x3, /**< The update failed because a node type changed */ + CU_GRAPH_EXEC_UPDATE_ERROR_FUNCTION_CHANGED = 0x4, /**< The update failed because the function of a kernel node changed (CUDA driver < 11.2) */ + CU_GRAPH_EXEC_UPDATE_ERROR_PARAMETERS_CHANGED = 0x5, /**< The update failed because the parameters changed in a way that is not supported */ + CU_GRAPH_EXEC_UPDATE_ERROR_NOT_SUPPORTED = 0x6, /**< The update failed because something about the node is not supported */ + CU_GRAPH_EXEC_UPDATE_ERROR_UNSUPPORTED_FUNCTION_CHANGE = 0x7, /**< The update failed because the function of a kernel node changed in an unsupported way */ + CU_GRAPH_EXEC_UPDATE_ERROR_ATTRIBUTES_CHANGED = 0x8 /**< The update failed because the node attributes changed in a way that is not supported */ +} CUgraphExecUpdateResult; + +/** + * Result information returned by cuGraphExecUpdate + */ +typedef struct CUgraphExecUpdateResultInfo_st { + /** + * Gives more specific detail when a cuda graph update fails. + */ + CUgraphExecUpdateResult result; + + /** + * The "to node" of the error edge when the topologies do not match. + * The error node when the error is associated with a specific node. + * NULL when the error is generic. + */ + CUgraphNode errorNode; + + /** + * The from node of error edge when the topologies do not match. Otherwise NULL. + */ + CUgraphNode errorFromNode; +} CUgraphExecUpdateResultInfo_v1; +typedef CUgraphExecUpdateResultInfo_v1 CUgraphExecUpdateResultInfo; + +/** + * CUDA memory pool attributes + */ +typedef enum CUmemPool_attribute_enum { + /** + * (value type = int) + * Allow cuMemAllocAsync to use memory asynchronously freed + * in another streams as long as a stream ordering dependency + * of the allocating stream on the free action exists. + * Cuda events and null stream interactions can create the required + * stream ordered dependencies. (default enabled) + */ + CU_MEMPOOL_ATTR_REUSE_FOLLOW_EVENT_DEPENDENCIES = 1, + + /** + * (value type = int) + * Allow reuse of already completed frees when there is no dependency + * between the free and allocation. (default enabled) + */ + CU_MEMPOOL_ATTR_REUSE_ALLOW_OPPORTUNISTIC, + + /** + * (value type = int) + * Allow cuMemAllocAsync to insert new stream dependencies + * in order to establish the stream ordering required to reuse + * a piece of memory released by cuFreeAsync (default enabled). + */ + CU_MEMPOOL_ATTR_REUSE_ALLOW_INTERNAL_DEPENDENCIES, + + /** + * (value type = cuuint64_t) + * Amount of reserved memory in bytes to hold onto before trying + * to release memory back to the OS. When more than the release + * threshold bytes of memory are held by the memory pool, the + * allocator will try to release memory back to the OS on the + * next call to stream, event or context synchronize. (default 0) + */ + CU_MEMPOOL_ATTR_RELEASE_THRESHOLD, + + /** + * (value type = cuuint64_t) + * Amount of backing memory currently allocated for the mempool. + */ + CU_MEMPOOL_ATTR_RESERVED_MEM_CURRENT, + + /** + * (value type = cuuint64_t) + * High watermark of backing memory allocated for the mempool since the + * last time it was reset. High watermark can only be reset to zero. + */ + CU_MEMPOOL_ATTR_RESERVED_MEM_HIGH, + + /** + * (value type = cuuint64_t) + * Amount of memory from the pool that is currently in use by the application. + */ + CU_MEMPOOL_ATTR_USED_MEM_CURRENT, + + /** + * (value type = cuuint64_t) + * High watermark of the amount of memory from the pool that was in use by the application since + * the last time it was reset. High watermark can only be reset to zero. + */ + CU_MEMPOOL_ATTR_USED_MEM_HIGH +} CUmemPool_attribute; + +/** + * Specifies the properties of allocations made from the pool. + */ +typedef struct CUmemPoolProps_st { + CUmemAllocationType allocType; /**< Allocation type. Currently must be specified as CU_MEM_ALLOCATION_TYPE_PINNED */ + CUmemAllocationHandleType handleTypes; /**< Handle types that will be supported by allocations from the pool. */ + CUmemLocation location; /**< Location where allocations should reside. */ + /** + * Windows-specific LPSECURITYATTRIBUTES required when + * ::CU_MEM_HANDLE_TYPE_WIN32 is specified. This security attribute defines + * the scope of which exported allocations may be transferred to other + * processes. In all other cases, this field is required to be zero. + */ + void *win32SecurityAttributes; + size_t maxSize; /**< Maximum pool size. When set to 0, defaults to a system dependent value. */ + unsigned short usage; /**< Bitmask indicating intended usage for the pool. */ + unsigned char reserved[54]; /**< reserved for future use, must be 0 */ +} CUmemPoolProps_v1; +typedef CUmemPoolProps_v1 CUmemPoolProps; + +/** + * Opaque data for exporting a pool allocation + */ +typedef struct CUmemPoolPtrExportData_st { + unsigned char reserved[64]; +} CUmemPoolPtrExportData_v1; +typedef CUmemPoolPtrExportData_v1 CUmemPoolPtrExportData; + +/** + * Memory allocation node parameters + */ +typedef struct CUDA_MEM_ALLOC_NODE_PARAMS_v1_st { + /** + * in: location where the allocation should reside (specified in ::location). + * ::handleTypes must be ::CU_MEM_HANDLE_TYPE_NONE. IPC is not supported. + */ + CUmemPoolProps poolProps; + const CUmemAccessDesc *accessDescs; /**< in: array of memory access descriptors. Used to describe peer GPU access */ + size_t accessDescCount; /**< in: number of memory access descriptors. Must not exceed the number of GPUs. */ + size_t bytesize; /**< in: size in bytes of the requested allocation */ + CUdeviceptr dptr; /**< out: address of the allocation returned by CUDA */ +} CUDA_MEM_ALLOC_NODE_PARAMS_v1; +typedef CUDA_MEM_ALLOC_NODE_PARAMS_v1 CUDA_MEM_ALLOC_NODE_PARAMS; + +/** + * Memory allocation node parameters + */ +typedef struct CUDA_MEM_ALLOC_NODE_PARAMS_v2_st { + /** + * in: location where the allocation should reside (specified in ::location). + * ::handleTypes must be ::CU_MEM_HANDLE_TYPE_NONE. IPC is not supported. + */ + CUmemPoolProps poolProps; + const CUmemAccessDesc *accessDescs; /**< in: array of memory access descriptors. Used to describe peer GPU access */ + size_t accessDescCount; /**< in: number of memory access descriptors. Must not exceed the number of GPUs. */ + size_t bytesize; /**< in: size in bytes of the requested allocation */ + CUdeviceptr dptr; /**< out: address of the allocation returned by CUDA */ +} CUDA_MEM_ALLOC_NODE_PARAMS_v2; + +/** + * Memory free node parameters + */ +typedef struct CUDA_MEM_FREE_NODE_PARAMS_st { + CUdeviceptr dptr; /**< in: the pointer to free */ +} CUDA_MEM_FREE_NODE_PARAMS; + +typedef enum CUgraphMem_attribute_enum { + /** + * (value type = cuuint64_t) + * Amount of memory, in bytes, currently associated with graphs + */ + CU_GRAPH_MEM_ATTR_USED_MEM_CURRENT, + + /** + * (value type = cuuint64_t) + * High watermark of memory, in bytes, associated with graphs since the + * last time it was reset. High watermark can only be reset to zero. + */ + CU_GRAPH_MEM_ATTR_USED_MEM_HIGH, + + /** + * (value type = cuuint64_t) + * Amount of memory, in bytes, currently allocated for use by + * the CUDA graphs asynchronous allocator. + */ + CU_GRAPH_MEM_ATTR_RESERVED_MEM_CURRENT, + + /** + * (value type = cuuint64_t) + * High watermark of memory, in bytes, currently allocated for use by + * the CUDA graphs asynchronous allocator. + */ + CU_GRAPH_MEM_ATTR_RESERVED_MEM_HIGH +} CUgraphMem_attribute; + +/** + * Child graph node parameters + */ +typedef struct CUDA_CHILD_GRAPH_NODE_PARAMS_st { + CUgraph graph; /**< The child graph to clone into the node for node creation, or + a handle to the graph owned by the node for node query */ +} CUDA_CHILD_GRAPH_NODE_PARAMS; + +/** + * Event record node parameters + */ +typedef struct CUDA_EVENT_RECORD_NODE_PARAMS_st { + CUevent event; /**< The event to record when the node executes */ +} CUDA_EVENT_RECORD_NODE_PARAMS; + +/** + * Event wait node parameters + */ +typedef struct CUDA_EVENT_WAIT_NODE_PARAMS_st { + CUevent event; /**< The event to wait on from the node */ +} CUDA_EVENT_WAIT_NODE_PARAMS; + +/** + * Graph node parameters. See ::cuGraphAddNode. + */ +typedef struct CUgraphNodeParams_st { + CUgraphNodeType type; /**< Type of the node */ + int reserved0[3]; /**< Reserved. Must be zero. */ + + union { + long long reserved1[29]; /**< Padding. Unused bytes must be zero. */ + CUDA_KERNEL_NODE_PARAMS_v3 kernel; /**< Kernel node parameters. */ + CUDA_MEMCPY_NODE_PARAMS memcpy; /**< Memcpy node parameters. */ + CUDA_MEMSET_NODE_PARAMS_v2 memset; /**< Memset node parameters. */ + CUDA_HOST_NODE_PARAMS_v2 host; /**< Host node parameters. */ + CUDA_CHILD_GRAPH_NODE_PARAMS graph; /**< Child graph node parameters. */ + CUDA_EVENT_WAIT_NODE_PARAMS eventWait; /**< Event wait node parameters. */ + CUDA_EVENT_RECORD_NODE_PARAMS eventRecord; /**< Event record node parameters. */ + CUDA_EXT_SEM_SIGNAL_NODE_PARAMS_v2 extSemSignal; /**< External semaphore signal node parameters. */ + CUDA_EXT_SEM_WAIT_NODE_PARAMS_v2 extSemWait; /**< External semaphore wait node parameters. */ + CUDA_MEM_ALLOC_NODE_PARAMS_v2 alloc; /**< Memory allocation node parameters. */ + CUDA_MEM_FREE_NODE_PARAMS free; /**< Memory free node parameters. */ + CUDA_BATCH_MEM_OP_NODE_PARAMS_v2 memOp; /**< MemOp node parameters. */ + CUDA_CONDITIONAL_NODE_PARAMS conditional; /**< Conditional node parameters. */ + }; + + long long reserved2; /**< Reserved bytes. Must be zero. */ +} CUgraphNodeParams; + +/** + * If set, each kernel launched as part of ::cuLaunchCooperativeKernelMultiDevice only + * waits for prior work in the stream corresponding to that GPU to complete before the + * kernel begins execution. + */ +#define CUDA_COOPERATIVE_LAUNCH_MULTI_DEVICE_NO_PRE_LAUNCH_SYNC 0x01 + +/** + * If set, any subsequent work pushed in a stream that participated in a call to + * ::cuLaunchCooperativeKernelMultiDevice will only wait for the kernel launched on + * the GPU corresponding to that stream to complete before it begins execution. + */ +#define CUDA_COOPERATIVE_LAUNCH_MULTI_DEVICE_NO_POST_LAUNCH_SYNC 0x02 + +/** + * If set, the CUDA array is a collection of layers, where each layer is either a 1D + * or a 2D array and the Depth member of CUDA_ARRAY3D_DESCRIPTOR specifies the number + * of layers, not the depth of a 3D array. + */ +#define CUDA_ARRAY3D_LAYERED 0x01 + +/** + * Deprecated, use CUDA_ARRAY3D_LAYERED + */ +#define CUDA_ARRAY3D_2DARRAY 0x01 + +/** + * This flag must be set in order to bind a surface reference + * to the CUDA array + */ +#define CUDA_ARRAY3D_SURFACE_LDST 0x02 + +/** + * If set, the CUDA array is a collection of six 2D arrays, representing faces of a cube. The + * width of such a CUDA array must be equal to its height, and Depth must be six. + * If ::CUDA_ARRAY3D_LAYERED flag is also set, then the CUDA array is a collection of cubemaps + * and Depth must be a multiple of six. + */ +#define CUDA_ARRAY3D_CUBEMAP 0x04 + +/** + * This flag must be set in order to perform texture gather operations + * on a CUDA array. + */ +#define CUDA_ARRAY3D_TEXTURE_GATHER 0x08 + +/** + * This flag if set indicates that the CUDA + * array is a DEPTH_TEXTURE. + */ +#define CUDA_ARRAY3D_DEPTH_TEXTURE 0x10 + +/** + * This flag indicates that the CUDA array may be bound as a color target + * in an external graphics API + */ +#define CUDA_ARRAY3D_COLOR_ATTACHMENT 0x20 + +/** + * This flag if set indicates that the CUDA array or CUDA mipmapped array + * is a sparse CUDA array or CUDA mipmapped array respectively + */ +#define CUDA_ARRAY3D_SPARSE 0x40 + +/** + * This flag if set indicates that the CUDA array or CUDA mipmapped array + * will allow deferred memory mapping + */ +#define CUDA_ARRAY3D_DEFERRED_MAPPING 0x80 + +/** + * This flag indicates that the CUDA array will be used for hardware accelerated + * video encode/decode operations. + */ +#define CUDA_ARRAY3D_VIDEO_ENCODE_DECODE 0x100 + +/** + * Override the texref format with a format inferred from the array. + * Flag for ::cuTexRefSetArray() + */ +#define CU_TRSA_OVERRIDE_FORMAT 0x01 + +/** + * Read the texture as integers rather than promoting the values to floats + * in the range [0,1]. + * Flag for ::cuTexRefSetFlags() and ::cuTexObjectCreate() + */ +#define CU_TRSF_READ_AS_INTEGER 0x01 + +/** + * Use normalized texture coordinates in the range [0,1) instead of [0,dim). + * Flag for ::cuTexRefSetFlags() and ::cuTexObjectCreate() + */ +#define CU_TRSF_NORMALIZED_COORDINATES 0x02 + +/** + * Perform sRGB->linear conversion during texture read. + * Flag for ::cuTexRefSetFlags() and ::cuTexObjectCreate() + */ +#define CU_TRSF_SRGB 0x10 + + /** + * Disable any trilinear filtering optimizations. + * Flag for ::cuTexRefSetFlags() and ::cuTexObjectCreate() + */ +#define CU_TRSF_DISABLE_TRILINEAR_OPTIMIZATION 0x20 + +/** + * Enable seamless cube map filtering. + * Flag for ::cuTexObjectCreate() + */ +#define CU_TRSF_SEAMLESS_CUBEMAP 0x40 + +/** + * C++ compile time constant for CU_LAUNCH_PARAM_END + */ +#define CU_LAUNCH_PARAM_END_AS_INT 0x00 + +/** + * End of array terminator for the \p extra parameter to + * ::cuLaunchKernel + */ +#define CU_LAUNCH_PARAM_END ((void*)CU_LAUNCH_PARAM_END_AS_INT) + +/** + * C++ compile time constant for CU_LAUNCH_PARAM_BUFFER_POINTER + */ +#define CU_LAUNCH_PARAM_BUFFER_POINTER_AS_INT 0x01 + +/** + * Indicator that the next value in the \p extra parameter to + * ::cuLaunchKernel will be a pointer to a buffer containing all kernel + * parameters used for launching kernel \p f. This buffer needs to + * honor all alignment/padding requirements of the individual parameters. + * If ::CU_LAUNCH_PARAM_BUFFER_SIZE is not also specified in the + * \p extra array, then ::CU_LAUNCH_PARAM_BUFFER_POINTER will have no + * effect. + */ +#define CU_LAUNCH_PARAM_BUFFER_POINTER ((void*)CU_LAUNCH_PARAM_BUFFER_POINTER_AS_INT) + +/** + * C++ compile time constant for CU_LAUNCH_PARAM_BUFFER_SIZE + */ +#define CU_LAUNCH_PARAM_BUFFER_SIZE_AS_INT 0x02 + +/** + * Indicator that the next value in the \p extra parameter to + * ::cuLaunchKernel will be a pointer to a size_t which contains the + * size of the buffer specified with ::CU_LAUNCH_PARAM_BUFFER_POINTER. + * It is required that ::CU_LAUNCH_PARAM_BUFFER_POINTER also be specified + * in the \p extra array if the value associated with + * ::CU_LAUNCH_PARAM_BUFFER_SIZE is not zero. + */ +#define CU_LAUNCH_PARAM_BUFFER_SIZE ((void*)CU_LAUNCH_PARAM_BUFFER_SIZE_AS_INT) + +/** + * For texture references loaded into the module, use default texunit from + * texture reference. + */ +#define CU_PARAM_TR_DEFAULT -1 + +/** + * Device that represents the CPU + */ +#define CU_DEVICE_CPU ((CUdevice)-1) + +/** + * Device that represents an invalid device + */ +#define CU_DEVICE_INVALID ((CUdevice)-2) + +/** + * Bitmasks for ::CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_FLUSH_WRITES_OPTIONS + */ +typedef enum CUflushGPUDirectRDMAWritesOptions_enum { + CU_FLUSH_GPU_DIRECT_RDMA_WRITES_OPTION_HOST = 1<<0, /**< ::cuFlushGPUDirectRDMAWrites() and its CUDA Runtime API counterpart are supported on the device. */ + CU_FLUSH_GPU_DIRECT_RDMA_WRITES_OPTION_MEMOPS = 1<<1 /**< The ::CU_STREAM_WAIT_VALUE_FLUSH flag and the ::CU_STREAM_MEM_OP_FLUSH_REMOTE_WRITES MemOp are supported on the device. */ +} CUflushGPUDirectRDMAWritesOptions; + +/** + * Platform native ordering for GPUDirect RDMA writes + */ +typedef enum CUGPUDirectRDMAWritesOrdering_enum { + CU_GPU_DIRECT_RDMA_WRITES_ORDERING_NONE = 0, /**< The device does not natively support ordering of remote writes. ::cuFlushGPUDirectRDMAWrites() can be leveraged if supported. */ + CU_GPU_DIRECT_RDMA_WRITES_ORDERING_OWNER = 100, /**< Natively, the device can consistently consume remote writes, although other CUDA devices may not. */ + CU_GPU_DIRECT_RDMA_WRITES_ORDERING_ALL_DEVICES = 200 /**< Any CUDA device in the system can consistently consume remote writes to this device. */ +} CUGPUDirectRDMAWritesOrdering; + +/** + * The scopes for ::cuFlushGPUDirectRDMAWrites + */ +typedef enum CUflushGPUDirectRDMAWritesScope_enum { + CU_FLUSH_GPU_DIRECT_RDMA_WRITES_TO_OWNER = 100, /**< Blocks until remote writes are visible to the CUDA device context owning the data. */ + CU_FLUSH_GPU_DIRECT_RDMA_WRITES_TO_ALL_DEVICES = 200 /**< Blocks until remote writes are visible to all CUDA device contexts. */ +} CUflushGPUDirectRDMAWritesScope; + +/** + * The targets for ::cuFlushGPUDirectRDMAWrites + */ +typedef enum CUflushGPUDirectRDMAWritesTarget_enum { + CU_FLUSH_GPU_DIRECT_RDMA_WRITES_TARGET_CURRENT_CTX = 0 /**< Sets the target for ::cuFlushGPUDirectRDMAWrites() to the currently active CUDA device context. */ +} CUflushGPUDirectRDMAWritesTarget; + +/** + * The additional write options for ::cuGraphDebugDotPrint + */ +typedef enum CUgraphDebugDot_flags_enum { + CU_GRAPH_DEBUG_DOT_FLAGS_VERBOSE = 1<<0, /**< Output all debug data as if every debug flag is enabled */ + CU_GRAPH_DEBUG_DOT_FLAGS_RUNTIME_TYPES = 1<<1, /**< Use CUDA Runtime structures for output */ + CU_GRAPH_DEBUG_DOT_FLAGS_KERNEL_NODE_PARAMS = 1<<2, /**< Adds CUDA_KERNEL_NODE_PARAMS values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_MEMCPY_NODE_PARAMS = 1<<3, /**< Adds CUDA_MEMCPY3D values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_MEMSET_NODE_PARAMS = 1<<4, /**< Adds CUDA_MEMSET_NODE_PARAMS values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_HOST_NODE_PARAMS = 1<<5, /**< Adds CUDA_HOST_NODE_PARAMS values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_EVENT_NODE_PARAMS = 1<<6, /**< Adds CUevent handle from record and wait nodes to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_EXT_SEMAS_SIGNAL_NODE_PARAMS = 1<<7, /**< Adds CUDA_EXT_SEM_SIGNAL_NODE_PARAMS values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_EXT_SEMAS_WAIT_NODE_PARAMS = 1<<8, /**< Adds CUDA_EXT_SEM_WAIT_NODE_PARAMS values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_KERNEL_NODE_ATTRIBUTES = 1<<9, /**< Adds CUkernelNodeAttrValue values to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_HANDLES = 1<<10, /**< Adds node handles and every kernel function handle to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_MEM_ALLOC_NODE_PARAMS = 1<<11, /**< Adds memory alloc node parameters to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_MEM_FREE_NODE_PARAMS = 1<<12, /**< Adds memory free node parameters to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_BATCH_MEM_OP_NODE_PARAMS = 1<<13, /**< Adds batch mem op node parameters to output */ + CU_GRAPH_DEBUG_DOT_FLAGS_EXTRA_TOPO_INFO = 1<<14, /**< Adds edge numbering information */ + CU_GRAPH_DEBUG_DOT_FLAGS_CONDITIONAL_NODE_PARAMS = 1<<15 /**< Adds conditional node parameters to output */ +} CUgraphDebugDot_flags; + +/** + * Flags for user objects for graphs + */ +typedef enum CUuserObject_flags_enum { + CU_USER_OBJECT_NO_DESTRUCTOR_SYNC = 1 /**< Indicates the destructor execution is not synchronized by any CUDA handle. */ +} CUuserObject_flags; + +/** + * Flags for retaining user object references for graphs + */ +typedef enum CUuserObjectRetain_flags_enum { + CU_GRAPH_USER_OBJECT_MOVE = 1 /**< Transfer references from the caller rather than creating new references. */ +} CUuserObjectRetain_flags; + +/** + * Flags for instantiating a graph + */ +typedef enum CUgraphInstantiate_flags_enum { + CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH = 1 /**< Automatically free memory allocated in a graph before relaunching. */ + , CUDA_GRAPH_INSTANTIATE_FLAG_UPLOAD = 2 /**< Automatically upload the graph after instantiation. Only supported by + ::cuGraphInstantiateWithParams. The upload will be performed using the + stream provided in \p instantiateParams. */ + , CUDA_GRAPH_INSTANTIATE_FLAG_DEVICE_LAUNCH = 4 /**< Instantiate the graph to be launchable from the device. This flag can only + be used on platforms which support unified addressing. This flag cannot be + used in conjunction with CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH. */ + , CUDA_GRAPH_INSTANTIATE_FLAG_USE_NODE_PRIORITY = 8 /**< Run the graph using the per-node priority attributes rather than the + priority of the stream it is launched into. */ +} CUgraphInstantiate_flags; + +/** + * CUDA device NUMA configuration + */ +typedef enum CUdeviceNumaConfig_enum { + CU_DEVICE_NUMA_CONFIG_NONE = 0, /**< The GPU is not a NUMA node */ + CU_DEVICE_NUMA_CONFIG_NUMA_NODE, /**< The GPU is a NUMA node, CU_DEVICE_ATTRIBUTE_NUMA_ID contains its NUMA ID */ +} CUdeviceNumaConfig; + +/** @} */ /* END CUDA_TYPES */ + +#if defined(__GNUC__) + #if defined(__CUDA_API_PUSH_VISIBILITY_DEFAULT) + #pragma GCC visibility push(default) + #endif +#endif + +#ifdef _WIN32 +#define CUDAAPI __stdcall +#else +#define CUDAAPI +#endif + +/** + * \defgroup CUDA_ERROR Error Handling + * + * ___MANBRIEF___ error handling functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the error handling functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Gets the string description of an error code + * + * Sets \p *pStr to the address of a NULL-terminated string description + * of the error code \p error. + * If the error code is not recognized, ::CUDA_ERROR_INVALID_VALUE + * will be returned and \p *pStr will be set to the NULL address. + * + * \param error - Error code to convert to string + * \param pStr - Address of the string pointer. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::CUresult, + * ::cudaGetErrorString + */ +CUresult CUDAAPI cuGetErrorString(CUresult error, const char **pStr); + +/** + * \brief Gets the string representation of an error code enum name + * + * Sets \p *pStr to the address of a NULL-terminated string representation + * of the name of the enum error code \p error. + * If the error code is not recognized, ::CUDA_ERROR_INVALID_VALUE + * will be returned and \p *pStr will be set to the NULL address. + * + * \param error - Error code to convert to string + * \param pStr - Address of the string pointer. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::CUresult, + * ::cudaGetErrorName + */ +CUresult CUDAAPI cuGetErrorName(CUresult error, const char **pStr); + +/** @} */ /* END CUDA_ERROR */ + +/** + * \defgroup CUDA_INITIALIZE Initialization + * + * ___MANBRIEF___ initialization functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the initialization functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Initialize the CUDA driver API + * Initializes the driver API and must be called before any other function from + * the driver API in the current process. Currently, the \p Flags parameter must be 0. If ::cuInit() + * has not been called, any function from the driver API will return + * ::CUDA_ERROR_NOT_INITIALIZED. + * + * \param Flags - Initialization flag for CUDA. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_SYSTEM_DRIVER_MISMATCH, + * ::CUDA_ERROR_COMPAT_NOT_SUPPORTED_ON_DEVICE + * \notefnerr + */ +CUresult CUDAAPI cuInit(unsigned int Flags); + +/** @} */ /* END CUDA_INITIALIZE */ + +/** + * \defgroup CUDA_VERSION Version Management + * + * ___MANBRIEF___ version management functions of the low-level CUDA driver + * API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the version management functions of the low-level + * CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns the latest CUDA version supported by driver + * + * Returns in \p *driverVersion the version of CUDA supported by + * the driver. The version is returned as + * (1000 × major + 10 × minor). For example, CUDA 9.2 + * would be represented by 9020. + * + * This function automatically returns ::CUDA_ERROR_INVALID_VALUE if + * \p driverVersion is NULL. + * + * \param driverVersion - Returns the CUDA driver version + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cudaDriverGetVersion, + * ::cudaRuntimeGetVersion + */ +CUresult CUDAAPI cuDriverGetVersion(int *driverVersion); + +/** @} */ /* END CUDA_VERSION */ + +/** + * \defgroup CUDA_DEVICE Device Management + * + * ___MANBRIEF___ device management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the device management functions of the low-level + * CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns a handle to a compute device + * + * Returns in \p *device a device handle given an ordinal in the range [0, + * ::cuDeviceGetCount()-1]. + * + * \param device - Returned device handle + * \param ordinal - Device number to get handle for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGetLuid, + * ::cuDeviceTotalMem, + * ::cuDeviceGetExecAffinitySupport + */ +CUresult CUDAAPI cuDeviceGet(CUdevice *device, int ordinal); + +/** + * \brief Returns the number of compute-capable devices + * + * Returns in \p *count the number of devices with compute capability greater + * than or equal to 2.0 that are available for execution. If there is no such + * device, ::cuDeviceGetCount() returns 0. + * + * \param count - Returned number of compute-capable devices + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGetLuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem, + * ::cuDeviceGetExecAffinitySupport, + * ::cudaGetDeviceCount + */ +CUresult CUDAAPI cuDeviceGetCount(int *count); + +/** + * \brief Returns an identifier string for the device + * + * Returns an ASCII string identifying the device \p dev in the NULL-terminated + * string pointed to by \p name. \p len specifies the maximum length of the + * string that may be returned. + * + * \param name - Returned identifier string for the device + * \param len - Maximum length of string to store in \p name + * \param dev - Device to get identifier string for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetUuid, + * ::cuDeviceGetLuid, + * ::cuDeviceGetCount, + * ::cuDeviceGet, + * ::cuDeviceTotalMem, + * ::cuDeviceGetExecAffinitySupport, + * ::cudaGetDeviceProperties + */ +CUresult CUDAAPI cuDeviceGetName(char *name, int len, CUdevice dev); + +/** + * \brief Return an UUID for the device + * + * Note there is a later version of this API, ::cuDeviceGetUuid_v2. It will + * supplant this version in 12.0, which is retained for minor version compatibility. + * + * Returns 16-octets identifying the device \p dev in the structure + * pointed by the \p uuid. + * + * \param uuid - Returned UUID + * \param dev - Device to get identifier string for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetUuid_v2 + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetLuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem, + * ::cuDeviceGetExecAffinitySupport, + * ::cudaGetDeviceProperties + */ +CUresult CUDAAPI cuDeviceGetUuid(CUuuid *uuid, CUdevice dev); + +/** + * \brief Return an UUID for the device (11.4+) + * + * Returns 16-octets identifying the device \p dev in the structure + * pointed by the \p uuid. If the device is in MIG mode, returns its + * MIG UUID which uniquely identifies the subscribed MIG compute instance. + * + * \param uuid - Returned UUID + * \param dev - Device to get identifier string for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetLuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem, + * ::cudaGetDeviceProperties + */ +CUresult CUDAAPI cuDeviceGetUuid_v2(CUuuid *uuid, CUdevice dev); + +/** + * \brief Return an LUID and device node mask for the device + * + * Return identifying information (\p luid and \p deviceNodeMask) to allow + * matching device with graphics APIs. + * + * \param luid - Returned LUID + * \param deviceNodeMask - Returned device node mask + * \param dev - Device to get identifier string for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGet, + * ::cuDeviceTotalMem, + * ::cuDeviceGetExecAffinitySupport, + * ::cudaGetDeviceProperties + */ +CUresult CUDAAPI cuDeviceGetLuid(char *luid, unsigned int *deviceNodeMask, CUdevice dev); + +/** + * \brief Returns the total amount of memory on the device + * + * Returns in \p *bytes the total amount of memory available on the device + * \p dev in bytes. + * + * \param bytes - Returned memory available on device in bytes + * \param dev - Device handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGet, + * ::cuDeviceGetExecAffinitySupport, + * ::cudaMemGetInfo + */ +CUresult CUDAAPI cuDeviceTotalMem(size_t *bytes, CUdevice dev); + +/** + * \brief Returns the maximum number of elements allocatable in a 1D linear texture for a given texture element size. + * + * Returns in \p maxWidthInElements the maximum number of texture elements allocatable in a 1D linear texture + * for given \p format and \p numChannels. + * + * \param maxWidthInElements - Returned maximum number of texture elements allocatable for given \p format and \p numChannels. + * \param format - Texture format. + * \param numChannels - Number of channels per texture element. + * \param dev - Device handle. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGet, + * ::cudaMemGetInfo, + * ::cuDeviceTotalMem + */ +CUresult CUDAAPI cuDeviceGetTexture1DLinearMaxWidth(size_t *maxWidthInElements, CUarray_format format, unsigned numChannels, CUdevice dev); + +/** + * \brief Returns information about the device + * + * Returns in \p *pi the integer value of the attribute \p attrib on device + * \p dev. The supported attributes are: + * - ::CU_DEVICE_ATTRIBUTE_MAX_THREADS_PER_BLOCK: Maximum number of threads per + * block; + * - ::CU_DEVICE_ATTRIBUTE_MAX_BLOCK_DIM_X: Maximum x-dimension of a block + * - ::CU_DEVICE_ATTRIBUTE_MAX_BLOCK_DIM_Y: Maximum y-dimension of a block + * - ::CU_DEVICE_ATTRIBUTE_MAX_BLOCK_DIM_Z: Maximum z-dimension of a block + * - ::CU_DEVICE_ATTRIBUTE_MAX_GRID_DIM_X: Maximum x-dimension of a grid + * - ::CU_DEVICE_ATTRIBUTE_MAX_GRID_DIM_Y: Maximum y-dimension of a grid + * - ::CU_DEVICE_ATTRIBUTE_MAX_GRID_DIM_Z: Maximum z-dimension of a grid + * - ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK: Maximum amount of + * shared memory available to a thread block in bytes + * - ::CU_DEVICE_ATTRIBUTE_TOTAL_CONSTANT_MEMORY: Memory available on device for + * __constant__ variables in a CUDA C kernel in bytes + * - ::CU_DEVICE_ATTRIBUTE_WARP_SIZE: Warp size in threads + * - ::CU_DEVICE_ATTRIBUTE_MAX_PITCH: Maximum pitch in bytes allowed by the + * memory copy functions that involve memory regions allocated through + * ::cuMemAllocPitch() + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_WIDTH: Maximum 1D + * texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LINEAR_WIDTH: Maximum width + * for a 1D texture bound to linear memory + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_MIPMAPPED_WIDTH: Maximum + * mipmapped 1D texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_WIDTH: Maximum 2D + * texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_HEIGHT: Maximum 2D + * texture height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_WIDTH: Maximum width + * for a 2D texture bound to linear memory + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_HEIGHT: Maximum height + * for a 2D texture bound to linear memory + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_PITCH: Maximum pitch + * in bytes for a 2D texture bound to linear memory + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_MIPMAPPED_WIDTH: Maximum + * mipmapped 2D texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_MIPMAPPED_HEIGHT: Maximum + * mipmapped 2D texture height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_WIDTH: Maximum 3D + * texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_HEIGHT: Maximum 3D + * texture height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_DEPTH: Maximum 3D + * texture depth + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_WIDTH_ALTERNATE: + * Alternate maximum 3D texture width, 0 if no alternate + * maximum 3D texture size is supported + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_HEIGHT_ALTERNATE: + * Alternate maximum 3D texture height, 0 if no alternate + * maximum 3D texture size is supported + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE3D_DEPTH_ALTERNATE: + * Alternate maximum 3D texture depth, 0 if no alternate + * maximum 3D texture size is supported + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURECUBEMAP_WIDTH: + * Maximum cubemap texture width or height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LAYERED_WIDTH: + * Maximum 1D layered texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LAYERED_LAYERS: + * Maximum layers in a 1D layered texture + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_WIDTH: + * Maximum 2D layered texture width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_HEIGHT: + * Maximum 2D layered texture height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LAYERED_LAYERS: + * Maximum layers in a 2D layered texture + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURECUBEMAP_LAYERED_WIDTH: + * Maximum cubemap layered texture width or height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURECUBEMAP_LAYERED_LAYERS: + * Maximum layers in a cubemap layered texture + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE1D_WIDTH: + * Maximum 1D surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_WIDTH: + * Maximum 2D surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_HEIGHT: + * Maximum 2D surface height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE3D_WIDTH: + * Maximum 3D surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE3D_HEIGHT: + * Maximum 3D surface height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE3D_DEPTH: + * Maximum 3D surface depth + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE1D_LAYERED_WIDTH: + * Maximum 1D layered surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE1D_LAYERED_LAYERS: + * Maximum layers in a 1D layered surface + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_LAYERED_WIDTH: + * Maximum 2D layered surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_LAYERED_HEIGHT: + * Maximum 2D layered surface height + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACE2D_LAYERED_LAYERS: + * Maximum layers in a 2D layered surface + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACECUBEMAP_WIDTH: + * Maximum cubemap surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACECUBEMAP_LAYERED_WIDTH: + * Maximum cubemap layered surface width + * - ::CU_DEVICE_ATTRIBUTE_MAXIMUM_SURFACECUBEMAP_LAYERED_LAYERS: + * Maximum layers in a cubemap layered surface + * - ::CU_DEVICE_ATTRIBUTE_MAX_REGISTERS_PER_BLOCK: Maximum number of 32-bit + * registers available to a thread block + * - ::CU_DEVICE_ATTRIBUTE_CLOCK_RATE: The typical clock frequency in kilohertz + * - ::CU_DEVICE_ATTRIBUTE_TEXTURE_ALIGNMENT: Alignment requirement; texture + * base addresses aligned to ::textureAlign bytes do not need an offset + * applied to texture fetches + * - ::CU_DEVICE_ATTRIBUTE_TEXTURE_PITCH_ALIGNMENT: Pitch alignment requirement + * for 2D texture references bound to pitched memory + * - ::CU_DEVICE_ATTRIBUTE_GPU_OVERLAP: 1 if the device can concurrently copy + * memory between host and device while executing a kernel, or 0 if not + * - ::CU_DEVICE_ATTRIBUTE_MULTIPROCESSOR_COUNT: Number of multiprocessors on + * the device + * - ::CU_DEVICE_ATTRIBUTE_KERNEL_EXEC_TIMEOUT: 1 if there is a run time limit + * for kernels executed on the device, or 0 if not + * - ::CU_DEVICE_ATTRIBUTE_INTEGRATED: 1 if the device is integrated with the + * memory subsystem, or 0 if not + * - ::CU_DEVICE_ATTRIBUTE_CAN_MAP_HOST_MEMORY: 1 if the device can map host + * memory into the CUDA address space, or 0 if not + * - ::CU_DEVICE_ATTRIBUTE_COMPUTE_MODE: Compute mode that device is currently + * in. Available modes are as follows: + * - ::CU_COMPUTEMODE_DEFAULT: Default mode - Device is not restricted and + * can have multiple CUDA contexts present at a single time. + * - ::CU_COMPUTEMODE_PROHIBITED: Compute-prohibited mode - Device is + * prohibited from creating new CUDA contexts. + * - ::CU_COMPUTEMODE_EXCLUSIVE_PROCESS: Compute-exclusive-process mode - Device + * can have only one context used by a single process at a time. + * - ::CU_DEVICE_ATTRIBUTE_CONCURRENT_KERNELS: 1 if the device supports + * executing multiple kernels within the same context simultaneously, or 0 if + * not. It is not guaranteed that multiple kernels will be resident + * on the device concurrently so this feature should not be relied upon for + * correctness. + * - ::CU_DEVICE_ATTRIBUTE_ECC_ENABLED: 1 if error correction is enabled on the + * device, 0 if error correction is disabled or not supported by the device + * - ::CU_DEVICE_ATTRIBUTE_PCI_BUS_ID: PCI bus identifier of the device + * - ::CU_DEVICE_ATTRIBUTE_PCI_DEVICE_ID: PCI device (also known as slot) identifier + * of the device + * - ::CU_DEVICE_ATTRIBUTE_PCI_DOMAIN_ID: PCI domain identifier of the device + * - ::CU_DEVICE_ATTRIBUTE_TCC_DRIVER: 1 if the device is using a TCC driver. TCC + * is only available on Tesla hardware running Windows Vista or later + * - ::CU_DEVICE_ATTRIBUTE_MEMORY_CLOCK_RATE: Peak memory clock frequency in kilohertz + * - ::CU_DEVICE_ATTRIBUTE_GLOBAL_MEMORY_BUS_WIDTH: Global memory bus width in bits + * - ::CU_DEVICE_ATTRIBUTE_L2_CACHE_SIZE: Size of L2 cache in bytes. 0 if the device doesn't have L2 cache + * - ::CU_DEVICE_ATTRIBUTE_MAX_THREADS_PER_MULTIPROCESSOR: Maximum resident threads per multiprocessor + * - ::CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING: 1 if the device shares a unified address space with + * the host, or 0 if not + * - ::CU_DEVICE_ATTRIBUTE_COMPUTE_CAPABILITY_MAJOR: Major compute capability version number + * - ::CU_DEVICE_ATTRIBUTE_COMPUTE_CAPABILITY_MINOR: Minor compute capability version number + * - ::CU_DEVICE_ATTRIBUTE_GLOBAL_L1_CACHE_SUPPORTED: 1 if device supports caching globals + * in L1 cache, 0 if caching globals in L1 cache is not supported by the device + * - ::CU_DEVICE_ATTRIBUTE_LOCAL_L1_CACHE_SUPPORTED: 1 if device supports caching locals + * in L1 cache, 0 if caching locals in L1 cache is not supported by the device + * - ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_MULTIPROCESSOR: Maximum amount of + * shared memory available to a multiprocessor in bytes; this amount is shared + * by all thread blocks simultaneously resident on a multiprocessor + * - ::CU_DEVICE_ATTRIBUTE_MAX_REGISTERS_PER_MULTIPROCESSOR: Maximum number of 32-bit + * registers available to a multiprocessor; this number is shared by all thread + * blocks simultaneously resident on a multiprocessor + * - ::CU_DEVICE_ATTRIBUTE_MANAGED_MEMORY: 1 if device supports allocating managed memory + * on this system, 0 if allocating managed memory is not supported by the device on this system. + * - ::CU_DEVICE_ATTRIBUTE_MULTI_GPU_BOARD: 1 if device is on a multi-GPU board, 0 if not. + * - ::CU_DEVICE_ATTRIBUTE_MULTI_GPU_BOARD_GROUP_ID: Unique identifier for a group of devices + * associated with the same board. Devices on the same multi-GPU board will share the same identifier. + * - ::CU_DEVICE_ATTRIBUTE_HOST_NATIVE_ATOMIC_SUPPORTED: 1 if Link between the device and the host + * supports native atomic operations. + * - ::CU_DEVICE_ATTRIBUTE_SINGLE_TO_DOUBLE_PRECISION_PERF_RATIO: Ratio of single precision performance + * (in floating-point operations per second) to double precision performance. + * - ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS: Device supports coherently accessing + * pageable memory without calling cudaHostRegister on it. + * - ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS: Device can coherently access managed memory + * concurrently with the CPU. + * - ::CU_DEVICE_ATTRIBUTE_COMPUTE_PREEMPTION_SUPPORTED: Device supports Compute Preemption. + * - ::CU_DEVICE_ATTRIBUTE_CAN_USE_HOST_POINTER_FOR_REGISTERED_MEM: Device can access host registered + * memory at the same virtual address as the CPU. + * - ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK_OPTIN: The maximum per block shared memory size + * supported on this device. This is the maximum value that can be opted into when using the cuFuncSetAttribute() or cuKernelSetAttribute() call. + * For more details see ::CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES + * - ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES: Device accesses pageable memory via the host's + * page tables. + * - ::CU_DEVICE_ATTRIBUTE_DIRECT_MANAGED_MEM_ACCESS_FROM_HOST: The host can directly access managed memory on the device without migration. + * - ::CU_DEVICE_ATTRIBUTE_VIRTUAL_MEMORY_MANAGEMENT_SUPPORTED: Device supports virtual memory management APIs like ::cuMemAddressReserve, ::cuMemCreate, ::cuMemMap and related APIs + * - ::CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_POSIX_FILE_DESCRIPTOR_SUPPORTED: Device supports exporting memory to a posix file descriptor with ::cuMemExportToShareableHandle, if requested via ::cuMemCreate + * - ::CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_WIN32_HANDLE_SUPPORTED: Device supports exporting memory to a Win32 NT handle with ::cuMemExportToShareableHandle, if requested via ::cuMemCreate + * - ::CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_WIN32_KMT_HANDLE_SUPPORTED: Device supports exporting memory to a Win32 KMT handle with ::cuMemExportToShareableHandle, if requested via ::cuMemCreate + * - ::CU_DEVICE_ATTRIBUTE_MAX_BLOCKS_PER_MULTIPROCESSOR: Maximum number of thread blocks that can reside on a multiprocessor + * - ::CU_DEVICE_ATTRIBUTE_GENERIC_COMPRESSION_SUPPORTED: Device supports compressible memory allocation via ::cuMemCreate + * - ::CU_DEVICE_ATTRIBUTE_MAX_PERSISTING_L2_CACHE_SIZE: Maximum L2 persisting lines capacity setting in bytes + * - ::CU_DEVICE_ATTRIBUTE_MAX_ACCESS_POLICY_WINDOW_SIZE: Maximum value of CUaccessPolicyWindow::num_bytes + * - ::CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_WITH_CUDA_VMM_SUPPORTED: Device supports specifying the GPUDirect RDMA flag with ::cuMemCreate. + * - ::CU_DEVICE_ATTRIBUTE_RESERVED_SHARED_MEMORY_PER_BLOCK: Amount of shared memory per block reserved by CUDA driver in bytes + * - ::CU_DEVICE_ATTRIBUTE_SPARSE_CUDA_ARRAY_SUPPORTED: Device supports sparse CUDA arrays and sparse CUDA mipmapped arrays. + * - ::CU_DEVICE_ATTRIBUTE_READ_ONLY_HOST_REGISTER_SUPPORTED: Device supports using the ::cuMemHostRegister flag ::CU_MEMHOSTERGISTER_READ_ONLY to register memory that must be mapped as read-only to the GPU + * - ::CU_DEVICE_ATTRIBUTE_MEMORY_POOLS_SUPPORTED: Device supports using the ::cuMemAllocAsync and ::cuMemPool family of APIs + * - ::CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_SUPPORTED: Device supports GPUDirect RDMA APIs, like nvidia_p2p_get_pages (see https://docs.nvidia.com/cuda/gpudirect-rdma for more information) + * - ::CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_FLUSH_WRITES_OPTIONS: The returned attribute shall be interpreted as a bitmask, where the individual bits are described by the ::CUflushGPUDirectRDMAWritesOptions enum + * - ::CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_WRITES_ORDERING: GPUDirect RDMA writes to the device do not need to be flushed for consumers within the scope indicated by the returned attribute. See ::CUGPUDirectRDMAWritesOrdering for the numerical values returned here. + * - ::CU_DEVICE_ATTRIBUTE_MEMPOOL_SUPPORTED_HANDLE_TYPES: Bitmask of handle types supported with mempool based IPC + * - ::CU_DEVICE_ATTRIBUTE_DEFERRED_MAPPING_CUDA_ARRAY_SUPPORTED: Device supports deferred mapping CUDA arrays and CUDA mipmapped arrays. + * - ::CU_DEVICE_ATTRIBUTE_NUMA_CONFIG: NUMA configuration of a device: value is of type ::CUdeviceNumaConfig enum + * - ::CU_DEVICE_ATTRIBUTE_NUMA_ID: NUMA node ID of the GPU memory + * - ::CU_DEVICE_ATTRIBUTE_MULTICAST_SUPPORTED: Device supports switch multicast and reduction operations. + * + * \param pi - Returned device attribute value + * \param attrib - Device attribute to query + * \param dev - Device handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem, + * ::cuDeviceGetExecAffinitySupport, + * ::cudaDeviceGetAttribute, + * ::cudaGetDeviceProperties + */ +CUresult CUDAAPI cuDeviceGetAttribute(int *pi, CUdevice_attribute attrib, CUdevice dev); + +/** + * \brief Return NvSciSync attributes that this device can support. + * + * Returns in \p nvSciSyncAttrList, the properties of NvSciSync that + * this CUDA device, \p dev can support. The returned \p nvSciSyncAttrList + * can be used to create an NvSciSync object that matches this device's capabilities. + * + * If NvSciSyncAttrKey_RequiredPerm field in \p nvSciSyncAttrList is + * already set this API will return ::CUDA_ERROR_INVALID_VALUE. + * + * The applications should set \p nvSciSyncAttrList to a valid + * NvSciSyncAttrList failing which this API will return + * ::CUDA_ERROR_INVALID_HANDLE. + * + * The \p flags controls how applications intends to use + * the NvSciSync created from the \p nvSciSyncAttrList. The valid flags are: + * - ::CUDA_NVSCISYNC_ATTR_SIGNAL, specifies that the applications intends to + * signal an NvSciSync on this CUDA device. + * - ::CUDA_NVSCISYNC_ATTR_WAIT, specifies that the applications intends to + * wait on an NvSciSync on this CUDA device. + * + * At least one of these flags must be set, failing which the API + * returns ::CUDA_ERROR_INVALID_VALUE. Both the flags are orthogonal + * to one another: a developer may set both these flags that allows to + * set both wait and signal specific attributes in the same \p nvSciSyncAttrList. + * + * Note that this API updates the input \p nvSciSyncAttrList with values equivalent + * to the following public attribute key-values: + * NvSciSyncAttrKey_RequiredPerm is set to + * - NvSciSyncAccessPerm_SignalOnly if ::CUDA_NVSCISYNC_ATTR_SIGNAL is set in \p flags. + * - NvSciSyncAccessPerm_WaitOnly if ::CUDA_NVSCISYNC_ATTR_WAIT is set in \p flags. + * - NvSciSyncAccessPerm_WaitSignal if both ::CUDA_NVSCISYNC_ATTR_WAIT and + * ::CUDA_NVSCISYNC_ATTR_SIGNAL are set in \p flags. + * NvSciSyncAttrKey_PrimitiveInfo is set to + * - NvSciSyncAttrValPrimitiveType_SysmemSemaphore on any valid \p device. + * - NvSciSyncAttrValPrimitiveType_Syncpoint if \p device is a Tegra device. + * - NvSciSyncAttrValPrimitiveType_SysmemSemaphorePayload64b if \p device is GA10X+. + * NvSciSyncAttrKey_GpuId is set to the same UUID that is returned for this + * \p device from ::cuDeviceGetUuid. + * + * \param nvSciSyncAttrList - Return NvSciSync attributes supported. + * \param dev - Valid Cuda Device to get NvSciSync attributes for. + * \param flags - flags describing NvSciSync usage. + * + * \return + * + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa + * ::cuImportExternalSemaphore, + * ::cuDestroyExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuDeviceGetNvSciSyncAttributes(void *nvSciSyncAttrList, CUdevice dev, int flags); + +/** + * \brief Sets the current memory pool of a device + * + * The memory pool must be local to the specified device. + * ::cuMemAllocAsync allocates from the current mempool of the provided stream's device. + * By default, a device's current memory pool is its default memory pool. + * + * \note Use ::cuMemAllocFromPoolAsync to specify asynchronous allocations from a device different + * than the one the stream runs on. + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuDeviceGetDefaultMemPool, ::cuDeviceGetMemPool, ::cuMemPoolCreate, ::cuMemPoolDestroy, ::cuMemAllocFromPoolAsync + */ +CUresult CUDAAPI cuDeviceSetMemPool(CUdevice dev, CUmemoryPool pool); + +/** + * \brief Gets the current mempool for a device + * + * Returns the last pool provided to ::cuDeviceSetMemPool for this device + * or the device's default memory pool if ::cuDeviceSetMemPool has never been called. + * By default the current mempool is the default mempool for a device. + * Otherwise the returned pool must have been set with ::cuDeviceSetMemPool. + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuDeviceGetDefaultMemPool, ::cuMemPoolCreate, ::cuDeviceSetMemPool + */ +CUresult CUDAAPI cuDeviceGetMemPool(CUmemoryPool *pool, CUdevice dev); + +/** + * \brief Returns the default mempool of a device + * + * The default mempool of a device contains device memory from that device. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuMemAllocAsync, ::cuMemPoolTrimTo, ::cuMemPoolGetAttribute, ::cuMemPoolSetAttribute, cuMemPoolSetAccess, ::cuDeviceGetMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuDeviceGetDefaultMemPool(CUmemoryPool *pool_out, CUdevice dev); + +/** + * \brief Returns information about the execution affinity support of the device. + * + * Returns in \p *pi whether execution affinity type \p type is supported by device \p dev. + * The supported types are: + * - ::CU_EXEC_AFFINITY_TYPE_SM_COUNT: 1 if context with limited SMs is supported by the device, + * or 0 if not; + * + * \param pi - 1 if the execution affinity type \p type is supported by the device, or 0 if not + * \param type - Execution affinity type to query + * \param dev - Device handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem + */ +CUresult CUDAAPI cuDeviceGetExecAffinitySupport(int *pi, CUexecAffinityType type, CUdevice dev); + +/** + * \brief Blocks until remote writes are visible to the specified scope + * + * Blocks until GPUDirect RDMA writes to the target context via mappings + * created through APIs like nvidia_p2p_get_pages (see + * https://docs.nvidia.com/cuda/gpudirect-rdma for more information), are + * visible to the specified scope. + * + * If the scope equals or lies within the scope indicated by + * ::CU_DEVICE_ATTRIBUTE_GPU_DIRECT_RDMA_WRITES_ORDERING, the call + * will be a no-op and can be safely omitted for performance. This can be + * determined by comparing the numerical values between the two enums, with + * smaller scopes having smaller values. + * + * Users may query support for this API via + * ::CU_DEVICE_ATTRIBUTE_FLUSH_FLUSH_GPU_DIRECT_RDMA_OPTIONS. + * + * \param target - The target of the operation, see ::CUflushGPUDirectRDMAWritesTarget + * \param scope - The scope of the operation, see ::CUflushGPUDirectRDMAWritesScope + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + */ +CUresult CUDAAPI cuFlushGPUDirectRDMAWrites(CUflushGPUDirectRDMAWritesTarget target, CUflushGPUDirectRDMAWritesScope scope); + +/** @} */ /* END CUDA_DEVICE */ + +/** + * \defgroup CUDA_DEVICE_DEPRECATED Device Management [DEPRECATED] + * + * ___MANBRIEF___ deprecated device management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the device management functions of the low-level + * CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns properties for a selected device + * + * \deprecated + * + * This function was deprecated as of CUDA 5.0 and replaced by ::cuDeviceGetAttribute(). + * + * Returns in \p *prop the properties of device \p dev. The ::CUdevprop + * structure is defined as: + * + * \code + typedef struct CUdevprop_st { + int maxThreadsPerBlock; + int maxThreadsDim[3]; + int maxGridSize[3]; + int sharedMemPerBlock; + int totalConstantMemory; + int SIMDWidth; + int memPitch; + int regsPerBlock; + int clockRate; + int textureAlign + } CUdevprop; + * \endcode + * where: + * + * - ::maxThreadsPerBlock is the maximum number of threads per block; + * - ::maxThreadsDim[3] is the maximum sizes of each dimension of a block; + * - ::maxGridSize[3] is the maximum sizes of each dimension of a grid; + * - ::sharedMemPerBlock is the total amount of shared memory available per + * block in bytes; + * - ::totalConstantMemory is the total amount of constant memory available on + * the device in bytes; + * - ::SIMDWidth is the warp size; + * - ::memPitch is the maximum pitch allowed by the memory copy functions that + * involve memory regions allocated through ::cuMemAllocPitch(); + * - ::regsPerBlock is the total number of registers available per block; + * - ::clockRate is the clock frequency in kilohertz; + * - ::textureAlign is the alignment requirement; texture base addresses that + * are aligned to ::textureAlign bytes do not need an offset applied to + * texture fetches. + * + * \param prop - Returned properties of device + * \param dev - Device to get properties for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuDeviceGetProperties(CUdevprop *prop, CUdevice dev); + +/** + * \brief Returns the compute capability of the device + * + * \deprecated + * + * This function was deprecated as of CUDA 5.0 and its functionality superseded + * by ::cuDeviceGetAttribute(). + * + * Returns in \p *major and \p *minor the major and minor revision numbers that + * define the compute capability of the device \p dev. + * + * \param major - Major revision number + * \param minor - Minor revision number + * \param dev - Device handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGetAttribute, + * ::cuDeviceGetCount, + * ::cuDeviceGetName, + * ::cuDeviceGetUuid, + * ::cuDeviceGet, + * ::cuDeviceTotalMem + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuDeviceComputeCapability(int *major, int *minor, CUdevice dev); + +/** @} */ /* END CUDA_DEVICE_DEPRECATED */ + +/** + * \defgroup CUDA_PRIMARY_CTX Primary Context Management + * + * ___MANBRIEF___ primary context management functions of the low-level CUDA driver + * API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the primary context management functions of the low-level + * CUDA driver application programming interface. + * + * The primary context is unique per device and shared with the CUDA runtime API. + * These functions allow integration with other libraries using CUDA. + * + * @{ + */ + +/** + * \brief Retain the primary context on the GPU + * + * Retains the primary context on the device. + * Once the user successfully retains the primary context, the primary context + * will be active and available to the user until the user releases it + * with ::cuDevicePrimaryCtxRelease() or resets it with ::cuDevicePrimaryCtxReset(). + * Unlike ::cuCtxCreate() the newly retained context is not pushed onto the stack. + * + * Retaining the primary context for the first time will fail with ::CUDA_ERROR_UNKNOWN + * if the compute mode of the device is ::CU_COMPUTEMODE_PROHIBITED. The function + * ::cuDeviceGetAttribute() can be used with ::CU_DEVICE_ATTRIBUTE_COMPUTE_MODE to + * determine the compute mode of the device. + * The nvidia-smi tool can be used to set the compute mode for + * devices. Documentation for nvidia-smi can be obtained by passing a + * -h option to it. + * + * Please note that the primary context always supports pinned allocations. Other + * flags can be specified by ::cuDevicePrimaryCtxSetFlags(). + * + * \param pctx - Returned context handle of the new context + * \param dev - Device for which primary context is requested + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuDevicePrimaryCtxRelease, + * ::cuDevicePrimaryCtxSetFlags, + * ::cuCtxCreate, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuDevicePrimaryCtxRetain(CUcontext *pctx, CUdevice dev); + +/** + * \brief Release the primary context on the GPU + * + * Releases the primary context interop on the device. + * A retained context should always be released once the user is done using + * it. The context is automatically reset once the last reference to it is + * released. This behavior is different when the primary context was retained + * by the CUDA runtime from CUDA 4.0 and earlier. In this case, the primary + * context remains always active. + * + * Releasing a primary context that has not been previously retained will + * fail with ::CUDA_ERROR_INVALID_CONTEXT. + * + * Please note that unlike ::cuCtxDestroy() this method does not pop the context + * from stack in any circumstances. + * + * \param dev - Device which primary context is released + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuDevicePrimaryCtxRetain, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuDevicePrimaryCtxRelease(CUdevice dev); + +/** + * \brief Set flags for the primary context + * + * Sets the flags for the primary context on the device overwriting perviously + * set ones. + * + * The three LSBs of the \p flags parameter can be used to control how the OS + * thread, which owns the CUDA context at the time of an API call, interacts + * with the OS scheduler when waiting for results from the GPU. Only one of + * the scheduling flags can be set when creating a context. + * + * - ::CU_CTX_SCHED_SPIN: Instruct CUDA to actively spin when waiting for + * results from the GPU. This can decrease latency when waiting for the GPU, + * but may lower the performance of CPU threads if they are performing work in + * parallel with the CUDA thread. + * + * - ::CU_CTX_SCHED_YIELD: Instruct CUDA to yield its thread when waiting for + * results from the GPU. This can increase latency when waiting for the GPU, + * but can increase the performance of CPU threads performing work in parallel + * with the GPU. + * + * - ::CU_CTX_SCHED_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work. + * + * - ::CU_CTX_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work.
    + * Deprecated: This flag was deprecated as of CUDA 4.0 and was + * replaced with ::CU_CTX_SCHED_BLOCKING_SYNC. + * + * - ::CU_CTX_SCHED_AUTO: The default value if the \p flags parameter is zero, + * uses a heuristic based on the number of active CUDA contexts in the + * process \e C and the number of logical processors in the system \e P. If + * \e C > \e P, then CUDA will yield to other OS threads when waiting for + * the GPU (::CU_CTX_SCHED_YIELD), otherwise CUDA will not yield while + * waiting for results and actively spin on the processor (::CU_CTX_SCHED_SPIN). + * Additionally, on Tegra devices, ::CU_CTX_SCHED_AUTO uses a heuristic based on + * the power profile of the platform and may choose ::CU_CTX_SCHED_BLOCKING_SYNC + * for low-powered devices. + * + * - ::CU_CTX_LMEM_RESIZE_TO_MAX: Instruct CUDA to not reduce local memory + * after resizing local memory for a kernel. This can prevent thrashing by + * local memory allocations when launching many kernels with high local + * memory usage at the cost of potentially increased memory usage.
    + * Deprecated: This flag is deprecated and the behavior enabled + * by this flag is now the default and cannot be disabled. + * + * - ::CU_CTX_COREDUMP_ENABLE: If GPU coredumps have not been enabled globally + * with ::cuCoredumpSetAttributeGlobal or environment variables, this flag can + * be set during context creation to instruct CUDA to create a coredump if + * this context raises an exception during execution. These environment variables + * are described in the CUDA-GDB user guide under the "GPU core dump support" + * section. + * The initial settings will be taken from the global settings at the time of + * context creation. The other settings that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * + * - ::CU_CTX_USER_COREDUMP_ENABLE: If user-triggered GPU coredumps have not + * been enabled globally with ::cuCoredumpSetAttributeGlobal or environment + * variables, this flag can be set during context creation to instruct CUDA to + * create a coredump if data is written to a certain pipe that is present in the + * OS space. These environment variables are described in the CUDA-GDB user + * guide under the "GPU core dump support" section. + * It is important to note that the pipe name *must* be set with + * ::cuCoredumpSetAttributeGlobal before creating the context if this flag is + * used. Setting this flag implies that ::CU_CTX_COREDUMP_ENABLE is set. + * The initial settings will be taken from the global settings at the time of + * context creation. The other settings that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * + * - ::CU_CTX_SYNC_MEMOPS: Ensures that synchronous memory operations initiated + * on this context will always synchronize. See further documentation in the + * section titled "API Synchronization behavior" to learn more about cases when + * synchronous memory operations can exhibit asynchronous behavior. + * + * \param dev - Device for which the primary context flags are set + * \param flags - New flags for the device + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa ::cuDevicePrimaryCtxRetain, + * ::cuDevicePrimaryCtxGetState, + * ::cuCtxCreate, + * ::cuCtxGetFlags, + * ::cuCtxSetFlags, + * ::cudaSetDeviceFlags + */ +CUresult CUDAAPI cuDevicePrimaryCtxSetFlags(CUdevice dev, unsigned int flags); + +/** + * \brief Get the state of the primary context + * + * Returns in \p *flags the flags for the primary context of \p dev, and in + * \p *active whether it is active. See ::cuDevicePrimaryCtxSetFlags for flag + * values. + * + * \param dev - Device to get primary context flags for + * \param flags - Pointer to store flags + * \param active - Pointer to store context state; 0 = inactive, 1 = active + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa + * ::cuDevicePrimaryCtxSetFlags, + * ::cuCtxGetFlags, + * ::cuCtxSetFlags, + * ::cudaGetDeviceFlags + */ +CUresult CUDAAPI cuDevicePrimaryCtxGetState(CUdevice dev, unsigned int *flags, int *active); + +/** + * \brief Destroy all allocations and reset all state on the primary context + * + * Explicitly destroys and cleans up all resources associated with the current + * device in the current process. + * + * Note that it is responsibility of the calling function to ensure that no + * other module in the process is using the device any more. For that reason + * it is recommended to use ::cuDevicePrimaryCtxRelease() in most cases. + * However it is safe for other modules to call ::cuDevicePrimaryCtxRelease() + * even after resetting the device. + * Resetting the primary context does not release it, an application that has + * retained the primary context should explicitly release its usage. + * + * \param dev - Device for which primary context is destroyed + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_PRIMARY_CONTEXT_ACTIVE + * \notefnerr + * + * \sa ::cuDevicePrimaryCtxRetain, + * ::cuDevicePrimaryCtxRelease, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cudaDeviceReset + */ +CUresult CUDAAPI cuDevicePrimaryCtxReset(CUdevice dev); + +/** @} */ /* END CUDA_PRIMARY_CTX */ + +/** + * \defgroup CUDA_CTX Context Management + * + * ___MANBRIEF___ context management functions of the low-level CUDA driver + * API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the context management functions of the low-level + * CUDA driver application programming interface. + * + * Please note that some functions are described in + * \ref CUDA_PRIMARY_CTX "Primary Context Management" section. + * + * @{ + */ + +/** + * \brief Create a CUDA context + * + * \note In most cases it is recommended to use ::cuDevicePrimaryCtxRetain. + * + * Creates a new CUDA context and associates it with the calling thread. The + * \p flags parameter is described below. The context is created with a usage + * count of 1 and the caller of ::cuCtxCreate() must call ::cuCtxDestroy() + * when done using the context. If a context is already current to the thread, + * it is supplanted by the newly created context and may be restored by a subsequent + * call to ::cuCtxPopCurrent(). + * + * The three LSBs of the \p flags parameter can be used to control how the OS + * thread, which owns the CUDA context at the time of an API call, interacts + * with the OS scheduler when waiting for results from the GPU. Only one of + * the scheduling flags can be set when creating a context. + * + * - ::CU_CTX_SCHED_SPIN: Instruct CUDA to actively spin when waiting for + * results from the GPU. This can decrease latency when waiting for the GPU, + * but may lower the performance of CPU threads if they are performing work in + * parallel with the CUDA thread. + * + * - ::CU_CTX_SCHED_YIELD: Instruct CUDA to yield its thread when waiting for + * results from the GPU. This can increase latency when waiting for the GPU, + * but can increase the performance of CPU threads performing work in parallel + * with the GPU. + * + * - ::CU_CTX_SCHED_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work. + * + * - ::CU_CTX_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work.
    + * Deprecated: This flag was deprecated as of CUDA 4.0 and was + * replaced with ::CU_CTX_SCHED_BLOCKING_SYNC. + * + * - ::CU_CTX_SCHED_AUTO: The default value if the \p flags parameter is zero, + * uses a heuristic based on the number of active CUDA contexts in the + * process \e C and the number of logical processors in the system \e P. If + * \e C > \e P, then CUDA will yield to other OS threads when waiting for + * the GPU (::CU_CTX_SCHED_YIELD), otherwise CUDA will not yield while + * waiting for results and actively spin on the processor (::CU_CTX_SCHED_SPIN). + * Additionally, on Tegra devices, ::CU_CTX_SCHED_AUTO uses a heuristic based on + * the power profile of the platform and may choose ::CU_CTX_SCHED_BLOCKING_SYNC + * for low-powered devices. + * + * - ::CU_CTX_MAP_HOST: Instruct CUDA to support mapped pinned allocations. + * This flag must be set in order to allocate pinned host memory that is + * accessible to the GPU. + * + * - ::CU_CTX_LMEM_RESIZE_TO_MAX: Instruct CUDA to not reduce local memory + * after resizing local memory for a kernel. This can prevent thrashing by + * local memory allocations when launching many kernels with high local + * memory usage at the cost of potentially increased memory usage.
    + * Deprecated: This flag is deprecated and the behavior enabled + * by this flag is now the default and cannot be disabled. + * Instead, the per-thread stack size can be controlled with ::cuCtxSetLimit(). + * + * - ::CU_CTX_COREDUMP_ENABLE: If GPU coredumps have not been enabled globally + * with ::cuCoredumpSetAttributeGlobal or environment variables, this flag can + * be set during context creation to instruct CUDA to create a coredump if + * this context raises an exception during execution. These environment variables + * are described in the CUDA-GDB user guide under the "GPU core dump support" + * section. + * The initial attributes will be taken from the global attributes at the time of + * context creation. The other attributes that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * + * - ::CU_CTX_USER_COREDUMP_ENABLE: If user-triggered GPU coredumps have not + * been enabled globally with ::cuCoredumpSetAttributeGlobal or environment + * variables, this flag can be set during context creation to instruct CUDA to + * create a coredump if data is written to a certain pipe that is present in the + * OS space. These environment variables are described in the CUDA-GDB user + * guide under the "GPU core dump support" section. + * It is important to note that the pipe name *must* be set with + * ::cuCoredumpSetAttributeGlobal before creating the context if this flag is + * used. Setting this flag implies that ::CU_CTX_COREDUMP_ENABLE is set. + * The initial attributes will be taken from the global attributes at the time of + * context creation. The other attributes that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * Setting this flag on any context creation is equivalent to setting the + * ::CU_COREDUMP_ENABLE_USER_TRIGGER attribute to \p true globally. + * + * - ::CU_CTX_SYNC_MEMOPS: Ensures that synchronous memory operations initiated + * on this context will always synchronize. See further documentation in the + * section titled "API Synchronization behavior" to learn more about cases when + * synchronous memory operations can exhibit asynchronous behavior. + * + * Context creation will fail with ::CUDA_ERROR_UNKNOWN if the compute mode of + * the device is ::CU_COMPUTEMODE_PROHIBITED. The function ::cuDeviceGetAttribute() + * can be used with ::CU_DEVICE_ATTRIBUTE_COMPUTE_MODE to determine the + * compute mode of the device. The nvidia-smi tool can be used to set + * the compute mode for * devices. + * Documentation for nvidia-smi can be obtained by passing a + * -h option to it. + * + * \param pctx - Returned context handle of the new context + * \param flags - Context creation flags + * \param dev - Device to create context on + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCoredumpSetAttributeGlobal, + * ::cuCoredumpSetAttribute, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuCtxCreate(CUcontext *pctx, unsigned int flags, CUdevice dev); + +/** + * \brief Create a CUDA context with execution affinity + * + * Creates a new CUDA context with execution affinity and associates it with + * the calling thread. The \p paramsArray and \p flags parameter are described below. + * The context is created with a usage count of 1 and the caller of ::cuCtxCreate() must + * call ::cuCtxDestroy() when done using the context. If a context is already + * current to the thread, it is supplanted by the newly created context and may + * be restored by a subsequent call to ::cuCtxPopCurrent(). + * + * The type and the amount of execution resource the context can use is limited by \p paramsArray + * and \p numParams. The \p paramsArray is an array of \p CUexecAffinityParam and the \p numParams + * describes the size of the array. If two \p CUexecAffinityParam in the array have the same type, + * the latter execution affinity parameter overrides the former execution affinity parameter. + * The supported execution affinity types are: + * - ::CU_EXEC_AFFINITY_TYPE_SM_COUNT limits the portion of SMs that the context can use. The portion + * of SMs is specified as the number of SMs via \p CUexecAffinitySmCount. This limit will be internally + * rounded up to the next hardware-supported amount. Hence, it is imperative to query the actual execution + * affinity of the context via \p cuCtxGetExecAffinity after context creation. Currently, this attribute + * is only supported under Volta+ MPS. + * + * The three LSBs of the \p flags parameter can be used to control how the OS + * thread, which owns the CUDA context at the time of an API call, interacts + * with the OS scheduler when waiting for results from the GPU. Only one of + * the scheduling flags can be set when creating a context. + * + * - ::CU_CTX_SCHED_SPIN: Instruct CUDA to actively spin when waiting for + * results from the GPU. This can decrease latency when waiting for the GPU, + * but may lower the performance of CPU threads if they are performing work in + * parallel with the CUDA thread. + * + * - ::CU_CTX_SCHED_YIELD: Instruct CUDA to yield its thread when waiting for + * results from the GPU. This can increase latency when waiting for the GPU, + * but can increase the performance of CPU threads performing work in parallel + * with the GPU. + * + * - ::CU_CTX_SCHED_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work. + * + * - ::CU_CTX_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work.
    + * Deprecated: This flag was deprecated as of CUDA 4.0 and was + * replaced with ::CU_CTX_SCHED_BLOCKING_SYNC. + * + * - ::CU_CTX_SCHED_AUTO: The default value if the \p flags parameter is zero, + * uses a heuristic based on the number of active CUDA contexts in the + * process \e C and the number of logical processors in the system \e P. If + * \e C > \e P, then CUDA will yield to other OS threads when waiting for + * the GPU (::CU_CTX_SCHED_YIELD), otherwise CUDA will not yield while + * waiting for results and actively spin on the processor (::CU_CTX_SCHED_SPIN). + * Additionally, on Tegra devices, ::CU_CTX_SCHED_AUTO uses a heuristic based on + * the power profile of the platform and may choose ::CU_CTX_SCHED_BLOCKING_SYNC + * for low-powered devices. + * + * - ::CU_CTX_MAP_HOST: Instruct CUDA to support mapped pinned allocations. + * This flag must be set in order to allocate pinned host memory that is + * accessible to the GPU. + * + * - ::CU_CTX_LMEM_RESIZE_TO_MAX: Instruct CUDA to not reduce local memory + * after resizing local memory for a kernel. This can prevent thrashing by + * local memory allocations when launching many kernels with high local + * memory usage at the cost of potentially increased memory usage.
    + * Deprecated: This flag is deprecated and the behavior enabled + * by this flag is now the default and cannot be disabled. + * Instead, the per-thread stack size can be controlled with ::cuCtxSetLimit(). + * + * - ::CU_CTX_COREDUMP_ENABLE: If GPU coredumps have not been enabled globally + * with ::cuCoredumpSetAttributeGlobal or environment variables, this flag can + * be set during context creation to instruct CUDA to create a coredump if + * this context raises an exception during execution. These environment variables + * are described in the CUDA-GDB user guide under the "GPU core dump support" + * section. + * The initial attributes will be taken from the global attributes at the time of + * context creation. The other attributes that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * + * - ::CU_CTX_USER_COREDUMP_ENABLE: If user-triggered GPU coredumps have not + * been enabled globally with ::cuCoredumpSetAttributeGlobal or environment + * variables, this flag can be set during context creation to instruct CUDA to + * create a coredump if data is written to a certain pipe that is present in the + * OS space. These environment variables are described in the CUDA-GDB user + * guide under the "GPU core dump support" section. + * It is important to note that the pipe name *must* be set with + * ::cuCoredumpSetAttributeGlobal before creating the context if this flag is + * used. Setting this flag implies that ::CU_CTX_COREDUMP_ENABLE is set. + * The initial attributes will be taken from the global attributes at the time of + * context creation. The other attributes that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * Setting this flag on any context creation is equivalent to setting the + * ::CU_COREDUMP_ENABLE_USER_TRIGGER attribute to \p true globally. + * + * Context creation will fail with ::CUDA_ERROR_UNKNOWN if the compute mode of + * the device is ::CU_COMPUTEMODE_PROHIBITED. The function ::cuDeviceGetAttribute() + * can be used with ::CU_DEVICE_ATTRIBUTE_COMPUTE_MODE to determine the + * compute mode of the device. The nvidia-smi tool can be used to set + * the compute mode for * devices. + * Documentation for nvidia-smi can be obtained by passing a + * -h option to it. + * + * \param pctx - Returned context handle of the new context + * \param paramsArray - Execution affinity parameters + * \param numParams - Number of execution affinity parameters + * \param flags - Context creation flags + * \param dev - Device to create context on + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNSUPPORTED_EXEC_AFFINITY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cuCoredumpSetAttributeGlobal, + * ::cuCoredumpSetAttribute, + * ::CUexecAffinityParam + */ +CUresult CUDAAPI cuCtxCreate_v3(CUcontext *pctx, CUexecAffinityParam *paramsArray, int numParams, unsigned int flags, CUdevice dev); + +/** + * \brief Create a CUDA context + * + * Creates a new CUDA context and associates it with the calling thread. The + * \p flags parameter is described below. The context is created with a usage + * count of 1 and the caller of ::cuCtxCreate() must call ::cuCtxDestroy() + * when done using the context. If a context is already current to the thread, + * it is supplanted by the newly created context and may be restored by a subsequent + * call to ::cuCtxPopCurrent(). + * + * CUDA context can be created with execution affinity. The type and the amount of + execution resource the context can use is limited by \p paramsArray and \p numExecAffinityParams + in \p execAffinity. The \p paramsArray is an array of \p CUexecAffinityParam and the \p numExecAffinityParams + * describes the size of the paramsArray. If two \p CUexecAffinityParam in the array have the same type, + * the latter execution affinity parameter overrides the former execution affinity parameter. + * The supported execution affinity types are: + * - ::CU_EXEC_AFFINITY_TYPE_SM_COUNT limits the portion of SMs that the context can use. The portion + * of SMs is specified as the number of SMs via \p CUexecAffinitySmCount. This limit will be internally + * rounded up to the next hardware-supported amount. Hence, it is imperative to query the actual execution + * affinity of the context via \p cuCtxGetExecAffinity after context creation. Currently, this attribute + * is only supported under Volta+ MPS. + * + * CUDA context can be created in CIG(CUDA in Graphics) mode by setting /p cigParams. Hardware support + * and software support for graphics clients can be determined using ::cuDeviceGetAttribute() with + * ::CU_DEVICE_ATTRIBUTE_D3D12_CIG_SUPPORTED. Data from graphics client is shared with CUDA via + * the /p sharedData in /pcigParams. For D3D12, /p sharedData is a ID3D12CommandQueue handle. + * + * Either /p execAffinityParams or /p cigParams can be set to a non-null value. Setting both to a + * non-null value will result in an undefined behavior. + * + * The three LSBs of the \p flags parameter can be used to control how the OS + * thread, which owns the CUDA context at the time of an API call, interacts + * with the OS scheduler when waiting for results from the GPU. Only one of + * the scheduling flags can be set when creating a context. + * + * - ::CU_CTX_SCHED_SPIN: Instruct CUDA to actively spin when waiting for + * results from the GPU. This can decrease latency when waiting for the GPU, + * but may lower the performance of CPU threads if they are performing work in + * parallel with the CUDA thread. + * + * - ::CU_CTX_SCHED_YIELD: Instruct CUDA to yield its thread when waiting for + * results from the GPU. This can increase latency when waiting for the GPU, + * but can increase the performance of CPU threads performing work in parallel + * with the GPU. + * + * - ::CU_CTX_SCHED_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work. + * + * - ::CU_CTX_BLOCKING_SYNC: Instruct CUDA to block the CPU thread on a + * synchronization primitive when waiting for the GPU to finish work.
    + * Deprecated: This flag was deprecated as of CUDA 4.0 and was + * replaced with ::CU_CTX_SCHED_BLOCKING_SYNC. + * + * - ::CU_CTX_SCHED_AUTO: The default value if the \p flags parameter is zero, + * uses a heuristic based on the number of active CUDA contexts in the + * process \e C and the number of logical processors in the system \e P. If + * \e C > \e P, then CUDA will yield to other OS threads when waiting for + * the GPU (::CU_CTX_SCHED_YIELD), otherwise CUDA will not yield while + * waiting for results and actively spin on the processor (::CU_CTX_SCHED_SPIN). + * Additionally, on Tegra devices, ::CU_CTX_SCHED_AUTO uses a heuristic based on + * the power profile of the platform and may choose ::CU_CTX_SCHED_BLOCKING_SYNC + * for low-powered devices. + * + * - ::CU_CTX_MAP_HOST: Instruct CUDA to support mapped pinned allocations. + * This flag must be set in order to allocate pinned host memory that is + * accessible to the GPU. + * + * - ::CU_CTX_LMEM_RESIZE_TO_MAX: Instruct CUDA to not reduce local memory + * after resizing local memory for a kernel. This can prevent thrashing by + * local memory allocations when launching many kernels with high local + * memory usage at the cost of potentially increased memory usage.
    + * Deprecated: This flag is deprecated and the behavior enabled + * by this flag is now the default and cannot be disabled. + * Instead, the per-thread stack size can be controlled with ::cuCtxSetLimit(). + * + * - ::CU_CTX_COREDUMP_ENABLE: If GPU coredumps have not been enabled globally + * with ::cuCoredumpSetAttributeGlobal or environment variables, this flag can + * be set during context creation to instruct CUDA to create a coredump if + * this context raises an exception during execution. These environment variables + * are described in the CUDA-GDB user guide under the "GPU core dump support" + * section. + * The initial attributes will be taken from the global attributes at the time of + * context creation. The other attributes that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. This flag is not supported when CUDA context is created in + * CIG(CUDA in Graphics) mode. + * + * - ::CU_CTX_USER_COREDUMP_ENABLE: If user-triggered GPU coredumps have not + * been enabled globally with ::cuCoredumpSetAttributeGlobal or environment + * variables, this flag can be set during context creation to instruct CUDA to + * create a coredump if data is written to a certain pipe that is present in the + * OS space. These environment variables are described in the CUDA-GDB user + * guide under the "GPU core dump support" section. + * It is important to note that the pipe name *must* be set with + * ::cuCoredumpSetAttributeGlobal before creating the context if this flag is + * used. Setting this flag implies that ::CU_CTX_COREDUMP_ENABLE is set. + * The initial attributes will be taken from the global attributes at the time of + * context creation. The other attributes that control coredump output can be + * modified by calling ::cuCoredumpSetAttribute from the created context after + * it becomes current. + * Setting this flag on any context creation is equivalent to setting the + * ::CU_COREDUMP_ENABLE_USER_TRIGGER attribute to \p true globally. + * This flag is not supported when CUDA context is created in + * CIG(CUDA in Graphics) mode. + * + * - ::CU_CTX_SYNC_MEMOPS: Ensures that synchronous memory operations initiated + * on this context will always synchronize. See further documentation in the + * section titled "API Synchronization behavior" to learn more about cases when + * synchronous memory operations can exhibit asynchronous behavior. + * + * Context creation will fail with ::CUDA_ERROR_UNKNOWN if the compute mode of + * the device is ::CU_COMPUTEMODE_PROHIBITED. The function ::cuDeviceGetAttribute() + * can be used with ::CU_DEVICE_ATTRIBUTE_COMPUTE_MODE to determine the + * compute mode of the device. The nvidia-smi tool can be used to set + * the compute mode for * devices. + * Documentation for nvidia-smi can be obtained by passing a + * -h option to it. + * + * Context creation will fail with :: CUDA_ERROR_INVALID_VALUE if invalid parameter was + * passed by client to create the CUDA context. + * + * Context creation in CIG mode will fail with ::CUDA_ERROR_NOT_SUPPORTED if CIG is not supported + * by the device or the driver. + * + * \param pctx - Returned context handle of the new context + * \param ctxCreateParams - Context creation parameters + * \param flags - Context creation flags + * \param dev - Device to create context on + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCoredumpSetAttributeGlobal, + * ::cuCoredumpSetAttribute, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuCtxCreate_v4(CUcontext *pctx, CUctxCreateParams *ctxCreateParams, unsigned int flags, CUdevice dev); + +/** + * \brief Destroy a CUDA context + * + * Destroys the CUDA context specified by \p ctx. The context \p ctx will be + * destroyed regardless of how many threads it is current to. + * It is the responsibility of the calling function to ensure that no API + * call issues using \p ctx while ::cuCtxDestroy() is executing. + * + * Destroys and cleans up all resources associated with the context. + * It is the caller's responsibility to ensure that the context or its resources + * are not accessed or passed in subsequent API calls and doing so will result in undefined behavior. + * These resources include CUDA types ::CUmodule, ::CUfunction, ::CUstream, ::CUevent, + * ::CUarray, ::CUmipmappedArray, ::CUtexObject, ::CUsurfObject, ::CUtexref, ::CUsurfref, + * ::CUgraphicsResource, ::CUlinkState, ::CUexternalMemory and ::CUexternalSemaphore. + * These resources also include memory allocations by ::cuMemAlloc(), ::cuMemAllocHost(), + * ::cuMemAllocManaged() and ::cuMemAllocPitch(). + * + * If \p ctx is current to the calling thread then \p ctx will also be + * popped from the current thread's context stack (as though ::cuCtxPopCurrent() + * were called). If \p ctx is current to other threads, then \p ctx will + * remain current to those threads, and attempting to access \p ctx from + * those threads will result in the error ::CUDA_ERROR_CONTEXT_IS_DESTROYED. + * + * \note ::cuCtxDestroy() will not destroy memory allocations by ::cuMemCreate(), ::cuMemAllocAsync() and + * ::cuMemAllocFromPoolAsync(). These memory allocations are not associated with any CUDA context and need to + * be destroyed explicitly. + * + * \param ctx - Context to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuCtxDestroy(CUcontext ctx); + +/** + * \brief Pushes a context on the current CPU thread + * + * Pushes the given context \p ctx onto the CPU thread's stack of current + * contexts. The specified context becomes the CPU thread's current context, so + * all CUDA functions that operate on the current context are affected. + * + * The previous current context may be made current again by calling + * ::cuCtxDestroy() or ::cuCtxPopCurrent(). + * + * \param ctx - Context to push + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuCtxPushCurrent(CUcontext ctx); + +/** + * \brief Pops the current CUDA context from the current CPU thread. + * + * Pops the current CUDA context from the CPU thread and passes back the + * old context handle in \p *pctx. That context may then be made current + * to a different CPU thread by calling ::cuCtxPushCurrent(). + * + * If a context was current to the CPU thread before ::cuCtxCreate() or + * ::cuCtxPushCurrent() was called, this function makes that context current to + * the CPU thread again. + * + * \param pctx - Returned popped context handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuCtxPopCurrent(CUcontext *pctx); + +/** + * \brief Binds the specified CUDA context to the calling CPU thread + * + * Binds the specified CUDA context to the calling CPU thread. + * If \p ctx is NULL then the CUDA context previously bound to the + * calling CPU thread is unbound and ::CUDA_SUCCESS is returned. + * + * If there exists a CUDA context stack on the calling CPU thread, this + * will replace the top of that stack with \p ctx. + * If \p ctx is NULL then this will be equivalent to popping the top + * of the calling CPU thread's CUDA context stack (or a no-op if the + * calling CPU thread's CUDA context stack is empty). + * + * \param ctx - Context to bind to the calling CPU thread + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa + * ::cuCtxGetCurrent, + * ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cudaSetDevice + */ +CUresult CUDAAPI cuCtxSetCurrent(CUcontext ctx); + +/** + * \brief Returns the CUDA context bound to the calling CPU thread. + * + * Returns in \p *pctx the CUDA context bound to the calling CPU thread. + * If no context is bound to the calling CPU thread then \p *pctx is + * set to NULL and ::CUDA_SUCCESS is returned. + * + * \param pctx - Returned context handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * \notefnerr + * + * \sa + * ::cuCtxSetCurrent, + * ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cudaGetDevice + */ +CUresult CUDAAPI cuCtxGetCurrent(CUcontext *pctx); + +/** + * \brief Returns the device ID for the current context + * + * Returns in \p *device the ordinal of the current context's device. + * + * \param device - Returned device ID for the current context + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cudaGetDevice + */ +CUresult CUDAAPI cuCtxGetDevice(CUdevice *device); + +/** + * \brief Returns the flags for the current context + * + * Returns in \p *flags the flags of the current context. See ::cuCtxCreate + * for flag values. + * + * \param flags - Pointer to store flags of current context + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetCurrent, + * ::cuCtxGetDevice, + * ::cuCtxGetLimit, + * ::cuCtxGetSharedMemConfig, + * ::cuCtxGetStreamPriorityRange, + * ::cuCtxSetFlags, + * ::cudaGetDeviceFlags + */ +CUresult CUDAAPI cuCtxGetFlags(unsigned int *flags); + +/** + * \brief Sets the flags for the current context + * + * Sets the flags for the current context overwriting previously set ones. See + * ::cuDevicePrimaryCtxSetFlags for flag values. + * + * \param flags - Flags to set on the current context + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetCurrent, + * ::cuCtxGetDevice, + * ::cuCtxGetLimit, + * ::cuCtxGetSharedMemConfig, + * ::cuCtxGetStreamPriorityRange, + * ::cuCtxGetFlags, + * ::cudaGetDeviceFlags, + * ::cuDevicePrimaryCtxSetFlags, + */ +CUresult CUDAAPI cuCtxSetFlags(unsigned int flags); + +/** + * \brief Returns the unique Id associated with the context supplied + * + * Returns in \p ctxId the unique Id which is associated with a given context. + * The Id is unique for the life of the program for this instance of CUDA. + * If context is supplied as NULL and there is one current, the Id of the + * current context is returned. + * + * \param ctx - Context for which to obtain the Id + * \param ctxId - Pointer to store the Id of the context + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPushCurrent + */ +CUresult CUDAAPI cuCtxGetId(CUcontext ctx, unsigned long long *ctxId); + +/** + * \brief Block for the current context's tasks to complete + * + * Blocks until the current context has completed all preceding requested tasks. + * If the current context is the primary context, green contexts that have been + * created will also be synchronized. + * ::cuCtxSynchronize() returns an error if one of the preceding tasks failed. + * If the context was created with the ::CU_CTX_SCHED_BLOCKING_SYNC flag, the + * CPU thread will block until the GPU context has finished its work. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cudaDeviceSynchronize + */ +CUresult CUDAAPI cuCtxSynchronize(void); + +/** + * \brief Set resource limits + * + * Setting \p limit to \p value is a request by the application to update + * the current limit maintained by the context. The driver is free to + * modify the requested value to meet h/w requirements (this could be + * clamping to minimum or maximum values, rounding up to nearest element + * size, etc). The application can use ::cuCtxGetLimit() to find out exactly + * what the limit has been set to. + * + * Setting each ::CUlimit has its own specific restrictions, so each is + * discussed here. + * + * - ::CU_LIMIT_STACK_SIZE controls the stack size in bytes of each GPU thread. + * The driver automatically increases the per-thread stack size + * for each kernel launch as needed. This size isn't reset back to the + * original value after each launch. Setting this value will take effect + * immediately, and if necessary, the device will block until all preceding + * requested tasks are complete. + * + * - ::CU_LIMIT_PRINTF_FIFO_SIZE controls the size in bytes of the FIFO used + * by the ::printf() device system call. Setting ::CU_LIMIT_PRINTF_FIFO_SIZE + * must be performed before launching any kernel that uses the ::printf() + * device system call, otherwise ::CUDA_ERROR_INVALID_VALUE will be returned. + * + * - ::CU_LIMIT_MALLOC_HEAP_SIZE controls the size in bytes of the heap used + * by the ::malloc() and ::free() device system calls. Setting + * ::CU_LIMIT_MALLOC_HEAP_SIZE must be performed before launching any kernel + * that uses the ::malloc() or ::free() device system calls, otherwise + * ::CUDA_ERROR_INVALID_VALUE will be returned. + * + * - ::CU_LIMIT_DEV_RUNTIME_SYNC_DEPTH controls the maximum nesting depth of + * a grid at which a thread can safely call ::cudaDeviceSynchronize(). Setting + * this limit must be performed before any launch of a kernel that uses the + * device runtime and calls ::cudaDeviceSynchronize() above the default sync + * depth, two levels of grids. Calls to ::cudaDeviceSynchronize() will fail + * with error code ::cudaErrorSyncDepthExceeded if the limitation is + * violated. This limit can be set smaller than the default or up the maximum + * launch depth of 24. When setting this limit, keep in mind that additional + * levels of sync depth require the driver to reserve large amounts of device + * memory which can no longer be used for user allocations. If these + * reservations of device memory fail, ::cuCtxSetLimit() will return + * ::CUDA_ERROR_OUT_OF_MEMORY, and the limit can be reset to a lower value. + * This limit is only applicable to devices of compute capability < 9.0. + * Attempting to set this limit on devices of other compute capability + * versions will result in the error ::CUDA_ERROR_UNSUPPORTED_LIMIT being + * returned. + * + * - ::CU_LIMIT_DEV_RUNTIME_PENDING_LAUNCH_COUNT controls the maximum number of + * outstanding device runtime launches that can be made from the current + * context. A grid is outstanding from the point of launch up until the grid + * is known to have been completed. Device runtime launches which violate + * this limitation fail and return ::cudaErrorLaunchPendingCountExceeded when + * ::cudaGetLastError() is called after launch. If more pending launches than + * the default (2048 launches) are needed for a module using the device + * runtime, this limit can be increased. Keep in mind that being able to + * sustain additional pending launches will require the driver to reserve + * larger amounts of device memory upfront which can no longer be used for + * allocations. If these reservations fail, ::cuCtxSetLimit() will return + * ::CUDA_ERROR_OUT_OF_MEMORY, and the limit can be reset to a lower value. + * This limit is only applicable to devices of compute capability 3.5 and + * higher. Attempting to set this limit on devices of compute capability less + * than 3.5 will result in the error ::CUDA_ERROR_UNSUPPORTED_LIMIT being + * returned. + * + * - ::CU_LIMIT_MAX_L2_FETCH_GRANULARITY controls the L2 cache fetch granularity. + * Values can range from 0B to 128B. This is purely a performance hint and + * it can be ignored or clamped depending on the platform. + * + * - ::CU_LIMIT_PERSISTING_L2_CACHE_SIZE controls size in bytes available for + * persisting L2 cache. This is purely a performance hint and it can be + * ignored or clamped depending on the platform. + * + * \param limit - Limit to set + * \param value - Size of limit + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNSUPPORTED_LIMIT, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSynchronize, + * ::cudaDeviceSetLimit + */ +CUresult CUDAAPI cuCtxSetLimit(CUlimit limit, size_t value); + +/** + * \brief Returns resource limits + * + * Returns in \p *pvalue the current size of \p limit. The supported + * ::CUlimit values are: + * - ::CU_LIMIT_STACK_SIZE: stack size in bytes of each GPU thread. + * - ::CU_LIMIT_PRINTF_FIFO_SIZE: size in bytes of the FIFO used by the + * ::printf() device system call. + * - ::CU_LIMIT_MALLOC_HEAP_SIZE: size in bytes of the heap used by the + * ::malloc() and ::free() device system calls. + * - ::CU_LIMIT_DEV_RUNTIME_SYNC_DEPTH: maximum grid depth at which a thread + * can issue the device runtime call ::cudaDeviceSynchronize() to wait on + * child grid launches to complete. + * - ::CU_LIMIT_DEV_RUNTIME_PENDING_LAUNCH_COUNT: maximum number of outstanding + * device runtime launches that can be made from this context. + * - ::CU_LIMIT_MAX_L2_FETCH_GRANULARITY: L2 cache fetch granularity. + * - ::CU_LIMIT_PERSISTING_L2_CACHE_SIZE: Persisting L2 cache size in bytes + * + * \param limit - Limit to query + * \param pvalue - Returned size of limit + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNSUPPORTED_LIMIT + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cudaDeviceGetLimit + */ +CUresult CUDAAPI cuCtxGetLimit(size_t *pvalue, CUlimit limit); + +/** + * \brief Returns the preferred cache configuration for the current context. + * + * On devices where the L1 cache and shared memory use the same hardware + * resources, this function returns through \p pconfig the preferred cache configuration + * for the current context. This is only a preference. The driver will use + * the requested configuration if possible, but it is free to choose a different + * configuration if required to execute functions. + * + * This will return a \p pconfig of ::CU_FUNC_CACHE_PREFER_NONE on devices + * where the size of the L1 cache and shared memory are fixed. + * + * The supported cache configurations are: + * - ::CU_FUNC_CACHE_PREFER_NONE: no preference for shared memory or L1 (default) + * - ::CU_FUNC_CACHE_PREFER_SHARED: prefer larger shared memory and smaller L1 cache + * - ::CU_FUNC_CACHE_PREFER_L1: prefer larger L1 cache and smaller shared memory + * - ::CU_FUNC_CACHE_PREFER_EQUAL: prefer equal sized L1 cache and shared memory + * + * \param pconfig - Returned cache configuration + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cuFuncSetCacheConfig, + * ::cudaDeviceGetCacheConfig + */ +CUresult CUDAAPI cuCtxGetCacheConfig(CUfunc_cache *pconfig); + +/** + * \brief Sets the preferred cache configuration for the current context. + * + * On devices where the L1 cache and shared memory use the same hardware + * resources, this sets through \p config the preferred cache configuration for + * the current context. This is only a preference. The driver will use + * the requested configuration if possible, but it is free to choose a different + * configuration if required to execute the function. Any function preference + * set via ::cuFuncSetCacheConfig() or ::cuKernelSetCacheConfig() will be preferred over this context-wide + * setting. Setting the context-wide cache configuration to + * ::CU_FUNC_CACHE_PREFER_NONE will cause subsequent kernel launches to prefer + * to not change the cache configuration unless required to launch the kernel. + * + * This setting does nothing on devices where the size of the L1 cache and + * shared memory are fixed. + * + * Launching a kernel with a different preference than the most recent + * preference setting may insert a device-side synchronization point. + * + * The supported cache configurations are: + * - ::CU_FUNC_CACHE_PREFER_NONE: no preference for shared memory or L1 (default) + * - ::CU_FUNC_CACHE_PREFER_SHARED: prefer larger shared memory and smaller L1 cache + * - ::CU_FUNC_CACHE_PREFER_L1: prefer larger L1 cache and smaller shared memory + * - ::CU_FUNC_CACHE_PREFER_EQUAL: prefer equal sized L1 cache and shared memory + * + * \param config - Requested cache configuration + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cuFuncSetCacheConfig, + * ::cudaDeviceSetCacheConfig, + * ::cuKernelSetCacheConfig + */ +CUresult CUDAAPI cuCtxSetCacheConfig(CUfunc_cache config); + +/** + * \brief Gets the context's API version. + * + * Returns a version number in \p version corresponding to the capabilities of + * the context (e.g. 3010 or 3020), which library developers can use to direct + * callers to a specific API version. If \p ctx is NULL, returns the API version + * used to create the currently bound context. + * + * Note that new API versions are only introduced when context capabilities are + * changed that break binary compatibility, so the API version and driver version + * may be different. For example, it is valid for the API version to be 3020 while + * the driver version is 4020. + * + * \param ctx - Context to check + * \param version - Pointer to version + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +CUresult CUDAAPI cuCtxGetApiVersion(CUcontext ctx, unsigned int *version); + +/** + * \brief Returns numerical values that correspond to the least and + * greatest stream priorities. + * + * Returns in \p *leastPriority and \p *greatestPriority the numerical values that correspond + * to the least and greatest stream priorities respectively. Stream priorities + * follow a convention where lower numbers imply greater priorities. The range of + * meaningful stream priorities is given by [\p *greatestPriority, \p *leastPriority]. + * If the user attempts to create a stream with a priority value that is + * outside the meaningful range as specified by this API, the priority is + * automatically clamped down or up to either \p *leastPriority or \p *greatestPriority + * respectively. See ::cuStreamCreateWithPriority for details on creating a + * priority stream. + * A NULL may be passed in for \p *leastPriority or \p *greatestPriority if the value + * is not desired. + * + * This function will return '0' in both \p *leastPriority and \p *greatestPriority if + * the current context's device does not support stream priorities + * (see ::cuDeviceGetAttribute). + * + * \param leastPriority - Pointer to an int in which the numerical value for least + * stream priority is returned + * \param greatestPriority - Pointer to an int in which the numerical value for greatest + * stream priority is returned + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa ::cuStreamCreateWithPriority, + * ::cuStreamGetPriority, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cudaDeviceGetStreamPriorityRange + */ +CUresult CUDAAPI cuCtxGetStreamPriorityRange(int *leastPriority, int *greatestPriority); + +/** + * \brief Resets all persisting lines in cache to normal status. + * + * ::cuCtxResetPersistingL2Cache Resets all persisting lines in cache to normal + * status. Takes effect on function return. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuCtxResetPersistingL2Cache(void); + +/** + * \brief Returns the execution affinity setting for the current context. + * + * Returns in \p *pExecAffinity the current value of \p type. The supported + * ::CUexecAffinityType values are: + * - ::CU_EXEC_AFFINITY_TYPE_SM_COUNT: number of SMs the context is limited to use. + * + * \param type - Execution affinity type to query + * \param pExecAffinity - Returned execution affinity + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNSUPPORTED_EXEC_AFFINITY + * \notefnerr + * + * \sa + * ::CUexecAffinityParam + */ +CUresult CUDAAPI cuCtxGetExecAffinity(CUexecAffinityParam *pExecAffinity, CUexecAffinityType type); + +/** + * \brief Records an event. + * + * Captures in \p hEvent all the activities of the context \p hCtx + * at the time of this call. \p hEvent and \p hCtx must be from the same + * CUDA context, otherwise ::CUDA_ERROR_INVALID_HANDLE will be returned. + * Calls such as ::cuEventQuery() or ::cuCtxWaitEvent() will then examine + * or wait for completion of the work that was captured. + * Uses of \p hCtx after this call do not modify \p hEvent. + * If the context passed to \p hCtx is the primary context, \p hEvent will + * capture all the activities of the primary context and its green contexts. + * If the context passed to \p hCtx is a context converted from green context + * via ::cuCtxFromGreenCtx(), \p hEvent will capture only the activities of the green context. + * + * \note The API will return ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED if the + * specified context \p hCtx has a stream in the capture mode. In such a case, + * the call will invalidate all the conflicting captures. + * + * \param hCtx - Context to record event for + * \param hEvent - Event to record + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED + * + * \sa + * ::cuCtxWaitEvent, + * ::cuGreenCtxRecordEvent, + * ::cuGreenCtxWaitEvent, + * ::cuEventRecord + */ +CUresult CUDAAPI cuCtxRecordEvent(CUcontext hCtx, CUevent hEvent); + +/** + * \brief Make a context wait on an event + * + * Makes all future work submitted to context \p hCtx wait for all work + * captured in \p hEvent. The synchronization will be performed on the device + * and will not block the calling CPU thread. See ::cuCtxRecordEvent() + * for details on what is captured by an event. + * If the context passed to \p hCtx is the primary context, the primary context + * and its green contexts will wait for \p hEvent. + * If the context passed to \p hCtx is a context converted from green context + * via ::cuCtxFromGreenCtx(), the green context will wait for \p hEvent. + * + * \note \p hEvent may be from a different context or device than \p hCtx. + * + * \note The API will return ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED and + * invalidate the capture if the specified event \p hEvent is part of an ongoing + * capture sequence or if the specified context \p hCtx has a stream in the capture mode. + * + * \param hCtx - Context to wait + * \param hEvent - Event to wait on + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED + * + * \sa + * ::cuCtxRecordEvent, + * ::cuGreenCtxRecordEvent, + * ::cuGreenCtxWaitEvent, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuCtxWaitEvent(CUcontext hCtx, CUevent hEvent); + +/** @} */ /* END CUDA_CTX */ + +/** + * \defgroup CUDA_CTX_DEPRECATED Context Management [DEPRECATED] + * + * ___MANBRIEF___ deprecated context management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the deprecated context management functions of the low-level + * CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Increment a context's usage-count + * + * \deprecated + * + * Note that this function is deprecated and should not be used. + * + * Increments the usage count of the context and passes back a context handle + * in \p *pctx that must be passed to ::cuCtxDetach() when the application is + * done with the context. ::cuCtxAttach() fails if there is no context current + * to the thread. + * + * Currently, the \p flags parameter must be 0. + * + * \param pctx - Returned context handle of the current context + * \param flags - Context attach flags (must be 0) + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxDetach, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuCtxAttach(CUcontext *pctx, unsigned int flags); + +/** + * \brief Decrement a context's usage-count + * + * \deprecated + * + * Note that this function is deprecated and should not be used. + * + * Decrements the usage count of the context \p ctx, and destroys the context + * if the usage count goes to 0. The context must be a handle that was passed + * back by ::cuCtxCreate() or ::cuCtxAttach(), and must be current to the + * calling thread. + * + * \param ctx - Context to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetCacheConfig, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuCtxDetach(CUcontext ctx); + + +/** + * \brief Returns the current shared memory configuration for the current context. + * + * \deprecated + * + * This function will return in \p pConfig the current size of shared memory banks + * in the current context. On devices with configurable shared memory banks, + * ::cuCtxSetSharedMemConfig can be used to change this setting, so that all + * subsequent kernel launches will by default use the new bank size. When + * ::cuCtxGetSharedMemConfig is called on devices without configurable shared + * memory, it will return the fixed bank size of the hardware. + * + * The returned bank configurations can be either: + * - ::CU_SHARED_MEM_CONFIG_FOUR_BYTE_BANK_SIZE: shared memory bank width is + * four bytes. + * - ::CU_SHARED_MEM_CONFIG_EIGHT_BYTE_BANK_SIZE: shared memory bank width will + * eight bytes. + * + * \param pConfig - returned shared memory configuration + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cuCtxGetSharedMemConfig, + * ::cuFuncSetCacheConfig, + * ::cudaDeviceGetSharedMemConfig + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuCtxGetSharedMemConfig(CUsharedconfig *pConfig); + +/** + * \brief Sets the shared memory configuration for the current context. + * + * \deprecated + * + * On devices with configurable shared memory banks, this function will set + * the context's shared memory bank size which is used for subsequent kernel + * launches. + * + * Changed the shared memory configuration between launches may insert a device + * side synchronization point between those launches. + * + * Changing the shared memory bank size will not increase shared memory usage + * or affect occupancy of kernels, but may have major effects on performance. + * Larger bank sizes will allow for greater potential bandwidth to shared memory, + * but will change what kinds of accesses to shared memory will result in bank + * conflicts. + * + * This function will do nothing on devices with fixed shared memory bank size. + * + * The supported bank configurations are: + * - ::CU_SHARED_MEM_CONFIG_DEFAULT_BANK_SIZE: set bank width to the default initial + * setting (currently, four bytes). + * - ::CU_SHARED_MEM_CONFIG_FOUR_BYTE_BANK_SIZE: set shared memory bank width to + * be natively four bytes. + * - ::CU_SHARED_MEM_CONFIG_EIGHT_BYTE_BANK_SIZE: set shared memory bank width to + * be natively eight bytes. + * + * \param config - requested shared memory configuration + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxCreate, + * ::cuCtxDestroy, + * ::cuCtxGetApiVersion, + * ::cuCtxGetCacheConfig, + * ::cuCtxGetDevice, + * ::cuCtxGetFlags, + * ::cuCtxGetLimit, + * ::cuCtxPopCurrent, + * ::cuCtxPushCurrent, + * ::cuCtxSetLimit, + * ::cuCtxSynchronize, + * ::cuCtxGetSharedMemConfig, + * ::cuFuncSetCacheConfig, + * ::cudaDeviceSetSharedMemConfig + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuCtxSetSharedMemConfig(CUsharedconfig config); + +/** @} */ /* END CUDA_CTX_DEPRECATED */ + + +/** + * \defgroup CUDA_MODULE Module Management + * + * ___MANBRIEF___ module management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the module management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Loads a compute module + * + * Takes a filename \p fname and loads the corresponding module \p module into + * the current context. The CUDA driver API does not attempt to lazily + * allocate the resources needed by a module; if the memory for functions and + * data (constant and global) needed by the module cannot be allocated, + * ::cuModuleLoad() fails. The file should be a \e cubin file as output by + * \b nvcc, or a \e PTX file either as output by \b nvcc or handwritten, or + * a \e fatbin file as output by \b nvcc from toolchain 4.0 or later. + * + * \param module - Returned module + * \param fname - Filename of module to load + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_NOT_FOUND, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_FILE_NOT_FOUND, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU, + * ::CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND + * \notefnerr + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload + */ +CUresult CUDAAPI cuModuleLoad(CUmodule *module, const char *fname); + +/** + * \brief Load a module's data + * + * Takes a pointer \p image and loads the corresponding module \p module into + * the current context. The \p image may be a \e cubin or \e fatbin + * as output by \b nvcc, or a NULL-terminated \e PTX, either as output by \b nvcc + * or hand-written. + * + * \param module - Returned module + * \param image - Module data to load + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU, + * ::CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND + * \notefnerr + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload + */ +CUresult CUDAAPI cuModuleLoadData(CUmodule *module, const void *image); + +/** + * \brief Load a module's data with options + * + * Takes a pointer \p image and loads the corresponding module \p module into + * the current context. The \p image may be a \e cubin or \e fatbin + * as output by \b nvcc, or a NULL-terminated \e PTX, either as output by \b nvcc + * or hand-written. + * + * \param module - Returned module + * \param image - Module data to load + * \param numOptions - Number of options + * \param options - Options for JIT + * \param optionValues - Option values for JIT + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU, + * ::CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND + * \notefnerr + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload + */ +CUresult CUDAAPI cuModuleLoadDataEx(CUmodule *module, const void *image, unsigned int numOptions, CUjit_option *options, void **optionValues); + +/** + * \brief Load a module's data + * + * Takes a pointer \p fatCubin and loads the corresponding module \p module + * into the current context. The pointer represents a fat binary object, + * which is a collection of different \e cubin and/or \e PTX files, all + * representing the same device code, but compiled and optimized for different + * architectures. + * + * Prior to CUDA 4.0, there was no documented API for constructing and using + * fat binary objects by programmers. Starting with CUDA 4.0, fat binary + * objects can be constructed by providing the -fatbin option to \b nvcc. + * More information can be found in the \b nvcc document. + * + * \param module - Returned module + * \param fatCubin - Fat binary to load + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_NOT_FOUND, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU, + * ::CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND + * \notefnerr + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleUnload + */ +CUresult CUDAAPI cuModuleLoadFatBinary(CUmodule *module, const void *fatCubin); + +/** + * \brief Unloads a module + * + * Unloads a module \p hmod from the current context. Attempting to unload + * a module which was obtained from the Library Management API such as + * ::cuLibraryGetModule will return ::CUDA_ERROR_NOT_PERMITTED. + * + * \param hmod - Module to unload + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_PERMITTED + * \notefnerr + * \note_destroy_ub + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary + */ +CUresult CUDAAPI cuModuleUnload(CUmodule hmod); + +/** + * CUDA Lazy Loading status + */ +typedef enum CUmoduleLoadingMode_enum { + CU_MODULE_EAGER_LOADING = 0x1, /**< Lazy Kernel Loading is not enabled */ + CU_MODULE_LAZY_LOADING = 0x2, /**< Lazy Kernel Loading is enabled */ +} CUmoduleLoadingMode; + +/** + * \brief Query lazy loading mode + * + * Returns lazy loading mode + * Module loading mode is controlled by CUDA_MODULE_LOADING env variable + * + * \param mode - Returns the lazy loading mode + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + * \sa + * ::cuModuleLoad, + */ +CUresult CUDAAPI cuModuleGetLoadingMode(CUmoduleLoadingMode *mode); + +/** + * \brief Returns a function handle + * + * Returns in \p *hfunc the handle of the function of name \p name located in + * module \p hmod. If no function of that name exists, ::cuModuleGetFunction() + * returns ::CUDA_ERROR_NOT_FOUND. + * + * \param hfunc - Returned function handle + * \param hmod - Module to retrieve function from + * \param name - Name of function to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_FOUND + * \notefnerr + * + * \sa ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload + */ +CUresult CUDAAPI cuModuleGetFunction(CUfunction *hfunc, CUmodule hmod, const char *name); + +/** + * \brief Returns the number of functions within a module + * + * Returns in \p count the number of functions in \p mod. + * + * \param count - Number of functions found within the module + * \param mod - Module to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + */ +CUresult CUDAAPI cuModuleGetFunctionCount(unsigned int *count, CUmodule mod); + +/** + * \brief Returns the function handles within a module. + * + * Returns in \p functions a maximum number of \p numFunctions function handles within \p mod. When + * function loading mode is set to LAZY the function retrieved may be partially loaded. The loading + * state of a function can be queried using ::cuFunctionIsLoaded. CUDA APIs may load the function + * automatically when called with partially loaded function handle which may incur additional + * latency. Alternatively, ::cuFunctionLoad can be used to explicitly load a function. The returned + * function handles become invalid when the module is unloaded. + * + * \param functions - Buffer where the function handles are returned to + * \param numFunctions - Maximum number of function handles may be returned to the buffer + * \param mod - Module to query from + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetFunctionCount, + * ::cuFuncIsLoaded, + * ::cuFuncLoad + */ +CUresult CUDAAPI cuModuleEnumerateFunctions(CUfunction *functions, unsigned int numFunctions, CUmodule mod); + +/** + * \brief Returns a global pointer from a module + * + * Returns in \p *dptr and \p *bytes the base pointer and size of the + * global of name \p name located in module \p hmod. If no variable of that name + * exists, ::cuModuleGetGlobal() returns ::CUDA_ERROR_NOT_FOUND. + * One of the parameters \p dptr or \p bytes (not both) can be NULL in which + * case it is ignored. + * + * \param dptr - Returned global device pointer + * \param bytes - Returned global size in bytes + * \param hmod - Module to retrieve global from + * \param name - Name of global to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_FOUND + * \notefnerr + * + * \sa ::cuModuleGetFunction, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload, + * ::cudaGetSymbolAddress, + * ::cudaGetSymbolSize + */ +CUresult CUDAAPI cuModuleGetGlobal(CUdeviceptr *dptr, size_t *bytes, CUmodule hmod, const char *name); + +/** + * \brief Creates a pending JIT linker invocation. + * + * If the call is successful, the caller owns the returned CUlinkState, which + * should eventually be destroyed with ::cuLinkDestroy. The + * device code machine size (32 or 64 bit) will match the calling application. + * + * Both linker and compiler options may be specified. Compiler options will + * be applied to inputs to this linker action which must be compiled from PTX. + * The options ::CU_JIT_WALL_TIME, + * ::CU_JIT_INFO_LOG_BUFFER_SIZE_BYTES, and ::CU_JIT_ERROR_LOG_BUFFER_SIZE_BYTES + * will accumulate data until the CUlinkState is destroyed. + * + * The data passed in via ::cuLinkAddData and ::cuLinkAddFile will be treated + * as relocatable (-rdc=true to nvcc) when linking the final cubin during + * ::cuLinkComplete and will have similar consequences as offline relocatable + * device code linking. + * + * \p optionValues must remain valid for the life of the CUlinkState if output + * options are used. No other references to inputs are maintained after this + * call returns. + * + * \note For LTO-IR input, only LTO-IR compiled with toolkits prior to CUDA 12.0 will be accepted + * + * \param numOptions Size of options arrays + * \param options Array of linker and compiler options + * \param optionValues Array of option values, each cast to void * + * \param stateOut On success, this will contain a CUlinkState to specify + * and complete this action + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND + * \notefnerr + * + * \sa ::cuLinkAddData, + * ::cuLinkAddFile, + * ::cuLinkComplete, + * ::cuLinkDestroy + */ +CUresult CUDAAPI +cuLinkCreate(unsigned int numOptions, CUjit_option *options, void **optionValues, CUlinkState *stateOut); + +/** + * \brief Add an input to a pending linker invocation + * + * Ownership of \p data is retained by the caller. No reference is retained to any + * inputs after this call returns. + * + * This method accepts only compiler options, which are used if the data must + * be compiled from PTX, and does not accept any of + * ::CU_JIT_WALL_TIME, ::CU_JIT_INFO_LOG_BUFFER, ::CU_JIT_ERROR_LOG_BUFFER, + * ::CU_JIT_TARGET_FROM_CUCONTEXT, or ::CU_JIT_TARGET. + * + * \note For LTO-IR input, only LTO-IR compiled with toolkits prior to CUDA 12.0 will be accepted + * + * \param state A pending linker action. + * \param type The type of the input data. + * \param data The input data. PTX must be NULL-terminated. + * \param size The length of the input data. + * \param name An optional name for this input in log messages. + * \param numOptions Size of options. + * \param options Options to be applied only for this input (overrides options from ::cuLinkCreate). + * \param optionValues Array of option values, each cast to void *. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_IMAGE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU + * + * \sa ::cuLinkCreate, + * ::cuLinkAddFile, + * ::cuLinkComplete, + * ::cuLinkDestroy + */ +CUresult CUDAAPI +cuLinkAddData(CUlinkState state, CUjitInputType type, void *data, size_t size, const char *name, + unsigned int numOptions, CUjit_option *options, void **optionValues); + +/** + * \brief Add a file input to a pending linker invocation + * + * No reference is retained to any inputs after this call returns. + * + * This method accepts only compiler options, which are used if the input + * must be compiled from PTX, and does not accept any of + * ::CU_JIT_WALL_TIME, ::CU_JIT_INFO_LOG_BUFFER, ::CU_JIT_ERROR_LOG_BUFFER, + * ::CU_JIT_TARGET_FROM_CUCONTEXT, or ::CU_JIT_TARGET. + * + * This method is equivalent to invoking ::cuLinkAddData on the contents + * of the file. + * + * \note For LTO-IR input, only LTO-IR compiled with toolkits prior to CUDA 12.0 will be accepted + * + * \param state A pending linker action + * \param type The type of the input data + * \param path Path to the input file + * \param numOptions Size of options + * \param options Options to be applied only for this input (overrides options from ::cuLinkCreate) + * \param optionValues Array of option values, each cast to void * + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_FILE_NOT_FOUND + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_IMAGE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU + * + * \sa ::cuLinkCreate, + * ::cuLinkAddData, + * ::cuLinkComplete, + * ::cuLinkDestroy + */ +CUresult CUDAAPI +cuLinkAddFile(CUlinkState state, CUjitInputType type, const char *path, + unsigned int numOptions, CUjit_option *options, void **optionValues); + +/** + * \brief Complete a pending linker invocation + * + * Completes the pending linker action and returns the cubin image for the linked + * device code, which can be used with ::cuModuleLoadData. The cubin is owned by + * \p state, so it should be loaded before \p state is destroyed via ::cuLinkDestroy. + * This call does not destroy \p state. + * + * \param state A pending linker invocation + * \param cubinOut On success, this will point to the output image + * \param sizeOut Optional parameter to receive the size of the generated image + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuLinkCreate, + * ::cuLinkAddData, + * ::cuLinkAddFile, + * ::cuLinkDestroy, + * ::cuModuleLoadData + */ +CUresult CUDAAPI +cuLinkComplete(CUlinkState state, void **cubinOut, size_t *sizeOut); + +/** + * \brief Destroys state for a JIT linker invocation. + * + * \param state State object for the linker invocation + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE + * + * \sa ::cuLinkCreate + */ +CUresult CUDAAPI +cuLinkDestroy(CUlinkState state); + +/** @} */ /* END CUDA_MODULE */ + +/** + * \defgroup CUDA_MODULE_DEPRECATED Module Management [DEPRECATED] + * + * ___MANBRIEF___ deprecated module management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the deprecated module management functions of the low-level + * CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns a handle to a texture reference + * + * \deprecated + * + * Returns in \p *pTexRef the handle of the texture reference of name \p name + * in the module \p hmod. If no texture reference of that name exists, + * ::cuModuleGetTexRef() returns ::CUDA_ERROR_NOT_FOUND. This texture reference + * handle should not be destroyed, since it will be destroyed when the module + * is unloaded. + * + * \param pTexRef - Returned texture reference + * \param hmod - Module to retrieve texture reference from + * \param name - Name of texture reference to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_FOUND + * \notefnerr + * + * \sa + * ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetSurfRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuModuleGetTexRef(CUtexref *pTexRef, CUmodule hmod, const char *name); + +/** + * \brief Returns a handle to a surface reference + * + * \deprecated + * + * Returns in \p *pSurfRef the handle of the surface reference of name \p name + * in the module \p hmod. If no surface reference of that name exists, + * ::cuModuleGetSurfRef() returns ::CUDA_ERROR_NOT_FOUND. + * + * \param pSurfRef - Returned surface reference + * \param hmod - Module to retrieve surface reference from + * \param name - Name of surface reference to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_FOUND + * \notefnerr + * + * \sa + * ::cuModuleGetFunction, + * ::cuModuleGetGlobal, + * ::cuModuleGetTexRef, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx, + * ::cuModuleLoadFatBinary, + * ::cuModuleUnload + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuModuleGetSurfRef(CUsurfref *pSurfRef, CUmodule hmod, const char *name); + +/** @} */ /* END CUDA_MODULE_DEPRECATED */ + +/** + * \defgroup CUDA_LIBRARY Library Management + * + * ___MANBRIEF___ library management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the library management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Load a library with specified code and options + * + * Takes a pointer \p code and loads the corresponding library \p library based on + * the application defined library loading mode: + * - If module loading is set to EAGER, via the environment variables described in "Module loading", + * \p library is loaded eagerly into all contexts at the time of the call and future contexts + * at the time of creation until the library is unloaded with ::cuLibraryUnload(). + * - If the environment variables are set to LAZY, \p library + * is not immediately loaded onto all existent contexts and will only be + * loaded when a function is needed for that context, such as a kernel launch. + * + * These environment variables are described in the CUDA programming guide under the + * "CUDA environment variables" section. + * + * The \p code may be a \e cubin or \e fatbin as output by \b nvcc, + * or a NULL-terminated \e PTX, either as output by \b nvcc or hand-written. + * A fatbin should also contain relocatable code when doing separate compilation. + * + * Options are passed as an array via \p jitOptions and any corresponding parameters are passed in + * \p jitOptionsValues. The number of total JIT options is supplied via \p numJitOptions. + * Any outputs will be returned via \p jitOptionsValues. + * + * Library load options are passed as an array via \p libraryOptions and any corresponding parameters are passed in + * \p libraryOptionValues. The number of total library load options is supplied via \p numLibraryOptions. + * + * \note If the library contains managed variables and no device in the system + * supports managed variables this call is expected to return ::CUDA_ERROR_NOT_SUPPORTED + * + * \param library - Returned library + * \param code - Code to load + * \param jitOptions - Options for JIT + * \param jitOptionsValues - Option values for JIT + * \param numJitOptions - Number of options + * \param libraryOptions - Options for loading + * \param libraryOptionValues - Option values for loading + * \param numLibraryOptions - Number of options for loading + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU, + * ::CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND, + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx + */ +CUresult CUDAAPI cuLibraryLoadData(CUlibrary *library, const void *code, + CUjit_option *jitOptions, void **jitOptionsValues, unsigned int numJitOptions, + CUlibraryOption *libraryOptions, void** libraryOptionValues, unsigned int numLibraryOptions); + +/** + * \brief Load a library with specified file and options + * + * Takes a pointer \p code and loads the corresponding library \p library based on + * the application defined library loading mode: + * - If module loading is set to EAGER, via the environment variables described in "Module loading", + * \p library is loaded eagerly into all contexts at the time of the call and future contexts + * at the time of creation until the library is unloaded with ::cuLibraryUnload(). + * - If the environment variables are set to LAZY, \p library + * is not immediately loaded onto all existent contexts and will only be + * loaded when a function is needed for that context, such as a kernel launch. + * + * These environment variables are described in the CUDA programming guide under the + * "CUDA environment variables" section. + * + * The file should be a \e cubin file as output by \b nvcc, or a \e PTX file either + * as output by \b nvcc or handwritten, or a \e fatbin file as output by \b nvcc. + * A fatbin should also contain relocatable code when doing separate compilation. + * + * Options are passed as an array via \p jitOptions and any corresponding parameters are + * passed in \p jitOptionsValues. The number of total options is supplied via \p numJitOptions. + * Any outputs will be returned via \p jitOptionsValues. + * + * Library load options are passed as an array via \p libraryOptions and any corresponding parameters are passed in + * \p libraryOptionValues. The number of total library load options is supplied via \p numLibraryOptions. + * + * \note If the library contains managed variables and no device in the system + * supports managed variables this call is expected to return ::CUDA_ERROR_NOT_SUPPORTED + * + * \param library - Returned library + * \param fileName - File to load from + * \param jitOptions - Options for JIT + * \param jitOptionsValues - Option values for JIT + * \param numJitOptions - Number of options + * \param libraryOptions - Options for loading + * \param libraryOptionValues - Option values for loading + * \param numLibraryOptions - Number of options for loading + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_PTX, + * ::CUDA_ERROR_UNSUPPORTED_PTX_VERSION, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NO_BINARY_FOR_GPU, + * ::CUDA_ERROR_SHARED_OBJECT_SYMBOL_NOT_FOUND, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_JIT_COMPILER_NOT_FOUND, + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryUnload, + * ::cuModuleLoad, + * ::cuModuleLoadData, + * ::cuModuleLoadDataEx + */ +CUresult CUDAAPI cuLibraryLoadFromFile(CUlibrary *library, const char *fileName, + CUjit_option *jitOptions, void **jitOptionsValues, unsigned int numJitOptions, + CUlibraryOption *libraryOptions, void **libraryOptionValues, unsigned int numLibraryOptions); + +/** + * \brief Unloads a library + * + * Unloads the library specified with \p library + * + * \param library - Library to unload + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuModuleUnload + */ +CUresult CUDAAPI cuLibraryUnload(CUlibrary library); + +/** + * \brief Returns a kernel handle + * + * Returns in \p pKernel the handle of the kernel with name \p name located in library \p library. + * If kernel handle is not found, the call returns ::CUDA_ERROR_NOT_FOUND. + * + * \param pKernel - Returned kernel handle + * \param library - Library to retrieve kernel from + * \param name - Name of kernel to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuKernelGetFunction, + * ::cuLibraryGetModule, + * ::cuModuleGetFunction + */ +CUresult CUDAAPI cuLibraryGetKernel(CUkernel *pKernel, CUlibrary library, const char *name); + +/** + * \brief Returns the number of kernels within a library + * + * Returns in \p count the number of kernels in \p lib. + * + * \param count - Number of kernels found within the library + * \param lib - Library to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + */ +CUresult CUDAAPI cuLibraryGetKernelCount(unsigned int *count, CUlibrary lib); + +/** + * \brief Retrieve the kernel handles within a library. + * + * Returns in \p kernels a maximum number of \p numKernels kernel handles within \p lib. + * The returned kernel handle becomes invalid when the library is unloaded. + * + * \param kernels - Buffer where the kernel handles are returned to + * \param numKernels - Maximum number of kernel handles may be returned to the buffer + * \param lib - Library to query from + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuLibraryGetKernelCount + */ +CUresult CUDAAPI cuLibraryEnumerateKernels(CUkernel *kernels, unsigned int numKernels, CUlibrary lib); + +/** + * \brief Returns a module handle + * + * Returns in \p pMod the module handle associated with the current context located in + * library \p library. If module handle is not found, the call returns ::CUDA_ERROR_NOT_FOUND. + * + * \param pMod - Returned module handle + * \param library - Library to retrieve module from + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuModuleGetFunction + */ +CUresult CUDAAPI cuLibraryGetModule(CUmodule *pMod, CUlibrary library); + +/** + * \brief Returns a function handle + * + * Returns in \p pFunc the handle of the function for the requested kernel \p kernel and + * the current context. If function handle is not found, the call returns ::CUDA_ERROR_NOT_FOUND. + * + * \param pFunc - Returned function handle + * \param kernel - Kernel to retrieve function for the requested context + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuLibraryGetKernel, + * ::cuLibraryGetModule, + * ::cuModuleGetFunction + */ +CUresult CUDAAPI cuKernelGetFunction(CUfunction *pFunc, CUkernel kernel); + +/** + * \brief Returns a library handle + * + * Returns in \p pLib the handle of the library for the requested kernel \p kernel + * + * \param pLib - Returned library handle + * \param kernel - Kernel to retrieve library handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuLibraryGetKernel + */ +CUresult CUDAAPI cuKernelGetLibrary(CUlibrary *pLib, CUkernel kernel); + +/** + * \brief Returns a global device pointer + * + * Returns in \p *dptr and \p *bytes the base pointer and size of the global with + * name \p name for the requested library \p library and the current context. + * If no global for the requested name \p name exists, the call returns ::CUDA_ERROR_NOT_FOUND. + * One of the parameters \p dptr or \p bytes (not both) can be NULL in which + * case it is ignored. + * + * \param dptr - Returned global device pointer for the requested context + * \param bytes - Returned global size in bytes + * \param library - Library to retrieve global from + * \param name - Name of global to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuLibraryGetModule, + * cuModuleGetGlobal + */ +CUresult CUDAAPI cuLibraryGetGlobal(CUdeviceptr *dptr, size_t *bytes, CUlibrary library, const char *name); + +/** + * \brief Returns a pointer to managed memory + * + * Returns in \p *dptr and \p *bytes the base pointer and size of the managed memory with + * name \p name for the requested library \p library. If no managed memory with the + * requested name \p name exists, the call returns ::CUDA_ERROR_NOT_FOUND. One of the parameters + * \p dptr or \p bytes (not both) can be NULL in which case it is ignored. + * Note that managed memory for library \p library is shared across devices and is registered + * when the library is loaded into atleast one context. + * + * \param dptr - Returned pointer to the managed memory + * \param bytes - Returned memory size in bytes + * \param library - Library to retrieve managed memory from + * \param name - Name of managed memory to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload + */ +CUresult CUDAAPI cuLibraryGetManaged(CUdeviceptr *dptr, size_t *bytes, CUlibrary library, const char *name); + +/** + * \brief Returns a pointer to a unified function + * + * Returns in \p *fptr the function pointer to a unified function denoted by \p symbol. + * If no unified function with name \p symbol exists, the call returns ::CUDA_ERROR_NOT_FOUND. + * If there is no device with attribute ::CU_DEVICE_ATTRIBUTE_UNIFIED_FUNCTION_POINTERS present in the system, + * the call may return ::CUDA_ERROR_NOT_FOUND. + * + * \param fptr - Returned pointer to a unified function + * \param library - Library to retrieve function pointer memory from + * \param symbol - Name of function pointer to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_FOUND + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload + */ +CUresult CUDAAPI cuLibraryGetUnifiedFunction(void **fptr, CUlibrary library, const char *symbol); + +/** + * \brief Returns information about a kernel + * + * Returns in \p *pi the integer value of the attribute \p attrib for the kernel + * \p kernel for the requested device \p dev. The supported attributes are: + * - ::CU_FUNC_ATTRIBUTE_MAX_THREADS_PER_BLOCK: The maximum number of threads + * per block, beyond which a launch of the kernel would fail. This number + * depends on both the kernel and the requested device. + * - ::CU_FUNC_ATTRIBUTE_SHARED_SIZE_BYTES: The size in bytes of + * statically-allocated shared memory per block required by this kernel. + * This does not include dynamically-allocated shared memory requested by + * the user at runtime. + * - ::CU_FUNC_ATTRIBUTE_CONST_SIZE_BYTES: The size in bytes of user-allocated + * constant memory required by this kernel. + * - ::CU_FUNC_ATTRIBUTE_LOCAL_SIZE_BYTES: The size in bytes of local memory + * used by each thread of this kernel. + * - ::CU_FUNC_ATTRIBUTE_NUM_REGS: The number of registers used by each thread + * of this kernel. + * - ::CU_FUNC_ATTRIBUTE_PTX_VERSION: The PTX virtual architecture version for + * which the kernel was compiled. This value is the major PTX version * 10 + * + the minor PTX version, so a PTX version 1.3 function would return the + * value 13. Note that this may return the undefined value of 0 for cubins + * compiled prior to CUDA 3.0. + * - ::CU_FUNC_ATTRIBUTE_BINARY_VERSION: The binary architecture version for + * which the kernel was compiled. This value is the major binary + * version * 10 + the minor binary version, so a binary version 1.3 function + * would return the value 13. Note that this will return a value of 10 for + * legacy cubins that do not have a properly-encoded binary architecture + * version. + * - ::CU_FUNC_CACHE_MODE_CA: The attribute to indicate whether the kernel has + * been compiled with user specified option "-Xptxas --dlcm=ca" set. + * - ::CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES: The maximum size in bytes of + * dynamically-allocated shared memory. + * - ::CU_FUNC_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT: Preferred shared memory-L1 + * cache split ratio in percent of total shared memory. + * - ::CU_FUNC_ATTRIBUTE_CLUSTER_SIZE_MUST_BE_SET: If this attribute is set, the + * kernel must launch with a valid cluster size specified. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_WIDTH: The required cluster width in + * blocks. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_HEIGHT: The required cluster height in + * blocks. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_DEPTH: The required cluster depth in + * blocks. + * - ::CU_FUNC_ATTRIBUTE_NON_PORTABLE_CLUSTER_SIZE_ALLOWED: Indicates whether + * the function can be launched with non-portable cluster size. 1 is allowed, + * 0 is disallowed. A non-portable cluster size may only function on the + * specific SKUs the program is tested on. The launch might fail if the + * program is run on a different hardware platform. CUDA API provides + * cudaOccupancyMaxActiveClusters to assist with checking whether the desired + * size can be launched on the current device. A portable cluster size is + * guaranteed to be functional on all compute capabilities higher than the + * target compute capability. The portable cluster size for sm_90 is 8 blocks + * per cluster. This value may increase for future compute capabilities. The + * specific hardware unit may support higher cluster sizes that’s not + * guaranteed to be portable. + * - ::CU_FUNC_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE: The block + * scheduling policy of a function. The value type is CUclusterSchedulingPolicy. + * + * \note If another thread is trying to set the same attribute on the same device using + * ::cuKernelSetAttribute() simultaneously, the attribute query will give the old or new + * value depending on the interleavings chosen by the OS scheduler and memory consistency. + * + * \param pi - Returned attribute value + * \param attrib - Attribute requested + * \param kernel - Kernel to query attribute of + * \param dev - Device to query attribute of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuKernelSetAttribute, + * ::cuLibraryGetKernel, + * ::cuLaunchKernel, + * ::cuKernelGetFunction, + * ::cuLibraryGetModule, + * ::cuModuleGetFunction, + * ::cuFuncGetAttribute + */ +CUresult CUDAAPI cuKernelGetAttribute(int *pi, CUfunction_attribute attrib, CUkernel kernel, CUdevice dev); + +/** + * \brief Sets information about a kernel + * + * This call sets the value of a specified attribute \p attrib on the kernel \p kernel + * for the requested device \p dev to an integer value specified by \p val. + * This function returns CUDA_SUCCESS if the new value of the attribute could be + * successfully set. If the set fails, this call will return an error. + * Not all attributes can have values set. Attempting to set a value on a read-only + * attribute will result in an error (CUDA_ERROR_INVALID_VALUE) + * + * Note that attributes set using ::cuFuncSetAttribute() will override the attribute + * set by this API irrespective of whether the call to ::cuFuncSetAttribute() is made + * before or after this API call. However, ::cuKernelGetAttribute() will always + * return the attribute value set by this API. + * + * Supported attributes are: + * - ::CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES: This is the maximum size in bytes of + * dynamically-allocated shared memory. The value should contain the requested + * maximum size of dynamically-allocated shared memory. The sum of this value and + * the function attribute ::CU_FUNC_ATTRIBUTE_SHARED_SIZE_BYTES cannot exceed the + * device attribute ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK_OPTIN. + * The maximal size of requestable dynamic shared memory may differ by GPU + * architecture. + * - ::CU_FUNC_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT: On devices where the L1 + * cache and shared memory use the same hardware resources, this sets the shared memory + * carveout preference, in percent of the total shared memory. + * See ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_MULTIPROCESSOR + * This is only a hint, and the driver can choose a different ratio if required to execute the function. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_WIDTH: The required cluster width in + * blocks. The width, height, and depth values must either all be 0 or all be + * positive. The validity of the cluster dimensions is checked at launch time. + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_HEIGHT: The required cluster height in + * blocks. The width, height, and depth values must either all be 0 or all be + * positive. The validity of the cluster dimensions is checked at launch time. + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_DEPTH: The required cluster depth in + * blocks. The width, height, and depth values must either all be 0 or all be + * positive. The validity of the cluster dimensions is checked at launch time. + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * - ::CU_FUNC_ATTRIBUTE_NON_PORTABLE_CLUSTER_SIZE_ALLOWED: Indicates whether + * the function can be launched with non-portable cluster size. 1 is allowed, + * 0 is disallowed. + * - ::CU_FUNC_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE: The block + * scheduling policy of a function. The value type is CUclusterSchedulingPolicy. + * + * \note The API has stricter locking requirements in comparison to its legacy counterpart + * ::cuFuncSetAttribute() due to device-wide semantics. If multiple threads are trying to + * set the same attribute on the same device simultaneously, the attribute setting will depend + * on the interleavings chosen by the OS scheduler and memory consistency. + * + * \param attrib - Attribute requested + * \param val - Value to set + * \param kernel - Kernel to set attribute of + * \param dev - Device to set attribute of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuKernelGetAttribute, + * ::cuLibraryGetKernel, + * ::cuLaunchKernel, + * ::cuKernelGetFunction, + * ::cuLibraryGetModule, + * ::cuModuleGetFunction, + * ::cuFuncSetAttribute + */ +CUresult CUDAAPI cuKernelSetAttribute(CUfunction_attribute attrib, int val, CUkernel kernel, CUdevice dev); + +/** + * \brief Sets the preferred cache configuration for a device kernel. + * + * On devices where the L1 cache and shared memory use the same hardware + * resources, this sets through \p config the preferred cache configuration for + * the device kernel \p kernel on the requested device \p dev. This is only a preference. + * The driver will use the requested configuration if possible, but it is free to choose a different + * configuration if required to execute \p kernel. Any context-wide preference + * set via ::cuCtxSetCacheConfig() will be overridden by this per-kernel + * setting. + * + * Note that attributes set using ::cuFuncSetCacheConfig() will override the attribute + * set by this API irrespective of whether the call to ::cuFuncSetCacheConfig() is made + * before or after this API call. + * + * This setting does nothing on devices where the size of the L1 cache and + * shared memory are fixed. + * + * Launching a kernel with a different preference than the most recent + * preference setting may insert a device-side synchronization point. + * + * + * The supported cache configurations are: + * - ::CU_FUNC_CACHE_PREFER_NONE: no preference for shared memory or L1 (default) + * - ::CU_FUNC_CACHE_PREFER_SHARED: prefer larger shared memory and smaller L1 cache + * - ::CU_FUNC_CACHE_PREFER_L1: prefer larger L1 cache and smaller shared memory + * - ::CU_FUNC_CACHE_PREFER_EQUAL: prefer equal sized L1 cache and shared memory + * + * \note The API has stricter locking requirements in comparison to its legacy counterpart + * ::cuFuncSetCacheConfig() due to device-wide semantics. If multiple threads are trying to + * set a config on the same device simultaneously, the cache config setting will depend + * on the interleavings chosen by the OS scheduler and memory consistency. + * + * \param kernel - Kernel to configure cache for + * \param config - Requested cache configuration + * \param dev - Device to set attribute of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuLibraryLoadData, + * ::cuLibraryLoadFromFile, + * ::cuLibraryUnload, + * ::cuLibraryGetKernel, + * ::cuKernelGetFunction, + * ::cuLibraryGetModule, + * ::cuModuleGetFunction, + * ::cuFuncSetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuLaunchKernel + */ +CUresult CUDAAPI cuKernelSetCacheConfig(CUkernel kernel, CUfunc_cache config, CUdevice dev); + +/** + * \brief Returns the function name for a ::CUkernel handle + * + * Returns in \p **name the function name associated with the kernel handle \p hfunc . + * The function name is returned as a null-terminated string. The returned name is only + * valid when the kernel handle is valid. If the library is unloaded or reloaded, one + * must call the API again to get the updated name. This API may return a mangled name if + * the function is not declared as having C linkage. If either \p **name or \p hfunc + * is NULL, ::CUDA_ERROR_INVALID_VALUE is returned. + * + * \param name - The returned name of the function + * \param hfunc - The function handle to retrieve the name for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + */ +CUresult CUDAAPI cuKernelGetName(const char **name, CUkernel hfunc); + +/** + * \brief Returns the offset and size of a kernel parameter in the device-side parameter layout + * + * Queries the kernel parameter at \p paramIndex into \p kernel's list of parameters, and returns + * in \p paramOffset and \p paramSize the offset and size, respectively, where the parameter + * will reside in the device-side parameter layout. This information can be used to update kernel + * node parameters from the device via ::cudaGraphKernelNodeSetParam() and + * ::cudaGraphKernelNodeUpdatesApply(). \p paramIndex must be less than the number of parameters + * that \p kernel takes. \p paramSize can be set to NULL if only the parameter offset is desired. + * + * \param kernel - The kernel to query + * \param paramIndex - The parameter index to query + * \param paramOffset - Returns the offset into the device-side parameter layout at which the parameter resides + * \param paramSize - Optionally returns the size of the parameter in the device-side parameter layout + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * +* \sa ::cuFuncGetParamInfo + */ +CUresult CUDAAPI cuKernelGetParamInfo(CUkernel kernel, size_t paramIndex, size_t *paramOffset, size_t *paramSize); +/** @} */ /* END CUDA_LIBRARY */ + +/** + * \defgroup CUDA_MEM Memory Management + * + * ___MANBRIEF___ memory management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the memory management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Gets free and total memory + * + * Returns in \p *total the total amount of memory available to the the current context. + * Returns in \p *free the amount of memory on the device that is free according to the OS. + * CUDA is not guaranteed to be able to allocate all of the memory that the OS reports as free. + * In a multi-tenet situation, free estimate returned is prone to race condition where + * a new allocation/free done by a different process or a different thread in the same + * process between the time when free memory was estimated and reported, will result in + * deviation in free value reported and actual free memory. + * + * The integrated GPU on Tegra shares memory with CPU and other component + * of the SoC. The free and total values returned by the API excludes + * the SWAP memory space maintained by the OS on some platforms. + * The OS may move some of the memory pages into swap area as the GPU or + * CPU allocate or access memory. See Tegra app note on how to calculate + * total and free memory on Tegra. + * + * \param free - Returned free memory in bytes + * \param total - Returned total memory in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemGetInfo + */ +CUresult CUDAAPI cuMemGetInfo(size_t *free, size_t *total); + +/** + * \brief Allocates device memory + * + * Allocates \p bytesize bytes of linear memory on the device and returns in + * \p *dptr a pointer to the allocated memory. The allocated memory is suitably + * aligned for any kind of variable. The memory is not cleared. If \p bytesize + * is 0, ::cuMemAlloc() returns ::CUDA_ERROR_INVALID_VALUE. + * + * \param dptr - Returned device pointer + * \param bytesize - Requested allocation size in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMalloc + */ +CUresult CUDAAPI cuMemAlloc(CUdeviceptr *dptr, size_t bytesize); + +/** + * \brief Allocates pitched device memory + * + * Allocates at least \p WidthInBytes * \p Height bytes of linear memory on + * the device and returns in \p *dptr a pointer to the allocated memory. The + * function may pad the allocation to ensure that corresponding pointers in + * any given row will continue to meet the alignment requirements for + * coalescing as the address is updated from row to row. \p ElementSizeBytes + * specifies the size of the largest reads and writes that will be performed + * on the memory range. \p ElementSizeBytes may be 4, 8 or 16 (since coalesced + * memory transactions are not possible on other data sizes). If + * \p ElementSizeBytes is smaller than the actual read/write size of a kernel, + * the kernel will run correctly, but possibly at reduced speed. The pitch + * returned in \p *pPitch by ::cuMemAllocPitch() is the width in bytes of the + * allocation. The intended usage of pitch is as a separate parameter of the + * allocation, used to compute addresses within the 2D array. Given the row + * and column of an array element of type \b T, the address is computed as: + * \code + T* pElement = (T*)((char*)BaseAddress + Row * Pitch) + Column; + * \endcode + * + * The pitch returned by ::cuMemAllocPitch() is guaranteed to work with + * ::cuMemcpy2D() under all circumstances. For allocations of 2D arrays, it is + * recommended that programmers consider performing pitch allocations using + * ::cuMemAllocPitch(). Due to alignment restrictions in the hardware, this is + * especially true if the application will be performing 2D memory copies + * between different regions of device memory (whether linear memory or CUDA + * arrays). + * + * The byte alignment of the pitch returned by ::cuMemAllocPitch() is guaranteed + * to match or exceed the alignment requirement for texture binding with + * ::cuTexRefSetAddress2D(). + * + * \param dptr - Returned device pointer + * \param pPitch - Returned pitch of allocation in bytes + * \param WidthInBytes - Requested allocation width in bytes + * \param Height - Requested allocation height in rows + * \param ElementSizeBytes - Size of largest reads/writes for range + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMallocPitch + */ +CUresult CUDAAPI cuMemAllocPitch(CUdeviceptr *dptr, size_t *pPitch, size_t WidthInBytes, size_t Height, unsigned int ElementSizeBytes); + +/** + * \brief Frees device memory + * + * Frees the memory space pointed to by \p dptr, which must have been returned + * by a previous call to one of the following memory allocation APIs - ::cuMemAlloc(), + * ::cuMemAllocPitch(), ::cuMemAllocManaged(), ::cuMemAllocAsync(), ::cuMemAllocFromPoolAsync() + * + * Note - This API will not perform any implict synchronization when the pointer was allocated with + * ::cuMemAllocAsync or ::cuMemAllocFromPoolAsync. Callers must ensure that all accesses to these + * pointer have completed before invoking ::cuMemFree. For best performance and memory reuse, users + * should use ::cuMemFreeAsync to free memory allocated via the stream ordered memory allocator. + * For all other pointers, this API may perform implicit synchronization. + * + * \param dptr - Pointer to memory to free + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemAllocManaged, ::cuMemAllocAsync, ::cuMemAllocFromPoolAsync, + * ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, ::cuMemcpy3D, ::cuMemcpy3DAsync, + * ::cuMemcpyAtoA, ::cuMemcpyAtoD, ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, + * ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, + * ::cuMemcpyHtoAAsync, ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, ::cuMemFreeAsync, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaFree + */ +CUresult CUDAAPI cuMemFree(CUdeviceptr dptr); + +/** + * \brief Get information on memory allocations + * + * Returns the base address in \p *pbase and size in \p *psize of the + * allocation by ::cuMemAlloc() or ::cuMemAllocPitch() that contains the input + * pointer \p dptr. Both parameters \p pbase and \p psize are optional. If one + * of them is NULL, it is ignored. + * + * \param pbase - Returned base address + * \param psize - Returned size of device memory allocation + * \param dptr - Device pointer to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_NOT_FOUND, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32 + */ +CUresult CUDAAPI cuMemGetAddressRange(CUdeviceptr *pbase, size_t *psize, CUdeviceptr dptr); + +/** + * \brief Allocates page-locked host memory + * + * Allocates \p bytesize bytes of host memory that is page-locked and + * accessible to the device. The driver tracks the virtual memory ranges + * allocated with this function and automatically accelerates calls to + * functions such as ::cuMemcpy(). Since the memory can be accessed directly by + * the device, it can be read or written with much higher bandwidth than + * pageable memory obtained with functions such as ::malloc(). + * + * On systems where ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES + * is true, ::cuMemAllocHost may not page-lock the allocated memory. + * + * Page-locking excessive amounts of memory with ::cuMemAllocHost() may degrade system + * performance, since it reduces the amount of memory available to the system + * for paging. As a result, this function is best used sparingly to allocate + * staging areas for data exchange between host and device. + * + * Note all host memory allocated using ::cuMemAllocHost() will automatically + * be immediately accessible to all contexts on all devices which support unified + * addressing (as may be queried using ::CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING). + * The device pointer that may be used to access this host memory from those + * contexts is always equal to the returned host pointer \p *pp. + * See \ref CUDA_UNIFIED for additional details. + * + * \param pp - Returned pointer to host memory + * \param bytesize - Requested allocation size in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMallocHost + */ +CUresult CUDAAPI cuMemAllocHost(void **pp, size_t bytesize); + +/** + * \brief Frees page-locked host memory + * + * Frees the memory space pointed to by \p p, which must have been returned by + * a previous call to ::cuMemAllocHost(). + * + * \param p - Pointer to memory to free + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaFreeHost + */ +CUresult CUDAAPI cuMemFreeHost(void *p); + +/** + * \brief Allocates page-locked host memory + * + * Allocates \p bytesize bytes of host memory that is page-locked and accessible + * to the device. The driver tracks the virtual memory ranges allocated with + * this function and automatically accelerates calls to functions such as + * ::cuMemcpyHtoD(). Since the memory can be accessed directly by the device, + * it can be read or written with much higher bandwidth than pageable memory + * obtained with functions such as ::malloc(). + * + * On systems where ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES + * is true, ::cuMemHostAlloc may not page-lock the allocated memory. + * + * Page-locking excessive amounts of memory may degrade system performance, + * since it reduces the amount of memory available to the system for paging. + * As a result, this function is best used sparingly to allocate staging areas + * for data exchange between host and device. + * + * The \p Flags parameter enables different options to be specified that + * affect the allocation, as follows. + * + * - ::CU_MEMHOSTALLOC_PORTABLE: The memory returned by this call will be + * considered as pinned memory by all CUDA contexts, not just the one that + * performed the allocation. + * + * - ::CU_MEMHOSTALLOC_DEVICEMAP: Maps the allocation into the CUDA address + * space. The device pointer to the memory may be obtained by calling + * ::cuMemHostGetDevicePointer(). + * + * - ::CU_MEMHOSTALLOC_WRITECOMBINED: Allocates the memory as write-combined + * (WC). WC memory can be transferred across the PCI Express bus more + * quickly on some system configurations, but cannot be read efficiently by + * most CPUs. WC memory is a good option for buffers that will be written by + * the CPU and read by the GPU via mapped pinned memory or host->device + * transfers. + * + * All of these flags are orthogonal to one another: a developer may allocate + * memory that is portable, mapped and/or write-combined with no restrictions. + * + * The ::CU_MEMHOSTALLOC_DEVICEMAP flag may be specified on CUDA contexts for + * devices that do not support mapped pinned memory. The failure is deferred + * to ::cuMemHostGetDevicePointer() because the memory may be mapped into + * other CUDA contexts via the ::CU_MEMHOSTALLOC_PORTABLE flag. + * + * The memory allocated by this function must be freed with ::cuMemFreeHost(). + * + * Note all host memory allocated using ::cuMemHostAlloc() will automatically + * be immediately accessible to all contexts on all devices which support unified + * addressing (as may be queried using ::CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING). + * Unless the flag ::CU_MEMHOSTALLOC_WRITECOMBINED is specified, the device pointer + * that may be used to access this host memory from those contexts is always equal + * to the returned host pointer \p *pp. If the flag ::CU_MEMHOSTALLOC_WRITECOMBINED + * is specified, then the function ::cuMemHostGetDevicePointer() must be used + * to query the device pointer, even if the context supports unified addressing. + * See \ref CUDA_UNIFIED for additional details. + * + * \param pp - Returned pointer to host memory + * \param bytesize - Requested allocation size in bytes + * \param Flags - Flags for allocation request + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaHostAlloc + */ +CUresult CUDAAPI cuMemHostAlloc(void **pp, size_t bytesize, unsigned int Flags); + +/** + * \brief Passes back device pointer of mapped pinned memory + * + * Passes back the device pointer \p pdptr corresponding to the mapped, pinned + * host buffer \p p allocated by ::cuMemHostAlloc. + * + * ::cuMemHostGetDevicePointer() will fail if the ::CU_MEMHOSTALLOC_DEVICEMAP + * flag was not specified at the time the memory was allocated, or if the + * function is called on a GPU that does not support mapped pinned memory. + * + * For devices that have a non-zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_HOST_POINTER_FOR_REGISTERED_MEM, the memory + * can also be accessed from the device using the host pointer \p p. + * The device pointer returned by ::cuMemHostGetDevicePointer() may or may not + * match the original host pointer \p p and depends on the devices visible to the + * application. If all devices visible to the application have a non-zero value for the + * device attribute, the device pointer returned by ::cuMemHostGetDevicePointer() + * will match the original pointer \p p. If any device visible to the application + * has a zero value for the device attribute, the device pointer returned by + * ::cuMemHostGetDevicePointer() will not match the original host pointer \p p, + * but it will be suitable for use on all devices provided Unified Virtual Addressing + * is enabled. In such systems, it is valid to access the memory using either pointer + * on devices that have a non-zero value for the device attribute. Note however that + * such devices should access the memory using only one of the two pointers and not both. + * + * \p Flags provides for future releases. For now, it must be set to 0. + * + * \param pdptr - Returned device pointer + * \param p - Host pointer + * \param Flags - Options (must be 0) + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaHostGetDevicePointer + */ +CUresult CUDAAPI cuMemHostGetDevicePointer(CUdeviceptr *pdptr, void *p, unsigned int Flags); + +/** + * \brief Passes back flags that were used for a pinned allocation + * + * Passes back the flags \p pFlags that were specified when allocating + * the pinned host buffer \p p allocated by ::cuMemHostAlloc. + * + * ::cuMemHostGetFlags() will fail if the pointer does not reside in + * an allocation performed by ::cuMemAllocHost() or ::cuMemHostAlloc(). + * + * \param pFlags - Returned flags word + * \param p - Host pointer + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuMemAllocHost, + * ::cuMemHostAlloc, + * ::cudaHostGetFlags + */ +CUresult CUDAAPI cuMemHostGetFlags(unsigned int *pFlags, void *p); + +/** + * \brief Allocates memory that will be automatically managed by the Unified Memory system + * + * Allocates \p bytesize bytes of managed memory on the device and returns in + * \p *dptr a pointer to the allocated memory. If the device doesn't support + * allocating managed memory, ::CUDA_ERROR_NOT_SUPPORTED is returned. Support + * for managed memory can be queried using the device attribute + * ::CU_DEVICE_ATTRIBUTE_MANAGED_MEMORY. The allocated memory is suitably + * aligned for any kind of variable. The memory is not cleared. If \p bytesize + * is 0, ::cuMemAllocManaged returns ::CUDA_ERROR_INVALID_VALUE. The pointer + * is valid on the CPU and on all GPUs in the system that support managed memory. + * All accesses to this pointer must obey the Unified Memory programming model. + * + * \p flags specifies the default stream association for this allocation. + * \p flags must be one of ::CU_MEM_ATTACH_GLOBAL or ::CU_MEM_ATTACH_HOST. If + * ::CU_MEM_ATTACH_GLOBAL is specified, then this memory is accessible from + * any stream on any device. If ::CU_MEM_ATTACH_HOST is specified, then the + * allocation should not be accessed from devices that have a zero value for the + * device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS; an explicit call to + * ::cuStreamAttachMemAsync will be required to enable access on such devices. + * + * If the association is later changed via ::cuStreamAttachMemAsync to + * a single stream, the default association as specified during ::cuMemAllocManaged + * is restored when that stream is destroyed. For __managed__ variables, the + * default association is always ::CU_MEM_ATTACH_GLOBAL. Note that destroying a + * stream is an asynchronous operation, and as a result, the change to default + * association won't happen until all work in the stream has completed. + * + * Memory allocated with ::cuMemAllocManaged should be released with ::cuMemFree. + * + * Device memory oversubscription is possible for GPUs that have a non-zero value for the + * device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. Managed memory on + * such GPUs may be evicted from device memory to host memory at any time by the Unified + * Memory driver in order to make room for other allocations. + * + * In a system where all GPUs have a non-zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS, managed memory may not be populated when this + * API returns and instead may be populated on access. In such systems, managed memory can + * migrate to any processor's memory at any time. The Unified Memory driver will employ heuristics to + * maintain data locality and prevent excessive page faults to the extent possible. The application + * can also guide the driver about memory usage patterns via ::cuMemAdvise. The application + * can also explicitly migrate memory to a desired processor's memory via + * ::cuMemPrefetchAsync. + * + * In a multi-GPU system where all of the GPUs have a zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS and all the GPUs have peer-to-peer support + * with each other, the physical storage for managed memory is created on the GPU which is active + * at the time ::cuMemAllocManaged is called. All other GPUs will reference the data at reduced + * bandwidth via peer mappings over the PCIe bus. The Unified Memory driver does not migrate + * memory among such GPUs. + * + * In a multi-GPU system where not all GPUs have peer-to-peer support with each other and + * where the value of the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS + * is zero for at least one of those GPUs, the location chosen for physical storage of managed + * memory is system-dependent. + * - On Linux, the location chosen will be device memory as long as the current set of active + * contexts are on devices that either have peer-to-peer support with each other or have a + * non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * If there is an active context on a GPU that does not have a non-zero value for that device + * attribute and it does not have peer-to-peer support with the other devices that have active + * contexts on them, then the location for physical storage will be 'zero-copy' or host memory. + * Note that this means that managed memory that is located in device memory is migrated to + * host memory if a new context is created on a GPU that doesn't have a non-zero value for + * the device attribute and does not support peer-to-peer with at least one of the other devices + * that has an active context. This in turn implies that context creation may fail if there is + * insufficient host memory to migrate all managed allocations. + * - On Windows, the physical storage is always created in 'zero-copy' or host memory. + * All GPUs will reference the data at reduced bandwidth over the PCIe bus. In these + * circumstances, use of the environment variable CUDA_VISIBLE_DEVICES is recommended to + * restrict CUDA to only use those GPUs that have peer-to-peer support. + * Alternatively, users can also set CUDA_MANAGED_FORCE_DEVICE_ALLOC to a + * non-zero value to force the driver to always use device memory for physical storage. + * When this environment variable is set to a non-zero value, all contexts created in + * that process on devices that support managed memory have to be peer-to-peer compatible + * with each other. Context creation will fail if a context is created on a device that + * supports managed memory and is not peer-to-peer compatible with any of the other + * managed memory supporting devices on which contexts were previously created, even if + * those contexts have been destroyed. These environment variables are described + * in the CUDA programming guide under the "CUDA environment variables" section. + * - On ARM, managed memory is not available on discrete gpu with Drive PX-2. + * + * \param dptr - Returned device pointer + * \param bytesize - Requested allocation size in bytes + * \param flags - Must be one of ::CU_MEM_ATTACH_GLOBAL or ::CU_MEM_ATTACH_HOST + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cuDeviceGetAttribute, ::cuStreamAttachMemAsync, + * ::cudaMallocManaged + */ +CUresult CUDAAPI cuMemAllocManaged(CUdeviceptr *dptr, size_t bytesize, unsigned int flags); + +/** +* \brief Registers a callback function to receive async notifications +* +* Registers \p callbackFunc to receive async notifications. +* +* The \p userData parameter is passed to the callback function at async notification time. +* Likewise, \p callback is also passed to the callback function to distinguish between +* multiple registered callbacks. +* +* The callback function being registered should be designed to return quickly (~10ms). +* Any long running tasks should be queued for execution on an application thread. +* +* Callbacks may not call cuDeviceRegisterAsyncNotification or cuDeviceUnregisterAsyncNotification. +* Doing so will result in ::CUDA_ERROR_NOT_PERMITTED. Async notification callbacks execute +* in an undefined order and may be serialized. +* +* Returns in \p *callback a handle representing the registered callback instance. +* +* \param device - The device on which to register the callback +* \param callbackFunc - The function to register as a callback +* \param userData - A generic pointer to user data. This is passed into the callback function. +* \param callback - A handle representing the registered callback instance +* +* \return +* ::CUDA_SUCCESS +* ::CUDA_ERROR_NOT_SUPPORTED +* ::CUDA_ERROR_INVALID_DEVICE +* ::CUDA_ERROR_INVALID_VALUE +* ::CUDA_ERROR_NOT_PERMITTED +* ::CUDA_ERROR_UNKNOWN +* \notefnerr +* +* \sa +* ::cuDeviceUnregisterAsyncNotification +*/ +CUresult CUDAAPI cuDeviceRegisterAsyncNotification(CUdevice device, CUasyncCallback callbackFunc, void *userData, CUasyncCallbackHandle *callback); + +/** +* \brief Unregisters an async notification callback +* +* Unregisters \p callback so that the corresponding callback function will stop receiving +* async notifications. +* +* \param device - The device from which to remove \p callback. +* \param callback - The callback instance to unregister from receiving async notifications. +* +* \return +* ::CUDA_SUCCESS +* ::CUDA_ERROR_NOT_SUPPORTED +* ::CUDA_ERROR_INVALID_DEVICE +* ::CUDA_ERROR_INVALID_VALUE +* ::CUDA_ERROR_NOT_PERMITTED +* ::CUDA_ERROR_UNKNOWN +* \notefnerr +* +* \sa +* ::cuDeviceRegisterAsyncNotification +*/ +CUresult CUDAAPI cuDeviceUnregisterAsyncNotification(CUdevice device, CUasyncCallbackHandle callback); + +/** + * \brief Returns a handle to a compute device + * + * Returns in \p *device a device handle given a PCI bus ID string. + * + * \param dev - Returned device handle + * + * \param pciBusId - String in one of the following forms: + * [domain]:[bus]:[device].[function] + * [domain]:[bus]:[device] + * [bus]:[device].[function] + * where \p domain, \p bus, \p device, and \p function are all hexadecimal values + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGet, + * ::cuDeviceGetAttribute, + * ::cuDeviceGetPCIBusId, + * ::cudaDeviceGetByPCIBusId + */ +CUresult CUDAAPI cuDeviceGetByPCIBusId(CUdevice *dev, const char *pciBusId); + +/** + * \brief Returns a PCI Bus Id string for the device + * + * Returns an ASCII string identifying the device \p dev in the NULL-terminated + * string pointed to by \p pciBusId. \p len specifies the maximum length of the + * string that may be returned. + * + * \param pciBusId - Returned identifier string for the device in the following format + * [domain]:[bus]:[device].[function] + * where \p domain, \p bus, \p device, and \p function are all hexadecimal values. + * pciBusId should be large enough to store 13 characters including the NULL-terminator. + * + * \param len - Maximum length of string to store in \p name + * + * \param dev - Device to get identifier string for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuDeviceGet, + * ::cuDeviceGetAttribute, + * ::cuDeviceGetByPCIBusId, + * ::cudaDeviceGetPCIBusId + */ +CUresult CUDAAPI cuDeviceGetPCIBusId(char *pciBusId, int len, CUdevice dev); + +/** + * \brief Gets an interprocess handle for a previously allocated event + * + * Takes as input a previously allocated event. This event must have been + * created with the ::CU_EVENT_INTERPROCESS and ::CU_EVENT_DISABLE_TIMING + * flags set. This opaque handle may be copied into other processes and + * opened with ::cuIpcOpenEventHandle to allow efficient hardware + * synchronization between GPU work in different processes. + * + * After the event has been opened in the importing process, + * ::cuEventRecord, ::cuEventSynchronize, ::cuStreamWaitEvent and + * ::cuEventQuery may be used in either process. Performing operations + * on the imported event after the exported event has been freed + * with ::cuEventDestroy will result in undefined behavior. + * + * IPC functionality is restricted to devices with support for unified + * addressing on Linux and Windows operating systems. + * IPC functionality on Windows is supported for compatibility purposes + * but not recommended as it comes with performance cost. + * Users can test their device for IPC functionality by calling + * ::cuapiDeviceGetAttribute with ::CU_DEVICE_ATTRIBUTE_IPC_EVENT_SUPPORTED + * + * \param pHandle - Pointer to a user allocated CUipcEventHandle + * in which to return the opaque event handle + * \param event - Event allocated with ::CU_EVENT_INTERPROCESS and + * ::CU_EVENT_DISABLE_TIMING flags. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_MAP_FAILED, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuEventCreate, + * ::cuEventDestroy, + * ::cuEventSynchronize, + * ::cuEventQuery, + * ::cuStreamWaitEvent, + * ::cuIpcOpenEventHandle, + * ::cuIpcGetMemHandle, + * ::cuIpcOpenMemHandle, + * ::cuIpcCloseMemHandle, + * ::cudaIpcGetEventHandle + */ +CUresult CUDAAPI cuIpcGetEventHandle(CUipcEventHandle *pHandle, CUevent event); + +/** + * \brief Opens an interprocess event handle for use in the current process + * + * Opens an interprocess event handle exported from another process with + * ::cuIpcGetEventHandle. This function returns a ::CUevent that behaves like + * a locally created event with the ::CU_EVENT_DISABLE_TIMING flag specified. + * This event must be freed with ::cuEventDestroy. + * + * Performing operations on the imported event after the exported event has + * been freed with ::cuEventDestroy will result in undefined behavior. + * + * IPC functionality is restricted to devices with support for unified + * addressing on Linux and Windows operating systems. + * IPC functionality on Windows is supported for compatibility purposes + * but not recommended as it comes with performance cost. + * Users can test their device for IPC functionality by calling + * ::cuapiDeviceGetAttribute with ::CU_DEVICE_ATTRIBUTE_IPC_EVENT_SUPPORTED + * + * \param phEvent - Returns the imported event + * \param handle - Interprocess handle to open + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_MAP_FAILED, + * ::CUDA_ERROR_PEER_ACCESS_UNSUPPORTED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuEventCreate, + * ::cuEventDestroy, + * ::cuEventSynchronize, + * ::cuEventQuery, + * ::cuStreamWaitEvent, + * ::cuIpcGetEventHandle, + * ::cuIpcGetMemHandle, + * ::cuIpcOpenMemHandle, + * ::cuIpcCloseMemHandle, + * ::cudaIpcOpenEventHandle + */ +CUresult CUDAAPI cuIpcOpenEventHandle(CUevent *phEvent, CUipcEventHandle handle); + +/** + * \brief Gets an interprocess memory handle for an existing device memory + * allocation + * + * Takes a pointer to the base of an existing device memory allocation created + * with ::cuMemAlloc and exports it for use in another process. This is a + * lightweight operation and may be called multiple times on an allocation + * without adverse effects. + * + * If a region of memory is freed with ::cuMemFree and a subsequent call + * to ::cuMemAlloc returns memory with the same device address, + * ::cuIpcGetMemHandle will return a unique handle for the + * new memory. + * + * IPC functionality is restricted to devices with support for unified + * addressing on Linux and Windows operating systems. + * IPC functionality on Windows is supported for compatibility purposes + * but not recommended as it comes with performance cost. + * Users can test their device for IPC functionality by calling + * ::cuapiDeviceGetAttribute with ::CU_DEVICE_ATTRIBUTE_IPC_EVENT_SUPPORTED + * + * \param pHandle - Pointer to user allocated ::CUipcMemHandle to return + * the handle in. + * \param dptr - Base pointer to previously allocated device memory + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_MAP_FAILED, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuMemAlloc, + * ::cuMemFree, + * ::cuIpcGetEventHandle, + * ::cuIpcOpenEventHandle, + * ::cuIpcOpenMemHandle, + * ::cuIpcCloseMemHandle, + * ::cudaIpcGetMemHandle + */ +CUresult CUDAAPI cuIpcGetMemHandle(CUipcMemHandle *pHandle, CUdeviceptr dptr); + +/** + * \brief Opens an interprocess memory handle exported from another process + * and returns a device pointer usable in the local process. + * + * Maps memory exported from another process with ::cuIpcGetMemHandle into + * the current device address space. For contexts on different devices + * ::cuIpcOpenMemHandle can attempt to enable peer access between the + * devices as if the user called ::cuCtxEnablePeerAccess. This behavior is + * controlled by the ::CU_IPC_MEM_LAZY_ENABLE_PEER_ACCESS flag. + * ::cuDeviceCanAccessPeer can determine if a mapping is possible. + * + * Contexts that may open ::CUipcMemHandles are restricted in the following way. + * ::CUipcMemHandles from each ::CUdevice in a given process may only be opened + * by one ::CUcontext per ::CUdevice per other process. + * + * If the memory handle has already been opened by the current context, the + * reference count on the handle is incremented by 1 and the existing device pointer + * is returned. + * + * Memory returned from ::cuIpcOpenMemHandle must be freed with + * ::cuIpcCloseMemHandle. + * + * Calling ::cuMemFree on an exported memory region before calling + * ::cuIpcCloseMemHandle in the importing context will result in undefined + * behavior. + * + * IPC functionality is restricted to devices with support for unified + * addressing on Linux and Windows operating systems. + * IPC functionality on Windows is supported for compatibility purposes + * but not recommended as it comes with performance cost. + * Users can test their device for IPC functionality by calling + * ::cuapiDeviceGetAttribute with ::CU_DEVICE_ATTRIBUTE_IPC_EVENT_SUPPORTED + * + * \param pdptr - Returned device pointer + * \param handle - ::CUipcMemHandle to open + * \param Flags - Flags for this operation. Must be specified as ::CU_IPC_MEM_LAZY_ENABLE_PEER_ACCESS + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_MAP_FAILED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_TOO_MANY_PEERS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \note No guarantees are made about the address returned in \p *pdptr. + * In particular, multiple processes may not receive the same address for the same \p handle. + * + * \sa + * ::cuMemAlloc, + * ::cuMemFree, + * ::cuIpcGetEventHandle, + * ::cuIpcOpenEventHandle, + * ::cuIpcGetMemHandle, + * ::cuIpcCloseMemHandle, + * ::cuCtxEnablePeerAccess, + * ::cuDeviceCanAccessPeer, + * ::cudaIpcOpenMemHandle + */ +CUresult CUDAAPI cuIpcOpenMemHandle(CUdeviceptr *pdptr, CUipcMemHandle handle, unsigned int Flags); + +/** + * \brief Attempts to close memory mapped with ::cuIpcOpenMemHandle + * + * Decrements the reference count of the memory returned by ::cuIpcOpenMemHandle by 1. + * When the reference count reaches 0, this API unmaps the memory. The original allocation + * in the exporting process as well as imported mappings in other processes + * will be unaffected. + * + * Any resources used to enable peer access will be freed if this is the + * last mapping using them. + * + * IPC functionality is restricted to devices with support for unified + * addressing on Linux and Windows operating systems. + * IPC functionality on Windows is supported for compatibility purposes + * but not recommended as it comes with performance cost. + * Users can test their device for IPC functionality by calling + * ::cuapiDeviceGetAttribute with ::CU_DEVICE_ATTRIBUTE_IPC_EVENT_SUPPORTED + * + * \param dptr - Device pointer returned by ::cuIpcOpenMemHandle + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_MAP_FAILED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * \sa + * ::cuMemAlloc, + * ::cuMemFree, + * ::cuIpcGetEventHandle, + * ::cuIpcOpenEventHandle, + * ::cuIpcGetMemHandle, + * ::cuIpcOpenMemHandle, + * ::cudaIpcCloseMemHandle + */ +CUresult CUDAAPI cuIpcCloseMemHandle(CUdeviceptr dptr); + +/** + * \brief Registers an existing host memory range for use by CUDA + * + * Page-locks the memory range specified by \p p and \p bytesize and maps it + * for the device(s) as specified by \p Flags. This memory range also is added + * to the same tracking mechanism as ::cuMemHostAlloc to automatically accelerate + * calls to functions such as ::cuMemcpyHtoD(). Since the memory can be accessed + * directly by the device, it can be read or written with much higher bandwidth + * than pageable memory that has not been registered. Page-locking excessive + * amounts of memory may degrade system performance, since it reduces the amount + * of memory available to the system for paging. As a result, this function is + * best used sparingly to register staging areas for data exchange between + * host and device. + * + * On systems where ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES + * is true, ::cuMemHostRegister will not page-lock the memory range specified + * by \p ptr but only populate unpopulated pages. + * + * The \p Flags parameter enables different options to be specified that + * affect the allocation, as follows. + * + * - ::CU_MEMHOSTREGISTER_PORTABLE: The memory returned by this call will be + * considered as pinned memory by all CUDA contexts, not just the one that + * performed the allocation. + * + * - ::CU_MEMHOSTREGISTER_DEVICEMAP: Maps the allocation into the CUDA address + * space. The device pointer to the memory may be obtained by calling + * ::cuMemHostGetDevicePointer(). + * + * - ::CU_MEMHOSTREGISTER_IOMEMORY: The pointer is treated as pointing to some + * I/O memory space, e.g. the PCI Express resource of a 3rd party device. + * + * - ::CU_MEMHOSTREGISTER_READ_ONLY: The pointer is treated as pointing to memory + * that is considered read-only by the device. On platforms without + * ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, this flag is + * required in order to register memory mapped to the CPU as read-only. Support + * for the use of this flag can be queried from the device attribute + * ::CU_DEVICE_ATTRIBUTE_READ_ONLY_HOST_REGISTER_SUPPORTED. Using this flag with + * a current context associated with a device that does not have this attribute + * set will cause ::cuMemHostRegister to error with CUDA_ERROR_NOT_SUPPORTED. + * + * All of these flags are orthogonal to one another: a developer may page-lock + * memory that is portable or mapped with no restrictions. + * + * The ::CU_MEMHOSTREGISTER_DEVICEMAP flag may be specified on CUDA contexts for + * devices that do not support mapped pinned memory. The failure is deferred + * to ::cuMemHostGetDevicePointer() because the memory may be mapped into + * other CUDA contexts via the ::CU_MEMHOSTREGISTER_PORTABLE flag. + * + * For devices that have a non-zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_HOST_POINTER_FOR_REGISTERED_MEM, the memory + * can also be accessed from the device using the host pointer \p p. + * The device pointer returned by ::cuMemHostGetDevicePointer() may or may not + * match the original host pointer \p ptr and depends on the devices visible to the + * application. If all devices visible to the application have a non-zero value for the + * device attribute, the device pointer returned by ::cuMemHostGetDevicePointer() + * will match the original pointer \p ptr. If any device visible to the application + * has a zero value for the device attribute, the device pointer returned by + * ::cuMemHostGetDevicePointer() will not match the original host pointer \p ptr, + * but it will be suitable for use on all devices provided Unified Virtual Addressing + * is enabled. In such systems, it is valid to access the memory using either pointer + * on devices that have a non-zero value for the device attribute. Note however that + * such devices should access the memory using only of the two pointers and not both. + * + * The memory page-locked by this function must be unregistered with + * ::cuMemHostUnregister(). + * + * \param p - Host pointer to memory to page-lock + * \param bytesize - Size in bytes of the address range to page-lock + * \param Flags - Flags for allocation request + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_HOST_MEMORY_ALREADY_REGISTERED, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa + * ::cuMemHostUnregister, + * ::cuMemHostGetFlags, + * ::cuMemHostGetDevicePointer, + * ::cudaHostRegister + */ +CUresult CUDAAPI cuMemHostRegister(void *p, size_t bytesize, unsigned int Flags); + +/** + * \brief Unregisters a memory range that was registered with cuMemHostRegister. + * + * Unmaps the memory range whose base address is specified by \p p, and makes + * it pageable again. + * + * The base address must be the same one specified to ::cuMemHostRegister(). + * + * \param p - Host pointer to memory to unregister + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_HOST_MEMORY_NOT_REGISTERED, + * \notefnerr + * + * \sa + * ::cuMemHostRegister, + * ::cudaHostUnregister + */ +CUresult CUDAAPI cuMemHostUnregister(void *p); + +/** + * \brief Copies memory + * + * Copies data between two pointers. + * \p dst and \p src are base pointers of the destination and source, respectively. + * \p ByteCount specifies the number of bytes to copy. + * Note that this function infers the type of the transfer (host to host, host to + * device, device to device, or device to host) from the pointer values. This + * function is only allowed in contexts which support unified addressing. + * + * \param dst - Destination unified virtual address space pointer + * \param src - Source unified virtual address space pointer + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy, + * ::cudaMemcpyToSymbol, + * ::cudaMemcpyFromSymbol + */ +CUresult CUDAAPI cuMemcpy(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount); + +/** + * \brief Copies device memory between two contexts + * + * Copies from device memory in one context to device memory in another + * context. \p dstDevice is the base device pointer of the destination memory + * and \p dstContext is the destination context. \p srcDevice is the base + * device pointer of the source memory and \p srcContext is the source pointer. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstDevice - Destination device pointer + * \param dstContext - Destination context + * \param srcDevice - Source device pointer + * \param srcContext - Source context + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuMemcpyDtoD, ::cuMemcpy3DPeer, ::cuMemcpyDtoDAsync, ::cuMemcpyPeerAsync, + * ::cuMemcpy3DPeerAsync, + * ::cudaMemcpyPeer + */ +CUresult CUDAAPI cuMemcpyPeer(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount); + +/** + * \brief Copies memory from Host to Device + * + * Copies from host memory to device memory. \p dstDevice and \p srcHost are + * the base addresses of the destination and source, respectively. \p ByteCount + * specifies the number of bytes to copy. + * + * \param dstDevice - Destination device pointer + * \param srcHost - Source host pointer + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy, + * ::cudaMemcpyToSymbol + */ +CUresult CUDAAPI cuMemcpyHtoD(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount); + +/** + * \brief Copies memory from Device to Host + * + * Copies from device to host memory. \p dstHost and \p srcDevice specify the + * base pointers of the destination and source, respectively. \p ByteCount + * specifies the number of bytes to copy. + * + * \param dstHost - Destination host pointer + * \param srcDevice - Source device pointer + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy, + * ::cudaMemcpyFromSymbol + */ +CUresult CUDAAPI cuMemcpyDtoH(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount); + +/** + * \brief Copies memory from Device to Device + * + * Copies from device memory to device memory. \p dstDevice and \p srcDevice + * are the base pointers of the destination and source, respectively. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstDevice - Destination device pointer + * \param srcDevice - Source device pointer + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy, + * ::cudaMemcpyToSymbol, + * ::cudaMemcpyFromSymbol + */ +CUresult CUDAAPI cuMemcpyDtoD(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount); + +/** + * \brief Copies memory from Device to Array + * + * Copies from device memory to a 1D CUDA array. \p dstArray and \p dstOffset + * specify the CUDA array handle and starting index of the destination data. + * \p srcDevice specifies the base pointer of the source. \p ByteCount + * specifies the number of bytes to copy. + * + * \param dstArray - Destination array + * \param dstOffset - Offset in bytes of destination array + * \param srcDevice - Source device pointer + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpyToArray + */ +CUresult CUDAAPI cuMemcpyDtoA(CUarray dstArray, size_t dstOffset, CUdeviceptr srcDevice, size_t ByteCount); + +/** + * \brief Copies memory from Array to Device + * + * Copies from one 1D CUDA array to device memory. \p dstDevice specifies the + * base pointer of the destination and must be naturally aligned with the CUDA + * array elements. \p srcArray and \p srcOffset specify the CUDA array handle + * and the offset in bytes into the array where the copy is to begin. + * \p ByteCount specifies the number of bytes to copy and must be evenly + * divisible by the array element size. + * + * \param dstDevice - Destination device pointer + * \param srcArray - Source array + * \param srcOffset - Offset in bytes of source array + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpyFromArray + */ +CUresult CUDAAPI cuMemcpyAtoD(CUdeviceptr dstDevice, CUarray srcArray, size_t srcOffset, size_t ByteCount); + +/** + * \brief Copies memory from Host to Array + * + * Copies from host memory to a 1D CUDA array. \p dstArray and \p dstOffset + * specify the CUDA array handle and starting offset in bytes of the destination + * data. \p pSrc specifies the base address of the source. \p ByteCount specifies + * the number of bytes to copy. + * + * \param dstArray - Destination array + * \param dstOffset - Offset in bytes of destination array + * \param srcHost - Source host pointer + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpyToArray + */ +CUresult CUDAAPI cuMemcpyHtoA(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount); + +/** + * \brief Copies memory from Array to Host + * + * Copies from one 1D CUDA array to host memory. \p dstHost specifies the base + * pointer of the destination. \p srcArray and \p srcOffset specify the CUDA + * array handle and starting offset in bytes of the source data. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstHost - Destination device pointer + * \param srcArray - Source array + * \param srcOffset - Offset in bytes of source array + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpyFromArray + */ +CUresult CUDAAPI cuMemcpyAtoH(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount); + +/** + * \brief Copies memory from Array to Array + * + * Copies from one 1D CUDA array to another. \p dstArray and \p srcArray + * specify the handles of the destination and source CUDA arrays for the copy, + * respectively. \p dstOffset and \p srcOffset specify the destination and + * source offsets in bytes into the CUDA arrays. \p ByteCount is the number of + * bytes to be copied. The size of the elements in the CUDA arrays need not be + * the same format, but the elements must be the same size; and count must be + * evenly divisible by that size. + * + * \param dstArray - Destination array + * \param dstOffset - Offset in bytes of destination array + * \param srcArray - Source array + * \param srcOffset - Offset in bytes of source array + * \param ByteCount - Size of memory copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpyArrayToArray + */ +CUresult CUDAAPI cuMemcpyAtoA(CUarray dstArray, size_t dstOffset, CUarray srcArray, size_t srcOffset, size_t ByteCount); + +/** + * \brief Copies memory for 2D arrays + * + * Perform a 2D memory copy according to the parameters specified in \p pCopy. + * The ::CUDA_MEMCPY2D structure is defined as: + * + * \code + typedef struct CUDA_MEMCPY2D_st { + unsigned int srcXInBytes, srcY; + CUmemorytype srcMemoryType; + const void *srcHost; + CUdeviceptr srcDevice; + CUarray srcArray; + unsigned int srcPitch; + + unsigned int dstXInBytes, dstY; + CUmemorytype dstMemoryType; + void *dstHost; + CUdeviceptr dstDevice; + CUarray dstArray; + unsigned int dstPitch; + + unsigned int WidthInBytes; + unsigned int Height; + } CUDA_MEMCPY2D; + * \endcode + * where: + * - ::srcMemoryType and ::dstMemoryType specify the type of memory of the + * source and destination, respectively; ::CUmemorytype_enum is defined as: + * + * \code + typedef enum CUmemorytype_enum { + CU_MEMORYTYPE_HOST = 0x01, + CU_MEMORYTYPE_DEVICE = 0x02, + CU_MEMORYTYPE_ARRAY = 0x03, + CU_MEMORYTYPE_UNIFIED = 0x04 + } CUmemorytype; + * \endcode + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::srcDevice and ::srcPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::srcArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_HOST, ::srcHost and ::srcPitch + * specify the (host) base address of the source data and the bytes per row to + * apply. ::srcArray is ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_DEVICE, ::srcDevice and ::srcPitch + * specify the (device) base address of the source data and the bytes per row + * to apply. ::srcArray is ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_ARRAY, ::srcArray specifies the + * handle of the source data. ::srcHost, ::srcDevice and ::srcPitch are + * ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_HOST, ::dstHost and ::dstPitch + * specify the (host) base address of the destination data and the bytes per + * row to apply. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::dstDevice and ::dstPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::dstArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_DEVICE, ::dstDevice and ::dstPitch + * specify the (device) base address of the destination data and the bytes per + * row to apply. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_ARRAY, ::dstArray specifies the + * handle of the destination data. ::dstHost, ::dstDevice and ::dstPitch are + * ignored. + * + * - ::srcXInBytes and ::srcY specify the base address of the source data for + * the copy. + * + * \par + * For host pointers, the starting address is + * \code + void* Start = (void*)((char*)srcHost+srcY*srcPitch + srcXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr Start = srcDevice+srcY*srcPitch+srcXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::srcXInBytes must be evenly divisible by the array + * element size. + * + * - ::dstXInBytes and ::dstY specify the base address of the destination data + * for the copy. + * + * \par + * For host pointers, the base address is + * \code + void* dstStart = (void*)((char*)dstHost+dstY*dstPitch + dstXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr dstStart = dstDevice+dstY*dstPitch+dstXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::dstXInBytes must be evenly divisible by the array + * element size. + * + * - ::WidthInBytes and ::Height specify the width (in bytes) and height of + * the 2D copy being performed. + * - If specified, ::srcPitch must be greater than or equal to ::WidthInBytes + + * ::srcXInBytes, and ::dstPitch must be greater than or equal to + * ::WidthInBytes + dstXInBytes. + * + * \par + * ::cuMemcpy2D() returns an error if any pitch is greater than the maximum + * allowed (::CU_DEVICE_ATTRIBUTE_MAX_PITCH). ::cuMemAllocPitch() passes back + * pitches that always work with ::cuMemcpy2D(). On intra-device memory copies + * (device to device, CUDA array to device, CUDA array to CUDA array), + * ::cuMemcpy2D() may fail for pitches not computed by ::cuMemAllocPitch(). + * ::cuMemcpy2DUnaligned() does not have this restriction, but may run + * significantly slower in the cases where ::cuMemcpy2D() would have returned + * an error code. + * + * \param pCopy - Parameters for the memory copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy2D, + * ::cudaMemcpy2DToArray, + * ::cudaMemcpy2DFromArray + */ +CUresult CUDAAPI cuMemcpy2D(const CUDA_MEMCPY2D *pCopy); + +/** + * \brief Copies memory for 2D arrays + * + * Perform a 2D memory copy according to the parameters specified in \p pCopy. + * The ::CUDA_MEMCPY2D structure is defined as: + * + * \code + typedef struct CUDA_MEMCPY2D_st { + unsigned int srcXInBytes, srcY; + CUmemorytype srcMemoryType; + const void *srcHost; + CUdeviceptr srcDevice; + CUarray srcArray; + unsigned int srcPitch; + unsigned int dstXInBytes, dstY; + CUmemorytype dstMemoryType; + void *dstHost; + CUdeviceptr dstDevice; + CUarray dstArray; + unsigned int dstPitch; + unsigned int WidthInBytes; + unsigned int Height; + } CUDA_MEMCPY2D; + * \endcode + * where: + * - ::srcMemoryType and ::dstMemoryType specify the type of memory of the + * source and destination, respectively; ::CUmemorytype_enum is defined as: + * + * \code + typedef enum CUmemorytype_enum { + CU_MEMORYTYPE_HOST = 0x01, + CU_MEMORYTYPE_DEVICE = 0x02, + CU_MEMORYTYPE_ARRAY = 0x03, + CU_MEMORYTYPE_UNIFIED = 0x04 + } CUmemorytype; + * \endcode + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::srcDevice and ::srcPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::srcArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_HOST, ::srcHost and ::srcPitch + * specify the (host) base address of the source data and the bytes per row to + * apply. ::srcArray is ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_DEVICE, ::srcDevice and ::srcPitch + * specify the (device) base address of the source data and the bytes per row + * to apply. ::srcArray is ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_ARRAY, ::srcArray specifies the + * handle of the source data. ::srcHost, ::srcDevice and ::srcPitch are + * ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::dstDevice and ::dstPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::dstArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_HOST, ::dstHost and ::dstPitch + * specify the (host) base address of the destination data and the bytes per + * row to apply. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_DEVICE, ::dstDevice and ::dstPitch + * specify the (device) base address of the destination data and the bytes per + * row to apply. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_ARRAY, ::dstArray specifies the + * handle of the destination data. ::dstHost, ::dstDevice and ::dstPitch are + * ignored. + * + * - ::srcXInBytes and ::srcY specify the base address of the source data for + * the copy. + * + * \par + * For host pointers, the starting address is + * \code + void* Start = (void*)((char*)srcHost+srcY*srcPitch + srcXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr Start = srcDevice+srcY*srcPitch+srcXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::srcXInBytes must be evenly divisible by the array + * element size. + * + * - ::dstXInBytes and ::dstY specify the base address of the destination data + * for the copy. + * + * \par + * For host pointers, the base address is + * \code + void* dstStart = (void*)((char*)dstHost+dstY*dstPitch + dstXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr dstStart = dstDevice+dstY*dstPitch+dstXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::dstXInBytes must be evenly divisible by the array + * element size. + * + * - ::WidthInBytes and ::Height specify the width (in bytes) and height of + * the 2D copy being performed. + * - If specified, ::srcPitch must be greater than or equal to ::WidthInBytes + + * ::srcXInBytes, and ::dstPitch must be greater than or equal to + * ::WidthInBytes + dstXInBytes. + * + * \par + * ::cuMemcpy2D() returns an error if any pitch is greater than the maximum + * allowed (::CU_DEVICE_ATTRIBUTE_MAX_PITCH). ::cuMemAllocPitch() passes back + * pitches that always work with ::cuMemcpy2D(). On intra-device memory copies + * (device to device, CUDA array to device, CUDA array to CUDA array), + * ::cuMemcpy2D() may fail for pitches not computed by ::cuMemAllocPitch(). + * ::cuMemcpy2DUnaligned() does not have this restriction, but may run + * significantly slower in the cases where ::cuMemcpy2D() would have returned + * an error code. + * + * \param pCopy - Parameters for the memory copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy2D, + * ::cudaMemcpy2DToArray, + * ::cudaMemcpy2DFromArray + */ +CUresult CUDAAPI cuMemcpy2DUnaligned(const CUDA_MEMCPY2D *pCopy); + +/** + * \brief Copies memory for 3D arrays + * + * Perform a 3D memory copy according to the parameters specified in + * \p pCopy. The ::CUDA_MEMCPY3D structure is defined as: + * + * \code + typedef struct CUDA_MEMCPY3D_st { + + unsigned int srcXInBytes, srcY, srcZ; + unsigned int srcLOD; + CUmemorytype srcMemoryType; + const void *srcHost; + CUdeviceptr srcDevice; + CUarray srcArray; + unsigned int srcPitch; // ignored when src is array + unsigned int srcHeight; // ignored when src is array; may be 0 if Depth==1 + + unsigned int dstXInBytes, dstY, dstZ; + unsigned int dstLOD; + CUmemorytype dstMemoryType; + void *dstHost; + CUdeviceptr dstDevice; + CUarray dstArray; + unsigned int dstPitch; // ignored when dst is array + unsigned int dstHeight; // ignored when dst is array; may be 0 if Depth==1 + + unsigned int WidthInBytes; + unsigned int Height; + unsigned int Depth; + } CUDA_MEMCPY3D; + * \endcode + * where: + * - ::srcMemoryType and ::dstMemoryType specify the type of memory of the + * source and destination, respectively; ::CUmemorytype_enum is defined as: + * + * \code + typedef enum CUmemorytype_enum { + CU_MEMORYTYPE_HOST = 0x01, + CU_MEMORYTYPE_DEVICE = 0x02, + CU_MEMORYTYPE_ARRAY = 0x03, + CU_MEMORYTYPE_UNIFIED = 0x04 + } CUmemorytype; + * \endcode + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::srcDevice and ::srcPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::srcArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_HOST, ::srcHost, ::srcPitch and + * ::srcHeight specify the (host) base address of the source data, the bytes + * per row, and the height of each 2D slice of the 3D array. ::srcArray is + * ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_DEVICE, ::srcDevice, ::srcPitch and + * ::srcHeight specify the (device) base address of the source data, the bytes + * per row, and the height of each 2D slice of the 3D array. ::srcArray is + * ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_ARRAY, ::srcArray specifies the + * handle of the source data. ::srcHost, ::srcDevice, ::srcPitch and + * ::srcHeight are ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::dstDevice and ::dstPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::dstArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_HOST, ::dstHost and ::dstPitch + * specify the (host) base address of the destination data, the bytes per row, + * and the height of each 2D slice of the 3D array. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_DEVICE, ::dstDevice and ::dstPitch + * specify the (device) base address of the destination data, the bytes per + * row, and the height of each 2D slice of the 3D array. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_ARRAY, ::dstArray specifies the + * handle of the destination data. ::dstHost, ::dstDevice, ::dstPitch and + * ::dstHeight are ignored. + * + * - ::srcXInBytes, ::srcY and ::srcZ specify the base address of the source + * data for the copy. + * + * \par + * For host pointers, the starting address is + * \code + void* Start = (void*)((char*)srcHost+(srcZ*srcHeight+srcY)*srcPitch + srcXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr Start = srcDevice+(srcZ*srcHeight+srcY)*srcPitch+srcXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::srcXInBytes must be evenly divisible by the array + * element size. + * + * - dstXInBytes, ::dstY and ::dstZ specify the base address of the + * destination data for the copy. + * + * \par + * For host pointers, the base address is + * \code + void* dstStart = (void*)((char*)dstHost+(dstZ*dstHeight+dstY)*dstPitch + dstXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr dstStart = dstDevice+(dstZ*dstHeight+dstY)*dstPitch+dstXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::dstXInBytes must be evenly divisible by the array + * element size. + * + * - ::WidthInBytes, ::Height and ::Depth specify the width (in bytes), height + * and depth of the 3D copy being performed. + * - If specified, ::srcPitch must be greater than or equal to ::WidthInBytes + + * ::srcXInBytes, and ::dstPitch must be greater than or equal to + * ::WidthInBytes + dstXInBytes. + * - If specified, ::srcHeight must be greater than or equal to ::Height + + * ::srcY, and ::dstHeight must be greater than or equal to ::Height + ::dstY. + * + * \par + * ::cuMemcpy3D() returns an error if any pitch is greater than the maximum + * allowed (::CU_DEVICE_ATTRIBUTE_MAX_PITCH). + * + * The ::srcLOD and ::dstLOD members of the ::CUDA_MEMCPY3D structure must be + * set to 0. + * + * \param pCopy - Parameters for the memory copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMemcpy3D + */ +CUresult CUDAAPI cuMemcpy3D(const CUDA_MEMCPY3D *pCopy); + +/** + * \brief Copies memory between contexts + * + * Perform a 3D memory copy according to the parameters specified in + * \p pCopy. See the definition of the ::CUDA_MEMCPY3D_PEER structure + * for documentation of its parameters. + * + * \param pCopy - Parameters for the memory copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_sync + * + * \sa ::cuMemcpyDtoD, ::cuMemcpyPeer, ::cuMemcpyDtoDAsync, ::cuMemcpyPeerAsync, + * ::cuMemcpy3DPeerAsync, + * ::cudaMemcpy3DPeer + */ +CUresult CUDAAPI cuMemcpy3DPeer(const CUDA_MEMCPY3D_PEER *pCopy); + +/** + * \brief Copies memory asynchronously + * + * Copies data between two pointers. + * \p dst and \p src are base pointers of the destination and source, respectively. + * \p ByteCount specifies the number of bytes to copy. + * Note that this function infers the type of the transfer (host to host, host to + * device, device to device, or device to host) from the pointer values. This + * function is only allowed in contexts which support unified addressing. + * + * \param dst - Destination unified virtual address space pointer + * \param src - Source unified virtual address space pointer + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpyAsync, + * ::cudaMemcpyToSymbolAsync, + * ::cudaMemcpyFromSymbolAsync + */ +CUresult CUDAAPI cuMemcpyAsync(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies device memory between two contexts asynchronously. + * + * Copies from device memory in one context to device memory in another + * context. \p dstDevice is the base device pointer of the destination memory + * and \p dstContext is the destination context. \p srcDevice is the base + * device pointer of the source memory and \p srcContext is the source pointer. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstDevice - Destination device pointer + * \param dstContext - Destination context + * \param srcDevice - Source device pointer + * \param srcContext - Source context + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemcpyDtoD, ::cuMemcpyPeer, ::cuMemcpy3DPeer, ::cuMemcpyDtoDAsync, + * ::cuMemcpy3DPeerAsync, + * ::cudaMemcpyPeerAsync + */ +CUresult CUDAAPI cuMemcpyPeerAsync(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies memory from Host to Device + * + * Copies from host memory to device memory. \p dstDevice and \p srcHost are + * the base addresses of the destination and source, respectively. \p ByteCount + * specifies the number of bytes to copy. + * + * \param dstDevice - Destination device pointer + * \param srcHost - Source host pointer + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpyAsync, + * ::cudaMemcpyToSymbolAsync + */ +CUresult CUDAAPI cuMemcpyHtoDAsync(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies memory from Device to Host + * + * Copies from device to host memory. \p dstHost and \p srcDevice specify the + * base pointers of the destination and source, respectively. \p ByteCount + * specifies the number of bytes to copy. + * + * \param dstHost - Destination host pointer + * \param srcDevice - Source device pointer + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpyAsync, + * ::cudaMemcpyFromSymbolAsync + */ +CUresult CUDAAPI cuMemcpyDtoHAsync(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies memory from Device to Device + * + * Copies from device memory to device memory. \p dstDevice and \p srcDevice + * are the base pointers of the destination and source, respectively. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstDevice - Destination device pointer + * \param srcDevice - Source device pointer + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpyAsync, + * ::cudaMemcpyToSymbolAsync, + * ::cudaMemcpyFromSymbolAsync + */ +CUresult CUDAAPI cuMemcpyDtoDAsync(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies memory from Host to Array + * + * Copies from host memory to a 1D CUDA array. \p dstArray and \p dstOffset + * specify the CUDA array handle and starting offset in bytes of the + * destination data. \p srcHost specifies the base address of the source. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstArray - Destination array + * \param dstOffset - Offset in bytes of destination array + * \param srcHost - Source host pointer + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpyToArrayAsync + */ +CUresult CUDAAPI cuMemcpyHtoAAsync(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies memory from Array to Host + * + * Copies from one 1D CUDA array to host memory. \p dstHost specifies the base + * pointer of the destination. \p srcArray and \p srcOffset specify the CUDA + * array handle and starting offset in bytes of the source data. + * \p ByteCount specifies the number of bytes to copy. + * + * \param dstHost - Destination pointer + * \param srcArray - Source array + * \param srcOffset - Offset in bytes of source array + * \param ByteCount - Size of memory copy in bytes + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * \note_memcpy + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpyFromArrayAsync + */ +CUresult CUDAAPI cuMemcpyAtoHAsync(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount, CUstream hStream); + +/** + * \brief Copies memory for 2D arrays + * + * Perform a 2D memory copy according to the parameters specified in \p pCopy. + * The ::CUDA_MEMCPY2D structure is defined as: + * + * \code + typedef struct CUDA_MEMCPY2D_st { + unsigned int srcXInBytes, srcY; + CUmemorytype srcMemoryType; + const void *srcHost; + CUdeviceptr srcDevice; + CUarray srcArray; + unsigned int srcPitch; + unsigned int dstXInBytes, dstY; + CUmemorytype dstMemoryType; + void *dstHost; + CUdeviceptr dstDevice; + CUarray dstArray; + unsigned int dstPitch; + unsigned int WidthInBytes; + unsigned int Height; + } CUDA_MEMCPY2D; + * \endcode + * where: + * - ::srcMemoryType and ::dstMemoryType specify the type of memory of the + * source and destination, respectively; ::CUmemorytype_enum is defined as: + * + * \code + typedef enum CUmemorytype_enum { + CU_MEMORYTYPE_HOST = 0x01, + CU_MEMORYTYPE_DEVICE = 0x02, + CU_MEMORYTYPE_ARRAY = 0x03, + CU_MEMORYTYPE_UNIFIED = 0x04 + } CUmemorytype; + * \endcode + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_HOST, ::srcHost and ::srcPitch + * specify the (host) base address of the source data and the bytes per row to + * apply. ::srcArray is ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::srcDevice and ::srcPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::srcArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_DEVICE, ::srcDevice and ::srcPitch + * specify the (device) base address of the source data and the bytes per row + * to apply. ::srcArray is ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_ARRAY, ::srcArray specifies the + * handle of the source data. ::srcHost, ::srcDevice and ::srcPitch are + * ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::dstDevice and ::dstPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::dstArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_HOST, ::dstHost and ::dstPitch + * specify the (host) base address of the destination data and the bytes per + * row to apply. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_DEVICE, ::dstDevice and ::dstPitch + * specify the (device) base address of the destination data and the bytes per + * row to apply. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_ARRAY, ::dstArray specifies the + * handle of the destination data. ::dstHost, ::dstDevice and ::dstPitch are + * ignored. + * + * - ::srcXInBytes and ::srcY specify the base address of the source data for + * the copy. + * + * \par + * For host pointers, the starting address is + * \code + void* Start = (void*)((char*)srcHost+srcY*srcPitch + srcXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr Start = srcDevice+srcY*srcPitch+srcXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::srcXInBytes must be evenly divisible by the array + * element size. + * + * - ::dstXInBytes and ::dstY specify the base address of the destination data + * for the copy. + * + * \par + * For host pointers, the base address is + * \code + void* dstStart = (void*)((char*)dstHost+dstY*dstPitch + dstXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr dstStart = dstDevice+dstY*dstPitch+dstXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::dstXInBytes must be evenly divisible by the array + * element size. + * + * - ::WidthInBytes and ::Height specify the width (in bytes) and height of + * the 2D copy being performed. + * - If specified, ::srcPitch must be greater than or equal to ::WidthInBytes + + * ::srcXInBytes, and ::dstPitch must be greater than or equal to + * ::WidthInBytes + dstXInBytes. + * - If specified, ::srcPitch must be greater than or equal to ::WidthInBytes + + * ::srcXInBytes, and ::dstPitch must be greater than or equal to + * ::WidthInBytes + dstXInBytes. + * - If specified, ::srcHeight must be greater than or equal to ::Height + + * ::srcY, and ::dstHeight must be greater than or equal to ::Height + ::dstY. + * + * \par + * ::cuMemcpy2DAsync() returns an error if any pitch is greater than the maximum + * allowed (::CU_DEVICE_ATTRIBUTE_MAX_PITCH). ::cuMemAllocPitch() passes back + * pitches that always work with ::cuMemcpy2D(). On intra-device memory copies + * (device to device, CUDA array to device, CUDA array to CUDA array), + * ::cuMemcpy2DAsync() may fail for pitches not computed by ::cuMemAllocPitch(). + * + * \param pCopy - Parameters for the memory copy + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpy2DAsync, + * ::cudaMemcpy2DToArrayAsync, + * ::cudaMemcpy2DFromArrayAsync + */ +CUresult CUDAAPI cuMemcpy2DAsync(const CUDA_MEMCPY2D *pCopy, CUstream hStream); + +/** + * \brief Copies memory for 3D arrays + * + * Perform a 3D memory copy according to the parameters specified in + * \p pCopy. The ::CUDA_MEMCPY3D structure is defined as: + * + * \code + typedef struct CUDA_MEMCPY3D_st { + + unsigned int srcXInBytes, srcY, srcZ; + unsigned int srcLOD; + CUmemorytype srcMemoryType; + const void *srcHost; + CUdeviceptr srcDevice; + CUarray srcArray; + unsigned int srcPitch; // ignored when src is array + unsigned int srcHeight; // ignored when src is array; may be 0 if Depth==1 + + unsigned int dstXInBytes, dstY, dstZ; + unsigned int dstLOD; + CUmemorytype dstMemoryType; + void *dstHost; + CUdeviceptr dstDevice; + CUarray dstArray; + unsigned int dstPitch; // ignored when dst is array + unsigned int dstHeight; // ignored when dst is array; may be 0 if Depth==1 + + unsigned int WidthInBytes; + unsigned int Height; + unsigned int Depth; + } CUDA_MEMCPY3D; + * \endcode + * where: + * - ::srcMemoryType and ::dstMemoryType specify the type of memory of the + * source and destination, respectively; ::CUmemorytype_enum is defined as: + * + * \code + typedef enum CUmemorytype_enum { + CU_MEMORYTYPE_HOST = 0x01, + CU_MEMORYTYPE_DEVICE = 0x02, + CU_MEMORYTYPE_ARRAY = 0x03, + CU_MEMORYTYPE_UNIFIED = 0x04 + } CUmemorytype; + * \endcode + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::srcDevice and ::srcPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::srcArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_HOST, ::srcHost, ::srcPitch and + * ::srcHeight specify the (host) base address of the source data, the bytes + * per row, and the height of each 2D slice of the 3D array. ::srcArray is + * ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_DEVICE, ::srcDevice, ::srcPitch and + * ::srcHeight specify the (device) base address of the source data, the bytes + * per row, and the height of each 2D slice of the 3D array. ::srcArray is + * ignored. + * + * \par + * If ::srcMemoryType is ::CU_MEMORYTYPE_ARRAY, ::srcArray specifies the + * handle of the source data. ::srcHost, ::srcDevice, ::srcPitch and + * ::srcHeight are ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_UNIFIED, ::dstDevice and ::dstPitch + * specify the (unified virtual address space) base address of the source data + * and the bytes per row to apply. ::dstArray is ignored. + * This value may be used only if unified addressing is supported in the calling + * context. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_HOST, ::dstHost and ::dstPitch + * specify the (host) base address of the destination data, the bytes per row, + * and the height of each 2D slice of the 3D array. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_DEVICE, ::dstDevice and ::dstPitch + * specify the (device) base address of the destination data, the bytes per + * row, and the height of each 2D slice of the 3D array. ::dstArray is ignored. + * + * \par + * If ::dstMemoryType is ::CU_MEMORYTYPE_ARRAY, ::dstArray specifies the + * handle of the destination data. ::dstHost, ::dstDevice, ::dstPitch and + * ::dstHeight are ignored. + * + * - ::srcXInBytes, ::srcY and ::srcZ specify the base address of the source + * data for the copy. + * + * \par + * For host pointers, the starting address is + * \code + void* Start = (void*)((char*)srcHost+(srcZ*srcHeight+srcY)*srcPitch + srcXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr Start = srcDevice+(srcZ*srcHeight+srcY)*srcPitch+srcXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::srcXInBytes must be evenly divisible by the array + * element size. + * + * - dstXInBytes, ::dstY and ::dstZ specify the base address of the + * destination data for the copy. + * + * \par + * For host pointers, the base address is + * \code + void* dstStart = (void*)((char*)dstHost+(dstZ*dstHeight+dstY)*dstPitch + dstXInBytes); + * \endcode + * + * \par + * For device pointers, the starting address is + * \code + CUdeviceptr dstStart = dstDevice+(dstZ*dstHeight+dstY)*dstPitch+dstXInBytes; + * \endcode + * + * \par + * For CUDA arrays, ::dstXInBytes must be evenly divisible by the array + * element size. + * + * - ::WidthInBytes, ::Height and ::Depth specify the width (in bytes), height + * and depth of the 3D copy being performed. + * - If specified, ::srcPitch must be greater than or equal to ::WidthInBytes + + * ::srcXInBytes, and ::dstPitch must be greater than or equal to + * ::WidthInBytes + dstXInBytes. + * - If specified, ::srcHeight must be greater than or equal to ::Height + + * ::srcY, and ::dstHeight must be greater than or equal to ::Height + ::dstY. + * + * \par + * ::cuMemcpy3DAsync() returns an error if any pitch is greater than the maximum + * allowed (::CU_DEVICE_ATTRIBUTE_MAX_PITCH). + * + * The ::srcLOD and ::dstLOD members of the ::CUDA_MEMCPY3D structure must be + * set to 0. + * + * \param pCopy - Parameters for the memory copy + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemcpy3DAsync + */ +CUresult CUDAAPI cuMemcpy3DAsync(const CUDA_MEMCPY3D *pCopy, CUstream hStream); + +/** + * \brief Copies memory between contexts asynchronously. + * + * Perform a 3D memory copy according to the parameters specified in + * \p pCopy. See the definition of the ::CUDA_MEMCPY3D_PEER structure + * for documentation of its parameters. + * + * \param pCopy - Parameters for the memory copy + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemcpyDtoD, ::cuMemcpyPeer, ::cuMemcpyDtoDAsync, ::cuMemcpyPeerAsync, + * ::cuMemcpy3DPeerAsync, + * ::cudaMemcpy3DPeerAsync + */ +CUresult CUDAAPI cuMemcpy3DPeerAsync(const CUDA_MEMCPY3D_PEER *pCopy, CUstream hStream); + +/** + * \brief Initializes device memory + * + * Sets the memory range of \p N 8-bit values to the specified value + * \p uc. + * + * \param dstDevice - Destination device pointer + * \param uc - Value to set + * \param N - Number of elements + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset + */ +CUresult CUDAAPI cuMemsetD8(CUdeviceptr dstDevice, unsigned char uc, size_t N); + +/** + * \brief Initializes device memory + * + * Sets the memory range of \p N 16-bit values to the specified value + * \p us. The \p dstDevice pointer must be two byte aligned. + * + * \param dstDevice - Destination device pointer + * \param us - Value to set + * \param N - Number of elements + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset + */ +CUresult CUDAAPI cuMemsetD16(CUdeviceptr dstDevice, unsigned short us, size_t N); + +/** + * \brief Initializes device memory + * + * Sets the memory range of \p N 32-bit values to the specified value + * \p ui. The \p dstDevice pointer must be four byte aligned. + * + * \param dstDevice - Destination device pointer + * \param ui - Value to set + * \param N - Number of elements + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32Async, + * ::cudaMemset + */ +CUresult CUDAAPI cuMemsetD32(CUdeviceptr dstDevice, unsigned int ui, size_t N); + +/** + * \brief Initializes device memory + * + * Sets the 2D memory range of \p Width 8-bit values to the specified value + * \p uc. \p Height specifies the number of rows to set, and \p dstPitch + * specifies the number of bytes between each row. This function performs + * fastest when the pitch is one that has been passed back by + * ::cuMemAllocPitch(). + * + * \param dstDevice - Destination device pointer + * \param dstPitch - Pitch of destination device pointer(Unused if \p Height is 1) + * \param uc - Value to set + * \param Width - Width of row + * \param Height - Number of rows + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset2D + */ +CUresult CUDAAPI cuMemsetD2D8(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height); + +/** + * \brief Initializes device memory + * + * Sets the 2D memory range of \p Width 16-bit values to the specified value + * \p us. \p Height specifies the number of rows to set, and \p dstPitch + * specifies the number of bytes between each row. The \p dstDevice pointer + * and \p dstPitch offset must be two byte aligned. This function performs + * fastest when the pitch is one that has been passed back by + * ::cuMemAllocPitch(). + * + * \param dstDevice - Destination device pointer + * \param dstPitch - Pitch of destination device pointer(Unused if \p Height is 1) + * \param us - Value to set + * \param Width - Width of row + * \param Height - Number of rows + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset2D + */ +CUresult CUDAAPI cuMemsetD2D16(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height); + +/** + * \brief Initializes device memory + * + * Sets the 2D memory range of \p Width 32-bit values to the specified value + * \p ui. \p Height specifies the number of rows to set, and \p dstPitch + * specifies the number of bytes between each row. The \p dstDevice pointer + * and \p dstPitch offset must be four byte aligned. This function performs + * fastest when the pitch is one that has been passed back by + * ::cuMemAllocPitch(). + * + * \param dstDevice - Destination device pointer + * \param dstPitch - Pitch of destination device pointer(Unused if \p Height is 1) + * \param ui - Value to set + * \param Width - Width of row + * \param Height - Number of rows + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset2D + */ +CUresult CUDAAPI cuMemsetD2D32(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height); + +/** + * \brief Sets device memory + * + * Sets the memory range of \p N 8-bit values to the specified value + * \p uc. + * + * \param dstDevice - Destination device pointer + * \param uc - Value to set + * \param N - Number of elements + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemsetAsync + */ +CUresult CUDAAPI cuMemsetD8Async(CUdeviceptr dstDevice, unsigned char uc, size_t N, CUstream hStream); + +/** + * \brief Sets device memory + * + * Sets the memory range of \p N 16-bit values to the specified value + * \p us. The \p dstDevice pointer must be two byte aligned. + * + * \param dstDevice - Destination device pointer + * \param us - Value to set + * \param N - Number of elements + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemsetAsync + */ +CUresult CUDAAPI cuMemsetD16Async(CUdeviceptr dstDevice, unsigned short us, size_t N, CUstream hStream); + +/** + * \brief Sets device memory + * + * Sets the memory range of \p N 32-bit values to the specified value + * \p ui. The \p dstDevice pointer must be four byte aligned. + * + * \param dstDevice - Destination device pointer + * \param ui - Value to set + * \param N - Number of elements + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, ::cuMemsetD32, + * ::cudaMemsetAsync + */ +CUresult CUDAAPI cuMemsetD32Async(CUdeviceptr dstDevice, unsigned int ui, size_t N, CUstream hStream); + +/** + * \brief Sets device memory + * + * Sets the 2D memory range of \p Width 8-bit values to the specified value + * \p uc. \p Height specifies the number of rows to set, and \p dstPitch + * specifies the number of bytes between each row. This function performs + * fastest when the pitch is one that has been passed back by + * ::cuMemAllocPitch(). + * + * \param dstDevice - Destination device pointer + * \param dstPitch - Pitch of destination device pointer(Unused if \p Height is 1) + * \param uc - Value to set + * \param Width - Width of row + * \param Height - Number of rows + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset2DAsync + */ +CUresult CUDAAPI cuMemsetD2D8Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height, CUstream hStream); + +/** + * \brief Sets device memory + * + * Sets the 2D memory range of \p Width 16-bit values to the specified value + * \p us. \p Height specifies the number of rows to set, and \p dstPitch + * specifies the number of bytes between each row. The \p dstDevice pointer + * and \p dstPitch offset must be two byte aligned. This function performs + * fastest when the pitch is one that has been passed back by + * ::cuMemAllocPitch(). + * + * \param dstDevice - Destination device pointer + * \param dstPitch - Pitch of destination device pointer(Unused if \p Height is 1) + * \param us - Value to set + * \param Width - Width of row + * \param Height - Number of rows + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D32, ::cuMemsetD2D32Async, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset2DAsync + */ +CUresult CUDAAPI cuMemsetD2D16Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height, CUstream hStream); + +/** + * \brief Sets device memory + * + * Sets the 2D memory range of \p Width 32-bit values to the specified value + * \p ui. \p Height specifies the number of rows to set, and \p dstPitch + * specifies the number of bytes between each row. The \p dstDevice pointer + * and \p dstPitch offset must be four byte aligned. This function performs + * fastest when the pitch is one that has been passed back by + * ::cuMemAllocPitch(). + * + * \param dstDevice - Destination device pointer + * \param dstPitch - Pitch of destination device pointer(Unused if \p Height is 1) + * \param ui - Value to set + * \param Width - Width of row + * \param Height - Number of rows + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * \note_memset + * \note_null_stream + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D8Async, + * ::cuMemsetD2D16, ::cuMemsetD2D16Async, ::cuMemsetD2D32, + * ::cuMemsetD8, ::cuMemsetD8Async, ::cuMemsetD16, ::cuMemsetD16Async, + * ::cuMemsetD32, ::cuMemsetD32Async, + * ::cudaMemset2DAsync + */ +CUresult CUDAAPI cuMemsetD2D32Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height, CUstream hStream); + +/** + * \brief Creates a 1D or 2D CUDA array + * + * Creates a CUDA array according to the ::CUDA_ARRAY_DESCRIPTOR structure + * \p pAllocateArray and returns a handle to the new CUDA array in \p *pHandle. + * The ::CUDA_ARRAY_DESCRIPTOR is defined as: + * + * \code + typedef struct { + unsigned int Width; + unsigned int Height; + CUarray_format Format; + unsigned int NumChannels; + } CUDA_ARRAY_DESCRIPTOR; + * \endcode + * where: + * + * - \p Width, and \p Height are the width, and height of the CUDA array (in + * elements); the CUDA array is one-dimensional if height is 0, two-dimensional + * otherwise; + * - ::Format specifies the format of the elements; ::CUarray_format is + * defined as: + * \code + typedef enum CUarray_format_enum { + CU_AD_FORMAT_UNSIGNED_INT8 = 0x01, + CU_AD_FORMAT_UNSIGNED_INT16 = 0x02, + CU_AD_FORMAT_UNSIGNED_INT32 = 0x03, + CU_AD_FORMAT_SIGNED_INT8 = 0x08, + CU_AD_FORMAT_SIGNED_INT16 = 0x09, + CU_AD_FORMAT_SIGNED_INT32 = 0x0a, + CU_AD_FORMAT_HALF = 0x10, + CU_AD_FORMAT_FLOAT = 0x20 + } CUarray_format; + * \endcode + * - \p NumChannels specifies the number of packed components per CUDA array + * element; it may be 1, 2, or 4; + * + * Here are examples of CUDA array descriptions: + * + * Description for a CUDA array of 2048 floats: + * \code + CUDA_ARRAY_DESCRIPTOR desc; + desc.Format = CU_AD_FORMAT_FLOAT; + desc.NumChannels = 1; + desc.Width = 2048; + desc.Height = 1; + * \endcode + * + * Description for a 64 x 64 CUDA array of floats: + * \code + CUDA_ARRAY_DESCRIPTOR desc; + desc.Format = CU_AD_FORMAT_FLOAT; + desc.NumChannels = 1; + desc.Width = 64; + desc.Height = 64; + * \endcode + * + * Description for a \p width x \p height CUDA array of 64-bit, 4x16-bit + * float16's: + * \code + CUDA_ARRAY_DESCRIPTOR desc; + desc.Format = CU_AD_FORMAT_HALF; + desc.NumChannels = 4; + desc.Width = width; + desc.Height = height; + * \endcode + * + * Description for a \p width x \p height CUDA array of 16-bit elements, each + * of which is two 8-bit unsigned chars: + * \code + CUDA_ARRAY_DESCRIPTOR arrayDesc; + desc.Format = CU_AD_FORMAT_UNSIGNED_INT8; + desc.NumChannels = 2; + desc.Width = width; + desc.Height = height; + * \endcode + * + * \param pHandle - Returned array + * \param pAllocateArray - Array descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMallocArray + */ +CUresult CUDAAPI cuArrayCreate(CUarray *pHandle, const CUDA_ARRAY_DESCRIPTOR *pAllocateArray); + +/** + * \brief Get a 1D or 2D CUDA array descriptor + * + * Returns in \p *pArrayDescriptor a descriptor containing information on the + * format and dimensions of the CUDA array \p hArray. It is useful for + * subroutines that have been passed a CUDA array, but need to know the CUDA + * array parameters for validation or other purposes. + * + * \param pArrayDescriptor - Returned array descriptor + * \param hArray - Array to get descriptor of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaArrayGetInfo + */ +CUresult CUDAAPI cuArrayGetDescriptor(CUDA_ARRAY_DESCRIPTOR *pArrayDescriptor, CUarray hArray); + +/** + * \brief Returns the layout properties of a sparse CUDA array + * + * Returns the layout properties of a sparse CUDA array in \p sparseProperties + * If the CUDA array is not allocated with flag ::CUDA_ARRAY3D_SPARSE + * ::CUDA_ERROR_INVALID_VALUE will be returned. + * + * If the returned value in ::CUDA_ARRAY_SPARSE_PROPERTIES::flags contains ::CU_ARRAY_SPARSE_PROPERTIES_SINGLE_MIPTAIL, + * then ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailSize represents the total size of the array. Otherwise, it will be zero. + * Also, the returned value in ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailFirstLevel is always zero. + * Note that the \p array must have been allocated using ::cuArrayCreate or ::cuArray3DCreate. For CUDA arrays obtained + * using ::cuMipmappedArrayGetLevel, ::CUDA_ERROR_INVALID_VALUE will be returned. Instead, ::cuMipmappedArrayGetSparseProperties + * must be used to obtain the sparse properties of the entire CUDA mipmapped array to which \p array belongs to. + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_INVALID_VALUE + * + * \param[out] sparseProperties - Pointer to ::CUDA_ARRAY_SPARSE_PROPERTIES + * \param[in] array - CUDA array to get the sparse properties of + * \sa ::cuMipmappedArrayGetSparseProperties, ::cuMemMapArrayAsync + */ +CUresult CUDAAPI cuArrayGetSparseProperties(CUDA_ARRAY_SPARSE_PROPERTIES *sparseProperties, CUarray array); + +/** + * \brief Returns the layout properties of a sparse CUDA mipmapped array + * + * Returns the sparse array layout properties in \p sparseProperties + * If the CUDA mipmapped array is not allocated with flag ::CUDA_ARRAY3D_SPARSE + * ::CUDA_ERROR_INVALID_VALUE will be returned. + * + * For non-layered CUDA mipmapped arrays, ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailSize returns the + * size of the mip tail region. The mip tail region includes all mip levels whose width, height or depth + * is less than that of the tile. + * For layered CUDA mipmapped arrays, if ::CUDA_ARRAY_SPARSE_PROPERTIES::flags contains ::CU_ARRAY_SPARSE_PROPERTIES_SINGLE_MIPTAIL, + * then ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailSize specifies the size of the mip tail of all layers combined. + * Otherwise, ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailSize specifies mip tail size per layer. + * The returned value of ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailFirstLevel is valid only if ::CUDA_ARRAY_SPARSE_PROPERTIES::miptailSize is non-zero. + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_INVALID_VALUE + * + * \param[out] sparseProperties - Pointer to ::CUDA_ARRAY_SPARSE_PROPERTIES + * \param[in] mipmap - CUDA mipmapped array to get the sparse properties of + * \sa ::cuArrayGetSparseProperties, ::cuMemMapArrayAsync + */ +CUresult CUDAAPI cuMipmappedArrayGetSparseProperties(CUDA_ARRAY_SPARSE_PROPERTIES *sparseProperties, CUmipmappedArray mipmap); + +/** + * \brief Returns the memory requirements of a CUDA array + * + * Returns the memory requirements of a CUDA array in \p memoryRequirements + * If the CUDA array is not allocated with flag ::CUDA_ARRAY3D_DEFERRED_MAPPING + * ::CUDA_ERROR_INVALID_VALUE will be returned. + * + * The returned value in ::CUDA_ARRAY_MEMORY_REQUIREMENTS::size + * represents the total size of the CUDA array. + * The returned value in ::CUDA_ARRAY_MEMORY_REQUIREMENTS::alignment + * represents the alignment necessary for mapping the CUDA array. + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_INVALID_VALUE + * + * \param[out] memoryRequirements - Pointer to ::CUDA_ARRAY_MEMORY_REQUIREMENTS + * \param[in] array - CUDA array to get the memory requirements of + * \param[in] device - Device to get the memory requirements for + * \sa ::cuMipmappedArrayGetMemoryRequirements, ::cuMemMapArrayAsync + */ +CUresult CUDAAPI cuArrayGetMemoryRequirements(CUDA_ARRAY_MEMORY_REQUIREMENTS *memoryRequirements, CUarray array, CUdevice device); + +/** + * \brief Returns the memory requirements of a CUDA mipmapped array + * + * Returns the memory requirements of a CUDA mipmapped array in \p memoryRequirements + * If the CUDA mipmapped array is not allocated with flag ::CUDA_ARRAY3D_DEFERRED_MAPPING + * ::CUDA_ERROR_INVALID_VALUE will be returned. + * + * The returned value in ::CUDA_ARRAY_MEMORY_REQUIREMENTS::size + * represents the total size of the CUDA mipmapped array. + * The returned value in ::CUDA_ARRAY_MEMORY_REQUIREMENTS::alignment + * represents the alignment necessary for mapping the CUDA mipmapped + * array. + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_INVALID_VALUE + * + * \param[out] memoryRequirements - Pointer to ::CUDA_ARRAY_MEMORY_REQUIREMENTS + * \param[in] mipmap - CUDA mipmapped array to get the memory requirements of + * \param[in] device - Device to get the memory requirements for + * \sa ::cuArrayGetMemoryRequirements, ::cuMemMapArrayAsync + */ +CUresult CUDAAPI cuMipmappedArrayGetMemoryRequirements(CUDA_ARRAY_MEMORY_REQUIREMENTS *memoryRequirements, CUmipmappedArray mipmap, CUdevice device); + +/** + * \brief Gets a CUDA array plane from a CUDA array + * + * Returns in \p pPlaneArray a CUDA array that represents a single format plane + * of the CUDA array \p hArray. + * + * If \p planeIdx is greater than the maximum number of planes in this array or if the array does + * not have a multi-planar format e.g: ::CU_AD_FORMAT_NV12, then ::CUDA_ERROR_INVALID_VALUE is returned. + * + * Note that if the \p hArray has format ::CU_AD_FORMAT_NV12, then passing in 0 for \p planeIdx returns + * a CUDA array of the same size as \p hArray but with one channel and ::CU_AD_FORMAT_UNSIGNED_INT8 as its format. + * If 1 is passed for \p planeIdx, then the returned CUDA array has half the height and width + * of \p hArray with two channels and ::CU_AD_FORMAT_UNSIGNED_INT8 as its format. + * + * \param pPlaneArray - Returned CUDA array referenced by the \p planeIdx + * \param hArray - Multiplanar CUDA array + * \param planeIdx - Plane index + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa + * ::cuArrayCreate, + * ::cudaArrayGetPlane + */ +CUresult CUDAAPI cuArrayGetPlane(CUarray *pPlaneArray, CUarray hArray, unsigned int planeIdx); + +/** + * \brief Destroys a CUDA array + * + * Destroys the CUDA array \p hArray. + * + * \param hArray - Array to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_ARRAY_IS_MAPPED, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaFreeArray + */ +CUresult CUDAAPI cuArrayDestroy(CUarray hArray); + +/** + * \brief Creates a 3D CUDA array + * + * Creates a CUDA array according to the ::CUDA_ARRAY3D_DESCRIPTOR structure + * \p pAllocateArray and returns a handle to the new CUDA array in \p *pHandle. + * The ::CUDA_ARRAY3D_DESCRIPTOR is defined as: + * + * \code + typedef struct { + unsigned int Width; + unsigned int Height; + unsigned int Depth; + CUarray_format Format; + unsigned int NumChannels; + unsigned int Flags; + } CUDA_ARRAY3D_DESCRIPTOR; + * \endcode + * where: + * + * - \p Width, \p Height, and \p Depth are the width, height, and depth of the + * CUDA array (in elements); the following types of CUDA arrays can be allocated: + * - A 1D array is allocated if \p Height and \p Depth extents are both zero. + * - A 2D array is allocated if only \p Depth extent is zero. + * - A 3D array is allocated if all three extents are non-zero. + * - A 1D layered CUDA array is allocated if only \p Height is zero and the + * ::CUDA_ARRAY3D_LAYERED flag is set. Each layer is a 1D array. The number + * of layers is determined by the depth extent. + * - A 2D layered CUDA array is allocated if all three extents are non-zero and + * the ::CUDA_ARRAY3D_LAYERED flag is set. Each layer is a 2D array. The number + * of layers is determined by the depth extent. + * - A cubemap CUDA array is allocated if all three extents are non-zero and the + * ::CUDA_ARRAY3D_CUBEMAP flag is set. \p Width must be equal to \p Height, and + * \p Depth must be six. A cubemap is a special type of 2D layered CUDA array, + * where the six layers represent the six faces of a cube. The order of the six + * layers in memory is the same as that listed in ::CUarray_cubemap_face. + * - A cubemap layered CUDA array is allocated if all three extents are non-zero, + * and both, ::CUDA_ARRAY3D_CUBEMAP and ::CUDA_ARRAY3D_LAYERED flags are set. + * \p Width must be equal to \p Height, and \p Depth must be a multiple of six. + * A cubemap layered CUDA array is a special type of 2D layered CUDA array that + * consists of a collection of cubemaps. The first six layers represent the first + * cubemap, the next six layers form the second cubemap, and so on. + * + * - ::Format specifies the format of the elements; ::CUarray_format is + * defined as: + * \code + typedef enum CUarray_format_enum { + CU_AD_FORMAT_UNSIGNED_INT8 = 0x01, + CU_AD_FORMAT_UNSIGNED_INT16 = 0x02, + CU_AD_FORMAT_UNSIGNED_INT32 = 0x03, + CU_AD_FORMAT_SIGNED_INT8 = 0x08, + CU_AD_FORMAT_SIGNED_INT16 = 0x09, + CU_AD_FORMAT_SIGNED_INT32 = 0x0a, + CU_AD_FORMAT_HALF = 0x10, + CU_AD_FORMAT_FLOAT = 0x20 + } CUarray_format; + * \endcode + * + * - \p NumChannels specifies the number of packed components per CUDA array + * element; it may be 1, 2, or 4; + * + * - ::Flags may be set to + * - ::CUDA_ARRAY3D_LAYERED to enable creation of layered CUDA arrays. If this flag is set, + * \p Depth specifies the number of layers, not the depth of a 3D array. + * - ::CUDA_ARRAY3D_SURFACE_LDST to enable surface references to be bound to the CUDA array. + * If this flag is not set, ::cuSurfRefSetArray will fail when attempting to bind the CUDA array + * to a surface reference. + * - ::CUDA_ARRAY3D_CUBEMAP to enable creation of cubemaps. If this flag is set, \p Width must be + * equal to \p Height, and \p Depth must be six. If the ::CUDA_ARRAY3D_LAYERED flag is also set, + * then \p Depth must be a multiple of six. + * - ::CUDA_ARRAY3D_TEXTURE_GATHER to indicate that the CUDA array will be used for texture gather. + * Texture gather can only be performed on 2D CUDA arrays. + * + * \p Width, \p Height and \p Depth must meet certain size requirements as listed in the following table. + * All values are specified in elements. Note that for brevity's sake, the full name of the device attribute + * is not specified. For ex., TEXTURE1D_WIDTH refers to the device attribute + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_WIDTH. + * + * Note that 2D CUDA arrays have different size requirements if the ::CUDA_ARRAY3D_TEXTURE_GATHER flag + * is set. \p Width and \p Height must not be greater than ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_GATHER_WIDTH + * and ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_GATHER_HEIGHT respectively, in that case. + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + *
    CUDA array typeValid extents that must always be met
    {(width range in elements), (height range), + * (depth range)}
    Valid extents with CUDA_ARRAY3D_SURFACE_LDST set
    + * {(width range in elements), (height range), (depth range)}
    1D{ (1,TEXTURE1D_WIDTH), 0, 0 }{ (1,SURFACE1D_WIDTH), 0, 0 }
    2D{ (1,TEXTURE2D_WIDTH), (1,TEXTURE2D_HEIGHT), 0 }{ (1,SURFACE2D_WIDTH), (1,SURFACE2D_HEIGHT), 0 }
    3D{ (1,TEXTURE3D_WIDTH), (1,TEXTURE3D_HEIGHT), (1,TEXTURE3D_DEPTH) } + *
    OR
    { (1,TEXTURE3D_WIDTH_ALTERNATE), (1,TEXTURE3D_HEIGHT_ALTERNATE), + * (1,TEXTURE3D_DEPTH_ALTERNATE) }
    { (1,SURFACE3D_WIDTH), (1,SURFACE3D_HEIGHT), + * (1,SURFACE3D_DEPTH) }
    1D Layered{ (1,TEXTURE1D_LAYERED_WIDTH), 0, + * (1,TEXTURE1D_LAYERED_LAYERS) }{ (1,SURFACE1D_LAYERED_WIDTH), 0, + * (1,SURFACE1D_LAYERED_LAYERS) }
    2D Layered{ (1,TEXTURE2D_LAYERED_WIDTH), (1,TEXTURE2D_LAYERED_HEIGHT), + * (1,TEXTURE2D_LAYERED_LAYERS) }{ (1,SURFACE2D_LAYERED_WIDTH), (1,SURFACE2D_LAYERED_HEIGHT), + * (1,SURFACE2D_LAYERED_LAYERS) }
    Cubemap{ (1,TEXTURECUBEMAP_WIDTH), (1,TEXTURECUBEMAP_WIDTH), 6 }{ (1,SURFACECUBEMAP_WIDTH), + * (1,SURFACECUBEMAP_WIDTH), 6 }
    Cubemap Layered{ (1,TEXTURECUBEMAP_LAYERED_WIDTH), (1,TEXTURECUBEMAP_LAYERED_WIDTH), + * (1,TEXTURECUBEMAP_LAYERED_LAYERS) }{ (1,SURFACECUBEMAP_LAYERED_WIDTH), (1,SURFACECUBEMAP_LAYERED_WIDTH), + * (1,SURFACECUBEMAP_LAYERED_LAYERS) }
    + * + * Here are examples of CUDA array descriptions: + * + * Description for a CUDA array of 2048 floats: + * \code + CUDA_ARRAY3D_DESCRIPTOR desc; + desc.Format = CU_AD_FORMAT_FLOAT; + desc.NumChannels = 1; + desc.Width = 2048; + desc.Height = 0; + desc.Depth = 0; + * \endcode + * + * Description for a 64 x 64 CUDA array of floats: + * \code + CUDA_ARRAY3D_DESCRIPTOR desc; + desc.Format = CU_AD_FORMAT_FLOAT; + desc.NumChannels = 1; + desc.Width = 64; + desc.Height = 64; + desc.Depth = 0; + * \endcode + * + * Description for a \p width x \p height x \p depth CUDA array of 64-bit, + * 4x16-bit float16's: + * \code + CUDA_ARRAY3D_DESCRIPTOR desc; + desc.Format = CU_AD_FORMAT_HALF; + desc.NumChannels = 4; + desc.Width = width; + desc.Height = height; + desc.Depth = depth; + * \endcode + * + * \param pHandle - Returned array + * \param pAllocateArray - 3D array descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuArray3DGetDescriptor, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaMalloc3DArray + */ +CUresult CUDAAPI cuArray3DCreate(CUarray *pHandle, const CUDA_ARRAY3D_DESCRIPTOR *pAllocateArray); + +/** + * \brief Get a 3D CUDA array descriptor + * + * Returns in \p *pArrayDescriptor a descriptor containing information on the + * format and dimensions of the CUDA array \p hArray. It is useful for + * subroutines that have been passed a CUDA array, but need to know the CUDA + * array parameters for validation or other purposes. + * + * This function may be called on 1D and 2D arrays, in which case the \p Height + * and/or \p Depth members of the descriptor struct will be set to 0. + * + * \param pArrayDescriptor - Returned 3D array descriptor + * \param hArray - 3D array to get descriptor of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * \notefnerr + * + * \sa ::cuArray3DCreate, ::cuArrayCreate, + * ::cuArrayDestroy, ::cuArrayGetDescriptor, ::cuMemAlloc, ::cuMemAllocHost, + * ::cuMemAllocPitch, ::cuMemcpy2D, ::cuMemcpy2DAsync, ::cuMemcpy2DUnaligned, + * ::cuMemcpy3D, ::cuMemcpy3DAsync, ::cuMemcpyAtoA, ::cuMemcpyAtoD, + * ::cuMemcpyAtoH, ::cuMemcpyAtoHAsync, ::cuMemcpyDtoA, ::cuMemcpyDtoD, ::cuMemcpyDtoDAsync, + * ::cuMemcpyDtoH, ::cuMemcpyDtoHAsync, ::cuMemcpyHtoA, ::cuMemcpyHtoAAsync, + * ::cuMemcpyHtoD, ::cuMemcpyHtoDAsync, ::cuMemFree, ::cuMemFreeHost, + * ::cuMemGetAddressRange, ::cuMemGetInfo, ::cuMemHostAlloc, + * ::cuMemHostGetDevicePointer, ::cuMemsetD2D8, ::cuMemsetD2D16, + * ::cuMemsetD2D32, ::cuMemsetD8, ::cuMemsetD16, ::cuMemsetD32, + * ::cudaArrayGetInfo + */ +CUresult CUDAAPI cuArray3DGetDescriptor(CUDA_ARRAY3D_DESCRIPTOR *pArrayDescriptor, CUarray hArray); + +/** + * \brief Creates a CUDA mipmapped array + * + * Creates a CUDA mipmapped array according to the ::CUDA_ARRAY3D_DESCRIPTOR structure + * \p pMipmappedArrayDesc and returns a handle to the new CUDA mipmapped array in \p *pHandle. + * \p numMipmapLevels specifies the number of mipmap levels to be allocated. This value is + * clamped to the range [1, 1 + floor(log2(max(width, height, depth)))]. + * + * The ::CUDA_ARRAY3D_DESCRIPTOR is defined as: + * + * \code + typedef struct { + unsigned int Width; + unsigned int Height; + unsigned int Depth; + CUarray_format Format; + unsigned int NumChannels; + unsigned int Flags; + } CUDA_ARRAY3D_DESCRIPTOR; + * \endcode + * where: + * + * - \p Width, \p Height, and \p Depth are the width, height, and depth of the + * CUDA array (in elements); the following types of CUDA arrays can be allocated: + * - A 1D mipmapped array is allocated if \p Height and \p Depth extents are both zero. + * - A 2D mipmapped array is allocated if only \p Depth extent is zero. + * - A 3D mipmapped array is allocated if all three extents are non-zero. + * - A 1D layered CUDA mipmapped array is allocated if only \p Height is zero and the + * ::CUDA_ARRAY3D_LAYERED flag is set. Each layer is a 1D array. The number + * of layers is determined by the depth extent. + * - A 2D layered CUDA mipmapped array is allocated if all three extents are non-zero and + * the ::CUDA_ARRAY3D_LAYERED flag is set. Each layer is a 2D array. The number + * of layers is determined by the depth extent. + * - A cubemap CUDA mipmapped array is allocated if all three extents are non-zero and the + * ::CUDA_ARRAY3D_CUBEMAP flag is set. \p Width must be equal to \p Height, and + * \p Depth must be six. A cubemap is a special type of 2D layered CUDA array, + * where the six layers represent the six faces of a cube. The order of the six + * layers in memory is the same as that listed in ::CUarray_cubemap_face. + * - A cubemap layered CUDA mipmapped array is allocated if all three extents are non-zero, + * and both, ::CUDA_ARRAY3D_CUBEMAP and ::CUDA_ARRAY3D_LAYERED flags are set. + * \p Width must be equal to \p Height, and \p Depth must be a multiple of six. + * A cubemap layered CUDA array is a special type of 2D layered CUDA array that + * consists of a collection of cubemaps. The first six layers represent the first + * cubemap, the next six layers form the second cubemap, and so on. + * + * - ::Format specifies the format of the elements; ::CUarray_format is + * defined as: + * \code + typedef enum CUarray_format_enum { + CU_AD_FORMAT_UNSIGNED_INT8 = 0x01, + CU_AD_FORMAT_UNSIGNED_INT16 = 0x02, + CU_AD_FORMAT_UNSIGNED_INT32 = 0x03, + CU_AD_FORMAT_SIGNED_INT8 = 0x08, + CU_AD_FORMAT_SIGNED_INT16 = 0x09, + CU_AD_FORMAT_SIGNED_INT32 = 0x0a, + CU_AD_FORMAT_HALF = 0x10, + CU_AD_FORMAT_FLOAT = 0x20 + } CUarray_format; + * \endcode + * + * - \p NumChannels specifies the number of packed components per CUDA array + * element; it may be 1, 2, or 4; + * + * - ::Flags may be set to + * - ::CUDA_ARRAY3D_LAYERED to enable creation of layered CUDA mipmapped arrays. If this flag is set, + * \p Depth specifies the number of layers, not the depth of a 3D array. + * - ::CUDA_ARRAY3D_SURFACE_LDST to enable surface references to be bound to individual mipmap levels of + * the CUDA mipmapped array. If this flag is not set, ::cuSurfRefSetArray will fail when attempting to + * bind a mipmap level of the CUDA mipmapped array to a surface reference. + * - ::CUDA_ARRAY3D_CUBEMAP to enable creation of mipmapped cubemaps. If this flag is set, \p Width must be + * equal to \p Height, and \p Depth must be six. If the ::CUDA_ARRAY3D_LAYERED flag is also set, + * then \p Depth must be a multiple of six. + * - ::CUDA_ARRAY3D_TEXTURE_GATHER to indicate that the CUDA mipmapped array will be used for texture gather. + * Texture gather can only be performed on 2D CUDA mipmapped arrays. + * + * \p Width, \p Height and \p Depth must meet certain size requirements as listed in the following table. + * All values are specified in elements. Note that for brevity's sake, the full name of the device attribute + * is not specified. For ex., TEXTURE1D_MIPMAPPED_WIDTH refers to the device attribute + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_MIPMAPPED_WIDTH. + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + *
    CUDA array typeValid extents that must always be met
    {(width range in elements), (height range), + * (depth range)}
    Valid extents with CUDA_ARRAY3D_SURFACE_LDST set
    + * {(width range in elements), (height range), (depth range)}
    1D{ (1,TEXTURE1D_MIPMAPPED_WIDTH), 0, 0 }{ (1,SURFACE1D_WIDTH), 0, 0 }
    2D{ (1,TEXTURE2D_MIPMAPPED_WIDTH), (1,TEXTURE2D_MIPMAPPED_HEIGHT), 0 }{ (1,SURFACE2D_WIDTH), (1,SURFACE2D_HEIGHT), 0 }
    3D{ (1,TEXTURE3D_WIDTH), (1,TEXTURE3D_HEIGHT), (1,TEXTURE3D_DEPTH) } + *
    OR
    { (1,TEXTURE3D_WIDTH_ALTERNATE), (1,TEXTURE3D_HEIGHT_ALTERNATE), + * (1,TEXTURE3D_DEPTH_ALTERNATE) }
    { (1,SURFACE3D_WIDTH), (1,SURFACE3D_HEIGHT), + * (1,SURFACE3D_DEPTH) }
    1D Layered{ (1,TEXTURE1D_LAYERED_WIDTH), 0, + * (1,TEXTURE1D_LAYERED_LAYERS) }{ (1,SURFACE1D_LAYERED_WIDTH), 0, + * (1,SURFACE1D_LAYERED_LAYERS) }
    2D Layered{ (1,TEXTURE2D_LAYERED_WIDTH), (1,TEXTURE2D_LAYERED_HEIGHT), + * (1,TEXTURE2D_LAYERED_LAYERS) }{ (1,SURFACE2D_LAYERED_WIDTH), (1,SURFACE2D_LAYERED_HEIGHT), + * (1,SURFACE2D_LAYERED_LAYERS) }
    Cubemap{ (1,TEXTURECUBEMAP_WIDTH), (1,TEXTURECUBEMAP_WIDTH), 6 }{ (1,SURFACECUBEMAP_WIDTH), + * (1,SURFACECUBEMAP_WIDTH), 6 }
    Cubemap Layered{ (1,TEXTURECUBEMAP_LAYERED_WIDTH), (1,TEXTURECUBEMAP_LAYERED_WIDTH), + * (1,TEXTURECUBEMAP_LAYERED_LAYERS) }{ (1,SURFACECUBEMAP_LAYERED_WIDTH), (1,SURFACECUBEMAP_LAYERED_WIDTH), + * (1,SURFACECUBEMAP_LAYERED_LAYERS) }
    + * + * + * \param pHandle - Returned mipmapped array + * \param pMipmappedArrayDesc - mipmapped array descriptor + * \param numMipmapLevels - Number of mipmap levels + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cuMipmappedArrayDestroy, + * ::cuMipmappedArrayGetLevel, + * ::cuArrayCreate, + * ::cudaMallocMipmappedArray + */ +CUresult CUDAAPI cuMipmappedArrayCreate(CUmipmappedArray *pHandle, const CUDA_ARRAY3D_DESCRIPTOR *pMipmappedArrayDesc, unsigned int numMipmapLevels); + +/** + * \brief Gets a mipmap level of a CUDA mipmapped array + * + * Returns in \p *pLevelArray a CUDA array that represents a single mipmap level + * of the CUDA mipmapped array \p hMipmappedArray. + * + * If \p level is greater than the maximum number of levels in this mipmapped array, + * ::CUDA_ERROR_INVALID_VALUE is returned. + * + * \param pLevelArray - Returned mipmap level CUDA array + * \param hMipmappedArray - CUDA mipmapped array + * \param level - Mipmap level + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa + * ::cuMipmappedArrayCreate, + * ::cuMipmappedArrayDestroy, + * ::cuArrayCreate, + * ::cudaGetMipmappedArrayLevel + */ +CUresult CUDAAPI cuMipmappedArrayGetLevel(CUarray *pLevelArray, CUmipmappedArray hMipmappedArray, unsigned int level); + +/** + * \brief Destroys a CUDA mipmapped array + * + * Destroys the CUDA mipmapped array \p hMipmappedArray. + * + * \param hMipmappedArray - Mipmapped array to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_ARRAY_IS_MAPPED, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * \notefnerr + * + * \sa + * ::cuMipmappedArrayCreate, + * ::cuMipmappedArrayGetLevel, + * ::cuArrayCreate, + * ::cudaFreeMipmappedArray + */ +CUresult CUDAAPI cuMipmappedArrayDestroy(CUmipmappedArray hMipmappedArray); + +/** +* \brief Retrieve handle for an address range +* +* Get a handle of the specified type to an address range. The address range +* must have been obtained by a prior call to either ::cuMemAlloc or ::cuMemAddressReserve. +* If the address range was obtained via ::cuMemAddressReserve, it must also be fully mapped via ::cuMemMap. +* The address range must have been obtained by a prior call to either ::cuMemAllocHost or +* ::cuMemHostAlloc on Tegra. +* +* Users must ensure the \p dptr and \p size are aligned to the host page size. +* +* When requesting CUmemRangeHandleType::CU_MEM_RANGE_HANDLE_TYPE_DMA_BUF_FD, +* users are expected to query for dma_buf support for the platform +* by using ::CU_DEVICE_ATTRIBUTE_DMA_BUF_SUPPORTED device attribute before calling +* this API. The \p handle will be interpreted as a pointer to an integer to store the dma_buf file descriptor. +* Users must ensure the entire address range is backed and mapped when +* the address range is allocated by ::cuMemAddressReserve. All the physical +* allocations backing the address range must be resident on the same device and +* have identical allocation properties. Users are also expected to retrieve a +* new handle every time the underlying physical allocation(s) corresponding +* to a previously queried VA range are changed. +* +* \param[out] handle - Pointer to the location where the returned handle will be stored. +* \param[in] dptr - Pointer to a valid CUDA device allocation. Must be aligned to host page size. +* \param[in] size - Length of the address range. Must be aligned to host page size. +* \param[in] handleType - Type of handle requested (defines type and size of the \p handle output parameter) +* \param[in] flags - Reserved, must be zero +* +* \return +* CUDA_SUCCESS +* CUDA_ERROR_INVALID_VALUE +* CUDA_ERROR_NOT_SUPPORTED +*/ +CUresult CUDAAPI cuMemGetHandleForAddressRange(void *handle, CUdeviceptr dptr, size_t size, CUmemRangeHandleType handleType, unsigned long long flags); + +/** @} */ /* END CUDA_MEM */ + +/** + * \defgroup CUDA_VA Virtual Memory Management + * + * ___MANBRIEF___ virtual memory management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the virtual memory management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** +* \brief Allocate an address range reservation. +* +* Reserves a virtual address range based on the given parameters, giving +* the starting address of the range in \p ptr. This API requires a system that +* supports UVA. The size and address parameters must be a multiple of the +* host page size and the alignment must be a power of two or zero for default +* alignment. +* +* \param[out] ptr - Resulting pointer to start of virtual address range allocated +* \param[in] size - Size of the reserved virtual address range requested +* \param[in] alignment - Alignment of the reserved virtual address range requested +* \param[in] addr - Fixed starting address range requested +* \param[in] flags - Currently unused, must be zero +* \return +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_OUT_OF_MEMORY, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemAddressFree +*/ +CUresult CUDAAPI cuMemAddressReserve(CUdeviceptr *ptr, size_t size, size_t alignment, CUdeviceptr addr, unsigned long long flags); + +/** +* \brief Free an address range reservation. +* +* Frees a virtual address range reserved by cuMemAddressReserve. The size +* must match what was given to memAddressReserve and the ptr given must +* match what was returned from memAddressReserve. +* +* \param[in] ptr - Starting address of the virtual address range to free +* \param[in] size - Size of the virtual address region to free +* \return +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemAddressReserve +*/ +CUresult CUDAAPI cuMemAddressFree(CUdeviceptr ptr, size_t size); + +/** +* \brief Create a CUDA memory handle representing a memory allocation of a given size described by the given properties +* +* This creates a memory allocation on the target device specified through the +* \p prop structure. The created allocation will not have any device or host +* mappings. The generic memory \p handle for the allocation can be +* mapped to the address space of calling process via ::cuMemMap. This handle +* cannot be transmitted directly to other processes (see +* ::cuMemExportToShareableHandle). On Windows, the caller must also pass +* an LPSECURITYATTRIBUTE in \p prop to be associated with this handle which +* limits or allows access to this handle for a recipient process (see +* ::CUmemAllocationProp::win32HandleMetaData for more). The \p size of this +* allocation must be a multiple of the the value given via +* ::cuMemGetAllocationGranularity with the ::CU_MEM_ALLOC_GRANULARITY_MINIMUM +* flag. +* To create a CPU allocation targeting a specific host NUMA node, applications must +* set ::CUmemAllocationProp::CUmemLocation::type to ::CU_MEM_LOCATION_TYPE_HOST_NUMA and +* ::CUmemAllocationProp::CUmemLocation::id must specify the NUMA ID of the CPU. +* On systems where NUMA is not available ::CUmemAllocationProp::CUmemLocation::id must be set to 0. +* Specifying ::CU_MEM_LOCATION_TYPE_HOST_NUMA_CURRENT or ::CU_MEM_LOCATION_TYPE_HOST as the +* ::CUmemLocation::type will result in ::CUDA_ERROR_INVALID_VALUE. +* +* Applications can set ::CUmemAllocationProp::requestedHandleTypes to +* ::CU_MEM_HANDLE_TYPE_FABRIC in order to create allocations suitable for sharing +* within an IMEX domain. An IMEX domain is either an OS instance or a group of securely +* connected OS instances using the NVIDIA IMEX daemon. An IMEX channel is a global resource +* within the IMEX domain that represents a logical entity that aims to provide fine grained +* accessibility control for the participating processes. When exporter and importer CUDA processes +* have been granted access to the same IMEX channel, they can securely share memory. +* If the allocating process does not have access setup for an IMEX channel, attempting to create +* a ::CUmemGenericAllocationHandle with ::CU_MEM_HANDLE_TYPE_FABRIC will result in ::CUDA_ERROR_NOT_PERMITTED. +* The nvidia-modprobe CLI provides more information regarding setting up of IMEX channels. +* +* If ::CUmemAllocationProp::allocFlags::usage contains ::CU_MEM_CREATE_USAGE_TILE_POOL flag then +* the memory allocation is intended only to be used as backing tile pool for sparse CUDA arrays +* and sparse CUDA mipmapped arrays. +* (see ::cuMemMapArrayAsync). +* +* \param[out] handle - Value of handle returned. All operations on this allocation are to be performed using this handle. +* \param[in] size - Size of the allocation requested +* \param[in] prop - Properties of the allocation to create. +* \param[in] flags - flags for future use, must be zero now. +* \return +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_OUT_OF_MEMORY, +* ::CUDA_ERROR_INVALID_DEVICE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* \notefnerr +* +* \sa ::cuMemRelease, ::cuMemExportToShareableHandle, ::cuMemImportFromShareableHandle +*/ +CUresult CUDAAPI cuMemCreate(CUmemGenericAllocationHandle *handle, size_t size, const CUmemAllocationProp *prop, unsigned long long flags); + +/** +* \brief Release a memory handle representing a memory allocation which was previously allocated through cuMemCreate. +* +* Frees the memory that was allocated on a device through cuMemCreate. +* +* The memory allocation will be freed when all outstanding mappings to the memory +* are unmapped and when all outstanding references to the handle (including it's +* shareable counterparts) are also released. The generic memory handle can be +* freed when there are still outstanding mappings made with this handle. Each +* time a recipient process imports a shareable handle, it needs to pair it with +* ::cuMemRelease for the handle to be freed. If \p handle is not a valid handle +* the behavior is undefined. +* +* \param[in] handle Value of handle which was returned previously by cuMemCreate. +* \return +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* \notefnerr +* +* \sa ::cuMemCreate +*/ +CUresult CUDAAPI cuMemRelease(CUmemGenericAllocationHandle handle); + +/** +* \brief Maps an allocation handle to a reserved virtual address range. +* +* Maps bytes of memory represented by \p handle starting from byte \p offset to +* \p size to address range [\p addr, \p addr + \p size]. This range must be an +* address reservation previously reserved with ::cuMemAddressReserve, and +* \p offset + \p size must be less than the size of the memory allocation. +* Both \p ptr, \p size, and \p offset must be a multiple of the value given via +* ::cuMemGetAllocationGranularity with the ::CU_MEM_ALLOC_GRANULARITY_MINIMUM flag. +* If \p handle represents a multicast object, \p ptr, \p size and \p offset must +* be aligned to the value returned by ::cuMulticastGetGranularity with the flag +* ::CU_MULTICAST_MINIMUM_GRANULARITY. For best performance however, it is +* recommended that \p ptr, \p size and \p offset be aligned to the value +* returned by ::cuMulticastGetGranularity with the flag +* ::CU_MULTICAST_RECOMMENDED_GRANULARITY. +* +* Please note calling ::cuMemMap does not make the address accessible, +* the caller needs to update accessibility of a contiguous mapped VA +* range by calling ::cuMemSetAccess. +* +* Once a recipient process obtains a shareable memory handle +* from ::cuMemImportFromShareableHandle, the process must +* use ::cuMemMap to map the memory into its address ranges before +* setting accessibility with ::cuMemSetAccess. +* +* ::cuMemMap can only create mappings on VA range reservations +* that are not currently mapped. +* +* \param[in] ptr - Address where memory will be mapped. +* \param[in] size - Size of the memory mapping. +* \param[in] offset - Offset into the memory represented by +* - \p handle from which to start mapping +* - Note: currently must be zero. +* \param[in] handle - Handle to a shareable memory +* \param[in] flags - flags for future use, must be zero now. +* \return +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_INVALID_DEVICE, +* ::CUDA_ERROR_OUT_OF_MEMORY, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* \notefnerr +* +* \sa ::cuMemUnmap, ::cuMemSetAccess, ::cuMemCreate, ::cuMemAddressReserve, ::cuMemImportFromShareableHandle +*/ +CUresult CUDAAPI cuMemMap(CUdeviceptr ptr, size_t size, size_t offset, CUmemGenericAllocationHandle handle, unsigned long long flags); + +/** + * \brief Maps or unmaps subregions of sparse CUDA arrays and sparse CUDA mipmapped arrays + * + * Performs map or unmap operations on subregions of sparse CUDA arrays and sparse CUDA mipmapped arrays. + * Each operation is specified by a ::CUarrayMapInfo entry in the \p mapInfoList array of size \p count. + * The structure ::CUarrayMapInfo is defined as follow: + \code + typedef struct CUarrayMapInfo_st { + CUresourcetype resourceType; + union { + CUmipmappedArray mipmap; + CUarray array; + } resource; + + CUarraySparseSubresourceType subresourceType; + union { + struct { + unsigned int level; + unsigned int layer; + unsigned int offsetX; + unsigned int offsetY; + unsigned int offsetZ; + unsigned int extentWidth; + unsigned int extentHeight; + unsigned int extentDepth; + } sparseLevel; + struct { + unsigned int layer; + unsigned long long offset; + unsigned long long size; + } miptail; + } subresource; + + CUmemOperationType memOperationType; + + CUmemHandleType memHandleType; + union { + CUmemGenericAllocationHandle memHandle; + } memHandle; + + unsigned long long offset; + unsigned int deviceBitMask; + unsigned int flags; + unsigned int reserved[2]; + } CUarrayMapInfo; + \endcode + * + * where ::CUarrayMapInfo::resourceType specifies the type of resource to be operated on. + * If ::CUarrayMapInfo::resourceType is set to ::CUresourcetype::CU_RESOURCE_TYPE_ARRAY then + * ::CUarrayMapInfo::resource::array must be set to a valid sparse CUDA array handle. + * The CUDA array must be either a 2D, 2D layered or 3D CUDA array and must have been allocated using + * ::cuArrayCreate or ::cuArray3DCreate with the flag ::CUDA_ARRAY3D_SPARSE + * or ::CUDA_ARRAY3D_DEFERRED_MAPPING. + * For CUDA arrays obtained using ::cuMipmappedArrayGetLevel, ::CUDA_ERROR_INVALID_VALUE will be returned. + * If ::CUarrayMapInfo::resourceType is set to ::CUresourcetype::CU_RESOURCE_TYPE_MIPMAPPED_ARRAY + * then ::CUarrayMapInfo::resource::mipmap must be set to a valid sparse CUDA mipmapped array handle. + * The CUDA mipmapped array must be either a 2D, 2D layered or 3D CUDA mipmapped array and must have been + * allocated using ::cuMipmappedArrayCreate with the flag ::CUDA_ARRAY3D_SPARSE + * or ::CUDA_ARRAY3D_DEFERRED_MAPPING. + * + * ::CUarrayMapInfo::subresourceType specifies the type of subresource within the resource. + * ::CUarraySparseSubresourceType_enum is defined as: + \code + typedef enum CUarraySparseSubresourceType_enum { + CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_SPARSE_LEVEL = 0, + CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_MIPTAIL = 1 + } CUarraySparseSubresourceType; + \endcode + * + * where ::CUarraySparseSubresourceType::CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_SPARSE_LEVEL indicates a + * sparse-miplevel which spans at least one tile in every dimension. The remaining miplevels which + * are too small to span at least one tile in any dimension constitute the mip tail region as indicated by + * ::CUarraySparseSubresourceType::CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_MIPTAIL subresource type. + * + * If ::CUarrayMapInfo::subresourceType is set to ::CUarraySparseSubresourceType::CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_SPARSE_LEVEL + * then ::CUarrayMapInfo::subresource::sparseLevel struct must contain valid array subregion offsets and extents. + * The ::CUarrayMapInfo::subresource::sparseLevel::offsetX, ::CUarrayMapInfo::subresource::sparseLevel::offsetY + * and ::CUarrayMapInfo::subresource::sparseLevel::offsetZ must specify valid X, Y and Z offsets respectively. + * The ::CUarrayMapInfo::subresource::sparseLevel::extentWidth, ::CUarrayMapInfo::subresource::sparseLevel::extentHeight + * and ::CUarrayMapInfo::subresource::sparseLevel::extentDepth must specify valid width, height and depth extents respectively. + * These offsets and extents must be aligned to the corresponding tile dimension. + * For CUDA mipmapped arrays ::CUarrayMapInfo::subresource::sparseLevel::level must specify a valid mip level index. Otherwise, + * must be zero. + * For layered CUDA arrays and layered CUDA mipmapped arrays ::CUarrayMapInfo::subresource::sparseLevel::layer must specify a valid layer index. Otherwise, + * must be zero. + * ::CUarrayMapInfo::subresource::sparseLevel::offsetZ must be zero and ::CUarrayMapInfo::subresource::sparseLevel::extentDepth + * must be set to 1 for 2D and 2D layered CUDA arrays and CUDA mipmapped arrays. + * Tile extents can be obtained by calling ::cuArrayGetSparseProperties and ::cuMipmappedArrayGetSparseProperties + * + * If ::CUarrayMapInfo::subresourceType is set to ::CUarraySparseSubresourceType::CU_ARRAY_SPARSE_SUBRESOURCE_TYPE_MIPTAIL + * then ::CUarrayMapInfo::subresource::miptail struct must contain valid mip tail offset in + * ::CUarrayMapInfo::subresource::miptail::offset and size in ::CUarrayMapInfo::subresource::miptail::size. + * Both, mip tail offset and mip tail size must be aligned to the tile size. + * For layered CUDA mipmapped arrays which don't have the flag ::CU_ARRAY_SPARSE_PROPERTIES_SINGLE_MIPTAIL set in ::CUDA_ARRAY_SPARSE_PROPERTIES::flags + * as returned by ::cuMipmappedArrayGetSparseProperties, ::CUarrayMapInfo::subresource::miptail::layer must specify a valid layer index. + * Otherwise, must be zero. + * + * If ::CUarrayMapInfo::resource::array or ::CUarrayMapInfo::resource::mipmap was created with ::CUDA_ARRAY3D_DEFERRED_MAPPING + * flag set the ::CUarrayMapInfo::subresourceType and the contents of ::CUarrayMapInfo::subresource will be ignored. + * + * ::CUarrayMapInfo::memOperationType specifies the type of operation. ::CUmemOperationType is defined as: + \code + typedef enum CUmemOperationType_enum { + CU_MEM_OPERATION_TYPE_MAP = 1, + CU_MEM_OPERATION_TYPE_UNMAP = 2 + } CUmemOperationType; + \endcode + * If ::CUarrayMapInfo::memOperationType is set to ::CUmemOperationType::CU_MEM_OPERATION_TYPE_MAP then the subresource + * will be mapped onto the tile pool memory specified by ::CUarrayMapInfo::memHandle at offset ::CUarrayMapInfo::offset. + * The tile pool allocation has to be created by specifying the ::CU_MEM_CREATE_USAGE_TILE_POOL flag when calling ::cuMemCreate. Also, + * ::CUarrayMapInfo::memHandleType must be set to ::CUmemHandleType::CU_MEM_HANDLE_TYPE_GENERIC. + * + * If ::CUarrayMapInfo::memOperationType is set to ::CUmemOperationType::CU_MEM_OPERATION_TYPE_UNMAP then an unmapping operation + * is performed. ::CUarrayMapInfo::memHandle must be NULL. + * + * ::CUarrayMapInfo::deviceBitMask specifies the list of devices that must map or unmap physical memory. + * Currently, this mask must have exactly one bit set, and the corresponding device must match the device associated with the stream. + * If ::CUarrayMapInfo::memOperationType is set to ::CUmemOperationType::CU_MEM_OPERATION_TYPE_MAP, the device must also match + * the device associated with the tile pool memory allocation as specified by ::CUarrayMapInfo::memHandle. + * + * ::CUarrayMapInfo::flags and ::CUarrayMapInfo::reserved[] are unused and must be set to zero. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * + * \param[in] mapInfoList - List of ::CUarrayMapInfo + * \param[in] count - Count of ::CUarrayMapInfo in \p mapInfoList + * \param[in] hStream - Stream identifier for the stream to use for map or unmap operations + * + * \sa ::cuMipmappedArrayCreate, ::cuArrayCreate, ::cuArray3DCreate, ::cuMemCreate, ::cuArrayGetSparseProperties, ::cuMipmappedArrayGetSparseProperties + */ +CUresult CUDAAPI cuMemMapArrayAsync(CUarrayMapInfo *mapInfoList, unsigned int count, CUstream hStream); + +/** +* \brief Unmap the backing memory of a given address range. +* +* The range must be the entire contiguous address range that was mapped to. In +* other words, ::cuMemUnmap cannot unmap a sub-range of an address range mapped +* by ::cuMemCreate / ::cuMemMap. Any backing memory allocations will be freed +* if there are no existing mappings and there are no unreleased memory handles. +* +* When ::cuMemUnmap returns successfully the address range is converted to an +* address reservation and can be used for a future calls to ::cuMemMap. Any new +* mapping to this virtual address will need to have access granted through +* ::cuMemSetAccess, as all mappings start with no accessibility setup. +* +* \param[in] ptr - Starting address for the virtual address range to unmap +* \param[in] size - Size of the virtual address range to unmap +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* \notefnerr +* \note_sync +* +* \sa ::cuMemCreate, ::cuMemAddressReserve +*/ +CUresult CUDAAPI cuMemUnmap(CUdeviceptr ptr, size_t size); + +/** +* \brief Set the access flags for each location specified in \p desc for the given virtual address range +* +* Given the virtual address range via \p ptr and \p size, and the locations +* in the array given by \p desc and \p count, set the access flags for the +* target locations. The range must be a fully mapped address range +* containing all allocations created by ::cuMemMap / ::cuMemCreate. +* Users cannot specify ::CU_MEM_LOCATION_TYPE_HOST_NUMA accessibility for allocations created on with other location types. +* Note: When ::CUmemAccessDesc::CUmemLocation::type is ::CU_MEM_LOCATION_TYPE_HOST_NUMA, ::CUmemAccessDesc::CUmemLocation::id +* is ignored. +* When setting the access flags for a virtual address range mapping a multicast +* object, \p ptr and \p size must be aligned to the value returned by +* ::cuMulticastGetGranularity with the flag ::CU_MULTICAST_MINIMUM_GRANULARITY. +* For best performance however, it is recommended that \p ptr and \p size be +* aligned to the value returned by ::cuMulticastGetGranularity with the flag +* ::CU_MULTICAST_RECOMMENDED_GRANULARITY. +* +* \param[in] ptr - Starting address for the virtual address range +* \param[in] size - Length of the virtual address range +* \param[in] desc - Array of ::CUmemAccessDesc that describe how to change the +* - mapping for each location specified +* \param[in] count - Number of ::CUmemAccessDesc in \p desc +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_INVALID_DEVICE, +* ::CUDA_ERROR_NOT_SUPPORTED +* \notefnerr +* \note_sync +* +* \sa ::cuMemSetAccess, ::cuMemCreate, :cuMemMap +*/ +CUresult CUDAAPI cuMemSetAccess(CUdeviceptr ptr, size_t size, const CUmemAccessDesc *desc, size_t count); + +/** +* \brief Get the access \p flags set for the given \p location and \p ptr +* +* \param[out] flags - Flags set for this location +* \param[in] location - Location in which to check the flags for +* \param[in] ptr - Address in which to check the access flags for +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_INVALID_DEVICE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemSetAccess +*/ +CUresult CUDAAPI cuMemGetAccess(unsigned long long *flags, const CUmemLocation *location, CUdeviceptr ptr); + +/** +* \brief Exports an allocation to a requested shareable handle type +* +* Given a CUDA memory handle, create a shareable memory +* allocation handle that can be used to share the memory with other +* processes. The recipient process can convert the shareable handle back into a +* CUDA memory handle using ::cuMemImportFromShareableHandle and map +* it with ::cuMemMap. The implementation of what this handle is and how it +* can be transferred is defined by the requested handle type in \p handleType +* +* Once all shareable handles are closed and the allocation is released, the allocated +* memory referenced will be released back to the OS and uses of the CUDA handle afterward +* will lead to undefined behavior. +* +* This API can also be used in conjunction with other APIs (e.g. Vulkan, OpenGL) +* that support importing memory from the shareable type +* +* \param[out] shareableHandle - Pointer to the location in which to store the requested handle type +* \param[in] handle - CUDA handle for the memory allocation +* \param[in] handleType - Type of shareable handle requested (defines type and size of the \p shareableHandle output parameter) +* \param[in] flags - Reserved, must be zero +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemImportFromShareableHandle +*/ +CUresult CUDAAPI cuMemExportToShareableHandle(void *shareableHandle, CUmemGenericAllocationHandle handle, CUmemAllocationHandleType handleType, unsigned long long flags); + +/** +* \brief Imports an allocation from a requested shareable handle type. +* +* If the current process cannot support the memory described by this shareable +* handle, this API will error as ::CUDA_ERROR_NOT_SUPPORTED. +* +* If \p shHandleType is ::CU_MEM_HANDLE_TYPE_FABRIC and the importer process has not been +* granted access to the same IMEX channel as the exporter process, this API will error +* as ::CUDA_ERROR_NOT_PERMITTED. +* +* \note Importing shareable handles exported from some graphics APIs(VUlkan, OpenGL, etc) +* created on devices under an SLI group may not be supported, and thus this API will +* return CUDA_ERROR_NOT_SUPPORTED. +* There is no guarantee that the contents of \p handle will be the same CUDA memory handle +* for the same given OS shareable handle, or the same underlying allocation. +* +* \param[out] handle - CUDA Memory handle for the memory allocation. +* \param[in] osHandle - Shareable Handle representing the memory allocation that is to be imported. +* \param[in] shHandleType - handle type of the exported handle ::CUmemAllocationHandleType. +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemExportToShareableHandle, ::cuMemMap, ::cuMemRelease +*/ +CUresult CUDAAPI cuMemImportFromShareableHandle(CUmemGenericAllocationHandle *handle, void *osHandle, CUmemAllocationHandleType shHandleType); + +/** +* \brief Calculates either the minimal or recommended granularity +* +* Calculates either the minimal or recommended granularity +* for a given allocation specification and returns it in granularity. This +* granularity can be used as a multiple for alignment, size, or address mapping. +* +* \param[out] granularity Returned granularity. +* \param[in] prop Property for which to determine the granularity for +* \param[in] option Determines which granularity to return +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemCreate, ::cuMemMap +*/ +CUresult CUDAAPI cuMemGetAllocationGranularity(size_t *granularity, const CUmemAllocationProp *prop, CUmemAllocationGranularity_flags option); + +/** +* \brief Retrieve the contents of the property structure defining properties for this handle +* +* \param[out] prop - Pointer to a properties structure which will hold the information about this handle +* \param[in] handle - Handle which to perform the query on +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemCreate, ::cuMemImportFromShareableHandle +*/ +CUresult CUDAAPI cuMemGetAllocationPropertiesFromHandle(CUmemAllocationProp *prop, CUmemGenericAllocationHandle handle); + +/** +* \brief Given an address \p addr, returns the allocation handle of the backing memory allocation. +* +* The handle is guaranteed to be the same handle value used to map the memory. If the address +* requested is not mapped, the function will fail. The returned handle must be released with +* corresponding number of calls to ::cuMemRelease. +* +* \note The address \p addr, can be any address in a range previously mapped +* by ::cuMemMap, and not necessarily the start address. +* +* \param[out] handle CUDA Memory handle for the backing memory allocation. +* \param[in] addr Memory address to query, that has been mapped previously. +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMemCreate, ::cuMemRelease, ::cuMemMap +*/ +CUresult CUDAAPI cuMemRetainAllocationHandle(CUmemGenericAllocationHandle *handle, void *addr); + +/** @} */ /* END CUDA_VA */ + +/** + * \defgroup CUDA_MALLOC_ASYNC Stream Ordered Memory Allocator + * + * ___MANBRIEF___ Functions for performing allocation and free operations in stream order. + * Functions for controlling the behavior of the underlying allocator. + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the stream ordered memory allocator exposed by the + * low-level CUDA driver application programming interface. + * + * @{ + * + * \section CUDA_MALLOC_ASYNC_overview overview + * + * The asynchronous allocator allows the user to allocate and free in stream order. + * All asynchronous accesses of the allocation must happen between + * the stream executions of the allocation and the free. If the memory is accessed + * outside of the promised stream order, a use before allocation / use after free error + * will cause undefined behavior. + * + * The allocator is free to reallocate the memory as long as it can guarantee + * that compliant memory accesses will not overlap temporally. + * The allocator may refer to internal stream ordering as well as inter-stream dependencies + * (such as CUDA events and null stream dependencies) when establishing the temporal guarantee. + * The allocator may also insert inter-stream dependencies to establish the temporal guarantee. + * + * \section CUDA_MALLOC_ASYNC_support Supported Platforms + * + * Whether or not a device supports the integrated stream ordered memory allocator + * may be queried by calling ::cuDeviceGetAttribute() with the device attribute + * ::CU_DEVICE_ATTRIBUTE_MEMORY_POOLS_SUPPORTED + */ + +/** + * \brief Frees memory with stream ordered semantics + * + * Inserts a free operation into \p hStream. + * The allocation must not be accessed after stream execution reaches the free. + * After this API returns, accessing the memory from any subsequent work launched on the GPU + * or querying its pointer attributes results in undefined behavior. + * + * \note During stream capture, this function results in the creation of a free node and + * must therefore be passed the address of a graph allocation. + * + * \param dptr - memory to free + * \param hStream - The stream establishing the stream ordering contract. + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT (default stream specified with no current context), + * ::CUDA_ERROR_NOT_SUPPORTED + */ +CUresult CUDAAPI cuMemFreeAsync(CUdeviceptr dptr, CUstream hStream); + +/** + * \brief Allocates memory with stream ordered semantics + * + * Inserts an allocation operation into \p hStream. + * A pointer to the allocated memory is returned immediately in *dptr. + * The allocation must not be accessed until the the allocation operation completes. + * The allocation comes from the memory pool current to the stream's device. + * + * \note The default memory pool of a device contains device memory from that device. + * \note Basic stream ordering allows future work submitted into the same stream to use the allocation. + * Stream query, stream synchronize, and CUDA events can be used to guarantee that the allocation + * operation completes before work submitted in a separate stream runs. + * \note During stream capture, this function results in the creation of an allocation node. In this case, + * the allocation is owned by the graph instead of the memory pool. The memory pool's properties + * are used to set the node's creation parameters. + * + * \param[out] dptr - Returned device pointer + * \param[in] bytesize - Number of bytes to allocate + * \param[in] hStream - The stream establishing the stream ordering contract and the memory pool to allocate from + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT (default stream specified with no current context), + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuMemAllocFromPoolAsync, ::cuMemFreeAsync, ::cuDeviceSetMemPool, + * ::cuDeviceGetDefaultMemPool, ::cuDeviceGetMemPool, ::cuMemPoolCreate, + * ::cuMemPoolSetAccess, ::cuMemPoolSetAttribute + */ +CUresult CUDAAPI cuMemAllocAsync(CUdeviceptr *dptr, size_t bytesize, CUstream hStream); + +/** + * \brief Tries to release memory back to the OS + * + * Releases memory back to the OS until the pool contains fewer than minBytesToKeep + * reserved bytes, or there is no more memory that the allocator can safely release. + * The allocator cannot release OS allocations that back outstanding asynchronous allocations. + * The OS allocations may happen at different granularity from the user allocations. + * + * \note: Allocations that have not been freed count as outstanding. + * \note: Allocations that have been asynchronously freed but whose completion has + * not been observed on the host (eg. by a synchronize) can count as outstanding. + * + * \param[in] pool - The memory pool to trim + * \param[in] minBytesToKeep - If the pool has less than minBytesToKeep reserved, + * the TrimTo operation is a no-op. Otherwise the pool will be guaranteed to have + * at least minBytesToKeep bytes reserved after the operation. + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuMemAllocAsync, ::cuMemFreeAsync, ::cuDeviceGetDefaultMemPool, + * ::cuDeviceGetMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuMemPoolTrimTo(CUmemoryPool pool, size_t minBytesToKeep); + +/** + * \brief Sets attributes of a memory pool + * + * Supported attributes are: + * - ::CU_MEMPOOL_ATTR_RELEASE_THRESHOLD: (value type = cuuint64_t) + * Amount of reserved memory in bytes to hold onto before trying + * to release memory back to the OS. When more than the release + * threshold bytes of memory are held by the memory pool, the + * allocator will try to release memory back to the OS on the + * next call to stream, event or context synchronize. (default 0) + * - ::CU_MEMPOOL_ATTR_REUSE_FOLLOW_EVENT_DEPENDENCIES: (value type = int) + * Allow ::cuMemAllocAsync to use memory asynchronously freed + * in another stream as long as a stream ordering dependency + * of the allocating stream on the free action exists. + * Cuda events and null stream interactions can create the required + * stream ordered dependencies. (default enabled) + * - ::CU_MEMPOOL_ATTR_REUSE_ALLOW_OPPORTUNISTIC: (value type = int) + * Allow reuse of already completed frees when there is no dependency + * between the free and allocation. (default enabled) + * - ::CU_MEMPOOL_ATTR_REUSE_ALLOW_INTERNAL_DEPENDENCIES: (value type = int) + * Allow ::cuMemAllocAsync to insert new stream dependencies + * in order to establish the stream ordering required to reuse + * a piece of memory released by ::cuMemFreeAsync (default enabled). + * - ::CU_MEMPOOL_ATTR_RESERVED_MEM_HIGH: (value type = cuuint64_t) + * Reset the high watermark that tracks the amount of backing memory that was + * allocated for the memory pool. It is illegal to set this attribute to a non-zero value. + * - ::CU_MEMPOOL_ATTR_USED_MEM_HIGH: (value type = cuuint64_t) + * Reset the high watermark that tracks the amount of used memory that was + * allocated for the memory pool. + * + * \param[in] pool - The memory pool to modify + * \param[in] attr - The attribute to modify + * \param[in] value - Pointer to the value to assign + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuMemAllocAsync, ::cuMemFreeAsync, ::cuDeviceGetDefaultMemPool, + * ::cuDeviceGetMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuMemPoolSetAttribute(CUmemoryPool pool, CUmemPool_attribute attr, void *value); + +/** + * \brief Gets attributes of a memory pool + * + * Supported attributes are: + * - ::CU_MEMPOOL_ATTR_RELEASE_THRESHOLD: (value type = cuuint64_t) + * Amount of reserved memory in bytes to hold onto before trying + * to release memory back to the OS. When more than the release + * threshold bytes of memory are held by the memory pool, the + * allocator will try to release memory back to the OS on the + * next call to stream, event or context synchronize. (default 0) + * - ::CU_MEMPOOL_ATTR_REUSE_FOLLOW_EVENT_DEPENDENCIES: (value type = int) + * Allow ::cuMemAllocAsync to use memory asynchronously freed + * in another stream as long as a stream ordering dependency + * of the allocating stream on the free action exists. + * Cuda events and null stream interactions can create the required + * stream ordered dependencies. (default enabled) + * - ::CU_MEMPOOL_ATTR_REUSE_ALLOW_OPPORTUNISTIC: (value type = int) + * Allow reuse of already completed frees when there is no dependency + * between the free and allocation. (default enabled) + * - ::CU_MEMPOOL_ATTR_REUSE_ALLOW_INTERNAL_DEPENDENCIES: (value type = int) + * Allow ::cuMemAllocAsync to insert new stream dependencies + * in order to establish the stream ordering required to reuse + * a piece of memory released by ::cuMemFreeAsync (default enabled). + * - ::CU_MEMPOOL_ATTR_RESERVED_MEM_CURRENT: (value type = cuuint64_t) + * Amount of backing memory currently allocated for the mempool + * - ::CU_MEMPOOL_ATTR_RESERVED_MEM_HIGH: (value type = cuuint64_t) + * High watermark of backing memory allocated for the mempool since the + * last time it was reset. + * - ::CU_MEMPOOL_ATTR_USED_MEM_CURRENT: (value type = cuuint64_t) + * Amount of memory from the pool that is currently in use by the application. + * - ::CU_MEMPOOL_ATTR_USED_MEM_HIGH: (value type = cuuint64_t) + * High watermark of the amount of memory from the pool that was in use by the application. + * + * \param[in] pool - The memory pool to get attributes of + * \param[in] attr - The attribute to get + * \param[out] value - Retrieved value + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuMemAllocAsync, ::cuMemFreeAsync, ::cuDeviceGetDefaultMemPool, + * ::cuDeviceGetMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuMemPoolGetAttribute(CUmemoryPool pool, CUmemPool_attribute attr, void *value); + +/** + * \brief Controls visibility of pools between devices + * + * \param[in] pool - The pool being modified + * \param[in] map - Array of access descriptors. Each descriptor instructs the access to enable for a single gpu. + * \param[in] count - Number of descriptors in the map array. + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuMemAllocAsync, ::cuMemFreeAsync, ::cuDeviceGetDefaultMemPool, + * ::cuDeviceGetMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuMemPoolSetAccess(CUmemoryPool pool, const CUmemAccessDesc *map, size_t count); + +/** + * \brief Returns the accessibility of a pool from a device + * + * Returns the accessibility of the pool's memory from the specified location. + * + * \param[out] flags - the accessibility of the pool from the specified location + * \param[in] memPool - the pool being queried + * \param[in] location - the location accessing the pool + * + * \sa ::cuMemAllocAsync, ::cuMemFreeAsync, ::cuDeviceGetDefaultMemPool, + * ::cuDeviceGetMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuMemPoolGetAccess(CUmemAccess_flags *flags, CUmemoryPool memPool, CUmemLocation *location); + +/** + * \brief Creates a memory pool + * + * Creates a CUDA memory pool and returns the handle in \p pool. The \p poolProps determines + * the properties of the pool such as the backing device and IPC capabilities. + * + * To create a memory pool targeting a specific host NUMA node, applications must + * set ::CUmemPoolProps::CUmemLocation::type to ::CU_MEM_LOCATION_TYPE_HOST_NUMA and + * ::CUmemPoolProps::CUmemLocation::id must specify the NUMA ID of the host memory node. + * Specifying ::CU_MEM_LOCATION_TYPE_HOST_NUMA_CURRENT or ::CU_MEM_LOCATION_TYPE_HOST as the + * ::CUmemPoolProps::CUmemLocation::type will result in ::CUDA_ERROR_INVALID_VALUE. +* By default, the pool's memory will be accessible from the device it is allocated on. + * In the case of pools created with ::CU_MEM_LOCATION_TYPE_HOST_NUMA, their default accessibility + * will be from the host CPU. + * Applications can control the maximum size of the pool by specifying a non-zero value for ::CUmemPoolProps::maxSize. + * If set to 0, the maximum size of the pool will default to a system dependent value. + * + * Applications can set ::CUmemPoolProps::handleTypes to ::CU_MEM_HANDLE_TYPE_FABRIC + * in order to create ::CUmemoryPool suitable for sharing within an IMEX domain. + * An IMEX domain is either an OS instance or a group of securely connected OS instances + * using the NVIDIA IMEX daemon. An IMEX channel is a global resource within the IMEX domain + * that represents a logical entity that aims to provide fine grained accessibility control + * for the participating processes. When exporter and importer CUDA processes have been + * granted access to the same IMEX channel, they can securely share memory. + * If the allocating process does not have access setup for an IMEX channel, attempting to export + * a ::CUmemoryPool with ::CU_MEM_HANDLE_TYPE_FABRIC will result in ::CUDA_ERROR_NOT_PERMITTED. + * The nvidia-modprobe CLI provides more information regarding setting up of IMEX channels. + * + * \note Specifying CU_MEM_HANDLE_TYPE_NONE creates a memory pool that will not support IPC. + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_NOT_PERMITTED + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa ::cuDeviceSetMemPool, ::cuDeviceGetMemPool, ::cuDeviceGetDefaultMemPool, + * ::cuMemAllocFromPoolAsync, ::cuMemPoolExportToShareableHandle + */ +CUresult CUDAAPI cuMemPoolCreate(CUmemoryPool *pool, const CUmemPoolProps *poolProps); + +/** + * \brief Destroys the specified memory pool + * + * If any pointers obtained from this pool haven't been freed or + * the pool has free operations that haven't completed + * when ::cuMemPoolDestroy is invoked, the function will return immediately and the + * resources associated with the pool will be released automatically + * once there are no more outstanding allocations. + * + * Destroying the current mempool of a device sets the default mempool of + * that device as the current mempool for that device. + * + * \note A device's default memory pool cannot be destroyed. + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuMemFreeAsync, ::cuDeviceSetMemPool, ::cuDeviceGetMemPool, + * ::cuDeviceGetDefaultMemPool, ::cuMemPoolCreate + */ +CUresult CUDAAPI cuMemPoolDestroy(CUmemoryPool pool); + +/** + * \brief Allocates memory from a specified pool with stream ordered semantics. + * + * Inserts an allocation operation into \p hStream. + * A pointer to the allocated memory is returned immediately in *dptr. + * The allocation must not be accessed until the the allocation operation completes. + * The allocation comes from the specified memory pool. + * + * \note + * - The specified memory pool may be from a device different than that of the specified \p hStream. + * + * - Basic stream ordering allows future work submitted into the same stream to use the allocation. + * Stream query, stream synchronize, and CUDA events can be used to guarantee that the allocation + * operation completes before work submitted in a separate stream runs. + * + * \note During stream capture, this function results in the creation of an allocation node. In this case, + * the allocation is owned by the graph instead of the memory pool. The memory pool's properties + * are used to set the node's creation parameters. + * + * \param[out] dptr - Returned device pointer + * \param[in] bytesize - Number of bytes to allocate + * \param[in] pool - The pool to allocate from + * \param[in] hStream - The stream establishing the stream ordering semantic + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT (default stream specified with no current context), + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuMemAllocAsync, ::cuMemFreeAsync, ::cuDeviceGetDefaultMemPool, + * ::cuDeviceGetMemPool, ::cuMemPoolCreate, ::cuMemPoolSetAccess, + * ::cuMemPoolSetAttribute + */ +CUresult CUDAAPI cuMemAllocFromPoolAsync(CUdeviceptr *dptr, size_t bytesize, CUmemoryPool pool, CUstream hStream); + +/** + * \brief Exports a memory pool to the requested handle type. + * + * Given an IPC capable mempool, create an OS handle to share the pool with another process. + * A recipient process can convert the shareable handle into a mempool with ::cuMemPoolImportFromShareableHandle. + * Individual pointers can then be shared with the ::cuMemPoolExportPointer and ::cuMemPoolImportPointer APIs. + * The implementation of what the shareable handle is and how it can be transferred is defined by the requested + * handle type. + * + * \note: To create an IPC capable mempool, create a mempool with a CUmemAllocationHandleType other than CU_MEM_HANDLE_TYPE_NONE. + * + * \param[out] handle_out - Returned OS handle + * \param[in] pool - pool to export + * \param[in] handleType - the type of handle to create + * \param[in] flags - must be 0 + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuMemPoolImportFromShareableHandle, ::cuMemPoolExportPointer, + * ::cuMemPoolImportPointer, ::cuMemAllocAsync, ::cuMemFreeAsync, + * ::cuDeviceGetDefaultMemPool, ::cuDeviceGetMemPool, ::cuMemPoolCreate, + * ::cuMemPoolSetAccess, ::cuMemPoolSetAttribute + */ +CUresult CUDAAPI cuMemPoolExportToShareableHandle(void *handle_out, CUmemoryPool pool, CUmemAllocationHandleType handleType, unsigned long long flags); + +/** + * \brief imports a memory pool from a shared handle. + * + * Specific allocations can be imported from the imported pool with cuMemPoolImportPointer. + * + * If \p handleType is ::CU_MEM_HANDLE_TYPE_FABRIC and the importer process has not been + * granted access to the same IMEX channel as the exporter process, this API will error + * as ::CUDA_ERROR_NOT_PERMITTED. + * + * + * \note Imported memory pools do not support creating new allocations. + * As such imported memory pools may not be used in cuDeviceSetMemPool + * or ::cuMemAllocFromPoolAsync calls. + * + * \param[out] pool_out - Returned memory pool + * \param[in] handle - OS handle of the pool to open + * \param[in] handleType - The type of handle being imported + * \param[in] flags - must be 0 + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuMemPoolExportToShareableHandle, ::cuMemPoolExportPointer, ::cuMemPoolImportPointer + */ +CUresult CUDAAPI cuMemPoolImportFromShareableHandle( + CUmemoryPool *pool_out, + void *handle, + CUmemAllocationHandleType handleType, + unsigned long long flags); + +/** + * \brief Export data to share a memory pool allocation between processes. + * + * Constructs \p shareData_out for sharing a specific allocation from an already shared memory pool. + * The recipient process can import the allocation with the ::cuMemPoolImportPointer api. + * The data is not a handle and may be shared through any IPC mechanism. + * + * \param[out] shareData_out - Returned export data + * \param[in] ptr - pointer to memory being exported + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuMemPoolExportToShareableHandle, ::cuMemPoolImportFromShareableHandle, ::cuMemPoolImportPointer + */ +CUresult CUDAAPI cuMemPoolExportPointer(CUmemPoolPtrExportData *shareData_out, CUdeviceptr ptr); + +/** + * \brief Import a memory pool allocation from another process. + * + * Returns in \p ptr_out a pointer to the imported memory. + * The imported memory must not be accessed before the allocation operation completes + * in the exporting process. The imported memory must be freed from all importing processes before + * being freed in the exporting process. The pointer may be freed with cuMemFree + * or cuMemFreeAsync. If cuMemFreeAsync is used, the free must be completed + * on the importing process before the free operation on the exporting process. + * + * \note The cuMemFreeAsync api may be used in the exporting process before + * the cuMemFreeAsync operation completes in its stream as long as the + * cuMemFreeAsync in the exporting process specifies a stream with + * a stream dependency on the importing process's cuMemFreeAsync. + * + * \param[out] ptr_out - pointer to imported memory + * \param[in] pool - pool from which to import + * \param[in] shareData - data specifying the memory to import + * + * \returns + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa ::cuMemPoolExportToShareableHandle, ::cuMemPoolImportFromShareableHandle, ::cuMemPoolExportPointer + */ +CUresult CUDAAPI cuMemPoolImportPointer(CUdeviceptr *ptr_out, CUmemoryPool pool, CUmemPoolPtrExportData *shareData); + +/** @} */ /* END CUDA_MALLOC_ASYNC */ + +/** + * \defgroup CUDA_MULTICAST Multicast Object Management + * + * ___MANBRIEF___ Functions for creating multicast objects, adding devices to them and binding/unbinding memory + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the CUDA multicast object operations exposed by the + * low-level CUDA driver application programming interface. + * + * @{ + * + * \section CUDA_MULTICAST_overview overview + * + * A multicast object created via ::cuMulticastCreate enables certain memory + * operations to be broadcast to a team of devices. Devices can be added to a + * multicast object via ::cuMulticastAddDevice. Memory can be bound on each + * participating device via either ::cuMulticastBindMem or ::cuMulticastBindAddr. + * Multicast objects can be mapped into a device's virtual address space using + * the virtual memmory management APIs (see ::cuMemMap and ::cuMemSetAccess). + * + * \section CUDA_MULTICAST_support Supported Platforms + * + * Support for multicast on a specific device can be queried using the device + * attribute ::CU_DEVICE_ATTRIBUTE_MULTICAST_SUPPORTED + */ + +/** + * \brief Create a generic allocation handle representing a multicast object described by the given properties. + * + * This creates a multicast object as described by \p prop. The number of + * participating devices is specified by ::CUmulticastObjectProp::numDevices. + * Devices can be added to the multicast object via ::cuMulticastAddDevice. + * All participating devices must be added to the multicast object before memory + * can be bound to it. Memory is bound to the multicast object via either + * ::cuMulticastBindMem or ::cuMulticastBindAddr, and can be unbound via + * ::cuMulticastUnbind. The total amount of memory that can be bound per device + * is specified by :CUmulticastObjectProp::size. This size must be a multiple of + * the value returned by ::cuMulticastGetGranularity with the flag + * ::CU_MULTICAST_GRANULARITY_MINIMUM. For best performance however, the size + * should be aligned to the value returned by ::cuMulticastGetGranularity with + * the flag ::CU_MULTICAST_GRANULARITY_RECOMMENDED. + * + * After all participating devices have been added, multicast objects can also + * be mapped to a device's virtual address space using the virtual memory + * management APIs (see ::cuMemMap and ::cuMemSetAccess). Multicast objects can + * also be shared with other processes by requesting a shareable handle via + * ::cuMemExportToShareableHandle. Note that the desired types of shareable + * handles must be specified in the bitmask ::CUmulticastObjectProp::handleTypes. + * Multicast objects can be released using the virtual memory management API + * ::cuMemRelease. + * + * \param[out] mcHandle Value of handle returned. + * \param[in] prop Properties of the multicast object to create. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa ::cuMulticastAddDevice, ::cuMulticastBindMem, ::cuMulticastBindAddr, ::cuMulticastUnbind + * \sa ::cuMemCreate, ::cuMemRelease, ::cuMemExportToShareableHandle, ::cuMemImportFromShareableHandle + */ +CUresult CUDAAPI cuMulticastCreate(CUmemGenericAllocationHandle *mcHandle, const CUmulticastObjectProp *prop); + +/** + * \brief Associate a device to a multicast object. + * + * Associates a device to a multicast object. The added device will be a part of + * the multicast team of size specified by CUmulticastObjectProp::numDevices + * during ::cuMulticastCreate. + * The association of the device to the multicast object is permanent during + * the life time of the multicast object. + * All devices must be added to the multicast team before any memory can be + * bound to any device in the team. Any calls to ::cuMulticastBindMem or + * ::cuMulticastBindAddr will block until all devices have been added. + * Similarly all devices must be added to the multicast team before a virtual + * address range can be mapped to the multicast object. A call to ::cuMemMap + * will block until all devices have been added. + * + * \param[in] mcHandle Handle representing a multicast object. + * \param[in] dev Device that will be associated to the multicast + * object. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa ::cuMulticastCreate, ::cuMulticastBindMem, ::cuMulticastBindAddr + */ +CUresult CUDAAPI cuMulticastAddDevice(CUmemGenericAllocationHandle mcHandle, CUdevice dev); + +/** + * \brief Bind a memory allocation represented by a handle to a multicast object. + * + * Binds a memory allocation specified by \p memHandle and created via + * ::cuMemCreate to a multicast object represented by \p mcHandle and created + * via ::cuMulticastCreate. The intended \p size of the bind, the offset in the + * multicast range \p mcOffset as well as the offset in the memory \p memOffset + * must be a multiple of the value returned by ::cuMulticastGetGranularity with + * the flag ::CU_MULTICAST_GRANULARITY_MINIMUM. For best performance however, + * \p size, \p mcOffset and \p memOffset should be aligned to the granularity of + * the memory allocation(see ::cuMemGetAllocationGranularity) or to the value + * returned by ::cuMulticastGetGranularity with the flag + * ::CU_MULTICAST_GRANULARITY_RECOMMENDED. + * + * The \p size + \p memOffset cannot be larger than the size of the allocated + * memory. Similarly the \p size + \p mcOffset cannot be larger than the size + * of the multicast object. + * The memory allocation must have beeen created on one of the devices + * that was added to the multicast team via ::cuMulticastAddDevice. + * Externally shareable as well as imported multicast objects can be bound only + * to externally shareable memory. + * Note that this call will return CUDA_ERROR_OUT_OF_MEMORY if there are + * insufficient resources required to perform the bind. This call may also + * return CUDA_ERROR_SYSTEM_NOT_READY if the necessary system software is not + * initialized or running. + * + * \param[in] mcHandle Handle representing a multicast object. + * \param[in] mcOffset Offset into the multicast object for attachment. + * \param[in] memHandle Handle representing a memory allocation. + * \param[in] memOffset Offset into the memory for attachment. + * \param[in] size Size of the memory that will be bound to the + * multicast object. + * \param[in] flags Flags for future use, must be zero for now. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_SYSTEM_NOT_READY + * + * \sa ::cuMulticastCreate, ::cuMulticastAddDevice, ::cuMemCreate + */ +CUresult CUDAAPI cuMulticastBindMem(CUmemGenericAllocationHandle mcHandle, size_t mcOffset, CUmemGenericAllocationHandle memHandle, size_t memOffset, size_t size, unsigned long long flags); + +/** + * \brief Bind a memory allocation represented by a virtual address to a multicast object. + * + * Binds a memory allocation specified by its mapped address \p memptr to a + * multicast object represented by \p mcHandle. + * The memory must have been allocated via ::cuMemCreate or ::cudaMallocAsync. + * The intended \p size of the bind, the offset in the multicast range + * \p mcOffset and \p memptr must be a multiple of the value returned by + * ::cuMulticastGetGranularity with the flag ::CU_MULTICAST_GRANULARITY_MINIMUM. + * For best performance however, \p size, \p mcOffset and \p memptr should be + * aligned to the value returned by ::cuMulticastGetGranularity with the flag + * ::CU_MULTICAST_GRANULARITY_RECOMMENDED. + * + * The \p size cannot be larger than the size of the allocated memory. + * Similarly the \p size + \p mcOffset cannot be larger than the total size + * of the multicast object. + * The memory allocation must have beeen created on one of the devices + * that was added to the multicast team via ::cuMulticastAddDevice. + * Externally shareable as well as imported multicast objects can be bound only + * to externally shareable memory. + * Note that this call will return CUDA_ERROR_OUT_OF_MEMORY if there are + * insufficient resources required to perform the bind. This call may also + * return CUDA_ERROR_SYSTEM_NOT_READY if the necessary system software is not + * initialized or running. + * + * \param[in] mcHandle Handle representing a multicast object. + * \param[in] mcOffset Offset into multicast va range for attachment. + * \param[in] memptr Virtual address of the memory allocation. + * \param[in] size Size of memory that will be bound to the + * multicast object. + * \param[in] flags Flags for future use, must be zero now. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY, + * ::CUDA_ERROR_SYSTEM_NOT_READY + * + * \sa ::cuMulticastCreate, ::cuMulticastAddDevice, ::cuMemCreate + */ +CUresult CUDAAPI cuMulticastBindAddr(CUmemGenericAllocationHandle mcHandle, size_t mcOffset, CUdeviceptr memptr, size_t size, unsigned long long flags); + +/** + * \brief Unbind any memory allocations bound to a multicast object at a given offset and upto a given size. + * + * Unbinds any memory allocations hosted on \p dev and bound to a multicast + * object at \p mcOffset and upto a given \p size. + * The intended \p size of the unbind and the offset in the multicast range + * ( \p mcOffset ) must be a multiple of the value returned by + * ::cuMulticastGetGranularity flag ::CU_MULTICAST_GRANULARITY_MINIMUM. + * The \p size + \p mcOffset cannot be larger than the total size of the + * multicast object. + * + * \note + * Warning: + * The \p mcOffset and the \p size must match the corresponding values specified + * during the bind call. Any other values may result in undefined behavior. + * + * \param[in] mcHandle Handle representing a multicast object. + * \param[in] dev Device that hosts the memory allocation. + * \param[in] mcOffset Offset into the multicast object. + * \param[in] size Desired size to unbind. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa ::cuMulticastBindMem, ::cuMulticastBindAddr + */ +CUresult CUDAAPI cuMulticastUnbind(CUmemGenericAllocationHandle mcHandle, CUdevice dev, size_t mcOffset, size_t size); + +/** +* \brief Calculates either the minimal or recommended granularity for multicast object +* +* Calculates either the minimal or recommended granularity for a given set of +* multicast object properties and returns it in granularity. This granularity +* can be used as a multiple for size, bind offsets and address mappings of the +* multicast object. +* +* \param[out] granularity Returned granularity. +* \param[in] prop Properties of the multicast object. +* \param[in] option Determines which granularity to return. +* +* \returns +* ::CUDA_SUCCESS, +* ::CUDA_ERROR_INVALID_VALUE, +* ::CUDA_ERROR_NOT_INITIALIZED, +* ::CUDA_ERROR_DEINITIALIZED, +* ::CUDA_ERROR_NOT_PERMITTED, +* ::CUDA_ERROR_NOT_SUPPORTED +* +* \sa ::cuMulticastCreate, ::cuMulticastBindMem, ::cuMulticastBindAddr, ::cuMulticastUnbind +*/ +CUresult CUDAAPI cuMulticastGetGranularity(size_t *granularity, const CUmulticastObjectProp *prop, CUmulticastGranularity_flags option); + +/** @} */ /* END CUDA_MULTICAST */ + +/** + * \defgroup CUDA_UNIFIED Unified Addressing + * + * ___MANBRIEF___ unified addressing functions of the low-level CUDA driver + * API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the unified addressing functions of the + * low-level CUDA driver application programming interface. + * + * @{ + * + * \section CUDA_UNIFIED_overview Overview + * + * CUDA devices can share a unified address space with the host. + * For these devices there is no distinction between a device + * pointer and a host pointer -- the same pointer value may be + * used to access memory from the host program and from a kernel + * running on the device (with exceptions enumerated below). + * + * \section CUDA_UNIFIED_support Supported Platforms + * + * Whether or not a device supports unified addressing may be + * queried by calling ::cuDeviceGetAttribute() with the device + * attribute ::CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING. + * + * Unified addressing is automatically enabled in 64-bit processes + * + * \section CUDA_UNIFIED_lookup Looking Up Information from Pointer Values + * + * It is possible to look up information about the memory which backs a + * pointer value. For instance, one may want to know if a pointer points + * to host or device memory. As another example, in the case of device + * memory, one may want to know on which CUDA device the memory + * resides. These properties may be queried using the function + * ::cuPointerGetAttribute() + * + * Since pointers are unique, it is not necessary to specify information + * about the pointers specified to the various copy functions in the + * CUDA API. The function ::cuMemcpy() may be used to perform a copy + * between two pointers, ignoring whether they point to host or device + * memory (making ::cuMemcpyHtoD(), ::cuMemcpyDtoD(), and ::cuMemcpyDtoH() + * unnecessary for devices supporting unified addressing). For + * multidimensional copies, the memory type ::CU_MEMORYTYPE_UNIFIED may be + * used to specify that the CUDA driver should infer the location of the + * pointer from its value. + * + * \section CUDA_UNIFIED_automaphost Automatic Mapping of Host Allocated Host Memory + * + * All host memory allocated in all contexts using ::cuMemAllocHost() and + * ::cuMemHostAlloc() is always directly accessible from all contexts on + * all devices that support unified addressing. This is the case regardless + * of whether or not the flags ::CU_MEMHOSTALLOC_PORTABLE and + * ::CU_MEMHOSTALLOC_DEVICEMAP are specified. + * + * The pointer value through which allocated host memory may be accessed + * in kernels on all devices that support unified addressing is the same + * as the pointer value through which that memory is accessed on the host, + * so it is not necessary to call ::cuMemHostGetDevicePointer() to get the device + * pointer for these allocations. + * + * Note that this is not the case for memory allocated using the flag + * ::CU_MEMHOSTALLOC_WRITECOMBINED, as discussed below. + * + * \section CUDA_UNIFIED_autopeerregister Automatic Registration of Peer Memory + * + * Upon enabling direct access from a context that supports unified addressing + * to another peer context that supports unified addressing using + * ::cuCtxEnablePeerAccess() all memory allocated in the peer context using + * ::cuMemAlloc() and ::cuMemAllocPitch() will immediately be accessible + * by the current context. The device pointer value through + * which any peer memory may be accessed in the current context + * is the same pointer value through which that memory may be + * accessed in the peer context. + * + * \section CUDA_UNIFIED_exceptions Exceptions, Disjoint Addressing + * + * Not all memory may be accessed on devices through the same pointer + * value through which they are accessed on the host. These exceptions + * are host memory registered using ::cuMemHostRegister() and host memory + * allocated using the flag ::CU_MEMHOSTALLOC_WRITECOMBINED. For these + * exceptions, there exists a distinct host and device address for the + * memory. The device address is guaranteed to not overlap any valid host + * pointer range and is guaranteed to have the same value across all + * contexts that support unified addressing. + * + * This device address may be queried using ::cuMemHostGetDevicePointer() + * when a context using unified addressing is current. Either the host + * or the unified device pointer value may be used to refer to this memory + * through ::cuMemcpy() and similar functions using the + * ::CU_MEMORYTYPE_UNIFIED memory type. + * + */ + +/** + * \brief Returns information about a pointer + * + * The supported attributes are: + * + * - ::CU_POINTER_ATTRIBUTE_CONTEXT: + * + * Returns in \p *data the ::CUcontext in which \p ptr was allocated or + * registered. + * The type of \p data must be ::CUcontext *. + * + * If \p ptr was not allocated by, mapped by, or registered with + * a ::CUcontext which uses unified virtual addressing then + * ::CUDA_ERROR_INVALID_VALUE is returned. + * + * - ::CU_POINTER_ATTRIBUTE_MEMORY_TYPE: + * + * Returns in \p *data the physical memory type of the memory that + * \p ptr addresses as a ::CUmemorytype enumerated value. + * The type of \p data must be unsigned int. + * + * If \p ptr addresses device memory then \p *data is set to + * ::CU_MEMORYTYPE_DEVICE. The particular ::CUdevice on which the + * memory resides is the ::CUdevice of the ::CUcontext returned by the + * ::CU_POINTER_ATTRIBUTE_CONTEXT attribute of \p ptr. + * + * If \p ptr addresses host memory then \p *data is set to + * ::CU_MEMORYTYPE_HOST. + * + * If \p ptr was not allocated by, mapped by, or registered with + * a ::CUcontext which uses unified virtual addressing then + * ::CUDA_ERROR_INVALID_VALUE is returned. + * + * If the current ::CUcontext does not support unified virtual + * addressing then ::CUDA_ERROR_INVALID_CONTEXT is returned. + * + * - ::CU_POINTER_ATTRIBUTE_DEVICE_POINTER: + * + * Returns in \p *data the device pointer value through which + * \p ptr may be accessed by kernels running in the current + * ::CUcontext. + * The type of \p data must be CUdeviceptr *. + * + * If there exists no device pointer value through which + * kernels running in the current ::CUcontext may access + * \p ptr then ::CUDA_ERROR_INVALID_VALUE is returned. + * + * If there is no current ::CUcontext then + * ::CUDA_ERROR_INVALID_CONTEXT is returned. + * + * Except in the exceptional disjoint addressing cases discussed + * below, the value returned in \p *data will equal the input + * value \p ptr. + * + * - ::CU_POINTER_ATTRIBUTE_HOST_POINTER: + * + * Returns in \p *data the host pointer value through which + * \p ptr may be accessed by by the host program. + * The type of \p data must be void **. + * If there exists no host pointer value through which + * the host program may directly access \p ptr then + * ::CUDA_ERROR_INVALID_VALUE is returned. + * + * Except in the exceptional disjoint addressing cases discussed + * below, the value returned in \p *data will equal the input + * value \p ptr. + * + * - ::CU_POINTER_ATTRIBUTE_P2P_TOKENS: + * + * Returns in \p *data two tokens for use with the nv-p2p.h Linux + * kernel interface. \p data must be a struct of type + * CUDA_POINTER_ATTRIBUTE_P2P_TOKENS. + * + * \p ptr must be a pointer to memory obtained from :cuMemAlloc(). + * Note that p2pToken and vaSpaceToken are only valid for the + * lifetime of the source allocation. A subsequent allocation at + * the same address may return completely different tokens. + * Querying this attribute has a side effect of setting the attribute + * ::CU_POINTER_ATTRIBUTE_SYNC_MEMOPS for the region of memory that + * \p ptr points to. + * + * - ::CU_POINTER_ATTRIBUTE_SYNC_MEMOPS: + * + * A boolean attribute which when set, ensures that synchronous memory operations + * initiated on the region of memory that \p ptr points to will always synchronize. + * See further documentation in the section titled "API synchronization behavior" + * to learn more about cases when synchronous memory operations can + * exhibit asynchronous behavior. + * + * - ::CU_POINTER_ATTRIBUTE_BUFFER_ID: + * + * Returns in \p *data a buffer ID which is guaranteed to be unique within the process. + * \p data must point to an unsigned long long. + * + * \p ptr must be a pointer to memory obtained from a CUDA memory allocation API. + * Every memory allocation from any of the CUDA memory allocation APIs will + * have a unique ID over a process lifetime. Subsequent allocations do not reuse IDs + * from previous freed allocations. IDs are only unique within a single process. + * + * + * - ::CU_POINTER_ATTRIBUTE_IS_MANAGED: + * + * Returns in \p *data a boolean that indicates whether the pointer points to + * managed memory or not. + * + * If \p ptr is not a valid CUDA pointer then ::CUDA_ERROR_INVALID_VALUE is returned. + * + * - ::CU_POINTER_ATTRIBUTE_DEVICE_ORDINAL: + * + * Returns in \p *data an integer representing a device ordinal of a device against + * which the memory was allocated or registered. + * + * - ::CU_POINTER_ATTRIBUTE_IS_LEGACY_CUDA_IPC_CAPABLE: + * + * Returns in \p *data a boolean that indicates if this pointer maps to + * an allocation that is suitable for ::cudaIpcGetMemHandle. + * + * - ::CU_POINTER_ATTRIBUTE_RANGE_START_ADDR: + * + * Returns in \p *data the starting address for the allocation referenced + * by the device pointer \p ptr. Note that this is not necessarily the + * address of the mapped region, but the address of the mappable address + * range \p ptr references (e.g. from ::cuMemAddressReserve). + * + * - ::CU_POINTER_ATTRIBUTE_RANGE_SIZE: + * + * Returns in \p *data the size for the allocation referenced by the device + * pointer \p ptr. Note that this is not necessarily the size of the mapped + * region, but the size of the mappable address range \p ptr references + * (e.g. from ::cuMemAddressReserve). To retrieve the size of the mapped + * region, see ::cuMemGetAddressRange + * + * - ::CU_POINTER_ATTRIBUTE_MAPPED: + * + * Returns in \p *data a boolean that indicates if this pointer is in a + * valid address range that is mapped to a backing allocation. + * + * - ::CU_POINTER_ATTRIBUTE_ALLOWED_HANDLE_TYPES: + * + * Returns a bitmask of the allowed handle types for an allocation that may + * be passed to ::cuMemExportToShareableHandle. + * + * - ::CU_POINTER_ATTRIBUTE_MEMPOOL_HANDLE: + * + * Returns in \p *data the handle to the mempool that the allocation was obtained from. + * + * + * \par + * + * Note that for most allocations in the unified virtual address space + * the host and device pointer for accessing the allocation will be the + * same. The exceptions to this are + * - user memory registered using ::cuMemHostRegister + * - host memory allocated using ::cuMemHostAlloc with the + * ::CU_MEMHOSTALLOC_WRITECOMBINED flag + * For these types of allocation there will exist separate, disjoint host + * and device addresses for accessing the allocation. In particular + * - The host address will correspond to an invalid unmapped device address + * (which will result in an exception if accessed from the device) + * - The device address will correspond to an invalid unmapped host address + * (which will result in an exception if accessed from the host). + * For these types of allocations, querying ::CU_POINTER_ATTRIBUTE_HOST_POINTER + * and ::CU_POINTER_ATTRIBUTE_DEVICE_POINTER may be used to retrieve the host + * and device addresses from either address. + * + * \param data - Returned pointer attribute value + * \param attribute - Pointer attribute to query + * \param ptr - Pointer + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuPointerSetAttribute, + * ::cuMemAlloc, + * ::cuMemFree, + * ::cuMemAllocHost, + * ::cuMemFreeHost, + * ::cuMemHostAlloc, + * ::cuMemHostRegister, + * ::cuMemHostUnregister, + * ::cudaPointerGetAttributes + */ +CUresult CUDAAPI cuPointerGetAttribute(void *data, CUpointer_attribute attribute, CUdeviceptr ptr); + +/** + * \brief Prefetches memory to the specified destination device + * + * Note there is a later version of this API, ::cuMemPrefetchAsync_v2. It will + * supplant this version in 13.0, which is retained for minor version compatibility. + * + * Prefetches memory to the specified destination device. \p devPtr is the + * base device pointer of the memory to be prefetched and \p dstDevice is the + * destination device. \p count specifies the number of bytes to copy. \p hStream + * is the stream in which the operation is enqueued. The memory range must refer + * to managed memory allocated via ::cuMemAllocManaged or declared via __managed__ variables + * or it may also refer to system-allocated memory on systems with non-zero + * CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. + * + * Passing in CU_DEVICE_CPU for \p dstDevice will prefetch the data to host memory. If + * \p dstDevice is a GPU, then the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS + * must be non-zero. Additionally, \p hStream must be associated with a device that has a + * non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * + * The start address and end address of the memory range will be rounded down and rounded up + * respectively to be aligned to CPU page size before the prefetch operation is enqueued + * in the stream. + * + * If no physical memory has been allocated for this region, then this memory region + * will be populated and mapped on the destination device. If there's insufficient + * memory to prefetch the desired region, the Unified Memory driver may evict pages from other + * ::cuMemAllocManaged allocations to host memory in order to make room. Device memory + * allocated using ::cuMemAlloc or ::cuArrayCreate will not be evicted. + * + * By default, any mappings to the previous location of the migrated pages are removed and + * mappings for the new location are only setup on \p dstDevice. The exact behavior however + * also depends on the settings applied to this memory range via ::cuMemAdvise as described + * below: + * + * If ::CU_MEM_ADVISE_SET_READ_MOSTLY was set on any subset of this memory range, + * then that subset will create a read-only copy of the pages on \p dstDevice. + * + * If ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION was called on any subset of this memory + * range, then the pages will be migrated to \p dstDevice even if \p dstDevice is not the + * preferred location of any pages in the memory range. + * + * If ::CU_MEM_ADVISE_SET_ACCESSED_BY was called on any subset of this memory range, + * then mappings to those pages from all the appropriate processors are updated to + * refer to the new location if establishing such a mapping is possible. Otherwise, + * those mappings are cleared. + * + * Note that this API is not required for functionality and only serves to improve performance + * by allowing the application to migrate data to a suitable location before it is accessed. + * Memory accesses to this range are always coherent and are allowed even when the data is + * actively being migrated. + * + * Note that this function is asynchronous with respect to the host and all work + * on other devices. + * + * \param devPtr - Pointer to be prefetched + * \param count - Size in bytes + * \param dstDevice - Destination device to prefetch to + * \param hStream - Stream to enqueue prefetch operation + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemcpy, ::cuMemcpyPeer, ::cuMemcpyAsync, + * ::cuMemcpy3DPeerAsync, ::cuMemAdvise, ::cuMemPrefetchAsync + * ::cudaMemPrefetchAsync_v2 + */ +CUresult CUDAAPI cuMemPrefetchAsync(CUdeviceptr devPtr, size_t count, CUdevice dstDevice, CUstream hStream); + +/** + * \brief Prefetches memory to the specified destination location + * + * Prefetches memory to the specified destination location. \p devPtr is the + * base device pointer of the memory to be prefetched and \p location specifies the + * destination location. \p count specifies the number of bytes to copy. \p hStream + * is the stream in which the operation is enqueued. The memory range must refer + * to managed memory allocated via ::cuMemAllocManaged or declared via __managed__ variables. + * + * Specifying ::CU_MEM_LOCATION_TYPE_DEVICE for ::CUmemLocation::type will prefetch memory to GPU + * specified by device ordinal ::CUmemLocation::id which must have non-zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. Additionally, \p hStream must be associated with a device + * that has a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * Specifying ::CU_MEM_LOCATION_TYPE_HOST as ::CUmemLocation::type will prefetch data to host memory. + * Applications can request prefetching memory to a specific host NUMA node by specifying + * ::CU_MEM_LOCATION_TYPE_HOST_NUMA for ::CUmemLocation::type and a valid host NUMA node id in ::CUmemLocation::id + * Users can also request prefetching memory to the host NUMA node closest to the current thread's CPU by specifying + * ::CU_MEM_LOCATION_TYPE_HOST_NUMA_CURRENT for ::CUmemLocation::type. Note when ::CUmemLocation::type is etiher + * ::CU_MEM_LOCATION_TYPE_HOST OR ::CU_MEM_LOCATION_TYPE_HOST_NUMA_CURRENT, ::CUmemLocation::id will be ignored. + * + * The start address and end address of the memory range will be rounded down and rounded up + * respectively to be aligned to CPU page size before the prefetch operation is enqueued + * in the stream. + * + * If no physical memory has been allocated for this region, then this memory region + * will be populated and mapped on the destination device. If there's insufficient + * memory to prefetch the desired region, the Unified Memory driver may evict pages from other + * ::cuMemAllocManaged allocations to host memory in order to make room. Device memory + * allocated using ::cuMemAlloc or ::cuArrayCreate will not be evicted. + * + * By default, any mappings to the previous location of the migrated pages are removed and + * mappings for the new location are only setup on the destination location. The exact behavior however + * also depends on the settings applied to this memory range via ::cuMemAdvise as described + * below: + * + * If ::CU_MEM_ADVISE_SET_READ_MOSTLY was set on any subset of this memory range, + * then that subset will create a read-only copy of the pages on destination location. + * If however the destination location is a host NUMA node, then any pages of that subset + * that are already in another host NUMA node will be transferred to the destination. + * + * If ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION was called on any subset of this memory + * range, then the pages will be migrated to \p location even if \p location is not the + * preferred location of any pages in the memory range. + * + * If ::CU_MEM_ADVISE_SET_ACCESSED_BY was called on any subset of this memory range, + * then mappings to those pages from all the appropriate processors are updated to + * refer to the new location if establishing such a mapping is possible. Otherwise, + * those mappings are cleared. + * + * Note that this API is not required for functionality and only serves to improve performance + * by allowing the application to migrate data to a suitable location before it is accessed. + * Memory accesses to this range are always coherent and are allowed even when the data is + * actively being migrated. + * + * Note that this function is asynchronous with respect to the host and all work + * on other devices. + * + * \param devPtr - Pointer to be prefetched + * \param count - Size in bytes + * \param dstDevice - Destination device to prefetch to + * \param flags - flags for future use, must be zero now. + * \param hStream - Stream to enqueue prefetch operation + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemcpy, ::cuMemcpyPeer, ::cuMemcpyAsync, + * ::cuMemcpy3DPeerAsync, ::cuMemAdvise, ::cuMemPrefetchAsync + * ::cudaMemPrefetchAsync_v2 + */ +CUresult CUDAAPI cuMemPrefetchAsync_v2(CUdeviceptr devPtr, size_t count, CUmemLocation location, unsigned int flags, CUstream hStream); + +/** + * \brief Advise about the usage of a given memory range + * + * Note there is a later version of this API, ::cuMemAdvise_v2. It will + * supplant this version in 13.0, which is retained for minor version compatibility. + * + * Advise the Unified Memory subsystem about the usage pattern for the memory range + * starting at \p devPtr with a size of \p count bytes. The start address and end address of the memory + * range will be rounded down and rounded up respectively to be aligned to CPU page size before the + * advice is applied. The memory range must refer to managed memory allocated via ::cuMemAllocManaged + * or declared via __managed__ variables. The memory range could also refer to system-allocated pageable + * memory provided it represents a valid, host-accessible region of memory and all additional constraints + * imposed by \p advice as outlined below are also satisfied. Specifying an invalid system-allocated pageable + * memory range results in an error being returned. + * + * The \p advice parameter can take the following values: + * - ::CU_MEM_ADVISE_SET_READ_MOSTLY: This implies that the data is mostly going to be read + * from and only occasionally written to. Any read accesses from any processor to this region will create a + * read-only copy of at least the accessed pages in that processor's memory. Additionally, if ::cuMemPrefetchAsync + * is called on this region, it will create a read-only copy of the data on the destination processor. + * If any processor writes to this region, all copies of the corresponding page will be invalidated + * except for the one where the write occurred. The \p device argument is ignored for this advice. + * Note that for a page to be read-duplicated, the accessing processor must either be the CPU or a GPU + * that has a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * Also, if a context is created on a device that does not have the device attribute + * ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS set, then read-duplication will not occur until + * all such contexts are destroyed. + * If the memory region refers to valid system-allocated pageable memory, then the accessing device must + * have a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS for a read-only + * copy to be created on that device. Note however that if the accessing device also has a non-zero value for the + * device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, then setting this advice + * will not create a read-only copy when that device accesses this memory region. + * + * - ::CU_MEM_ADVISE_UNSET_READ_MOSTLY: Undoes the effect of ::CU_MEM_ADVISE_SET_READ_MOSTLY and also prevents the + * Unified Memory driver from attempting heuristic read-duplication on the memory range. Any read-duplicated + * copies of the data will be collapsed into a single copy. The location for the collapsed + * copy will be the preferred location if the page has a preferred location and one of the read-duplicated + * copies was resident at that location. Otherwise, the location chosen is arbitrary. + * + * - ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION: This advice sets the preferred location for the + * data to be the memory belonging to \p device. Passing in CU_DEVICE_CPU for \p device sets the + * preferred location as host memory. If \p device is a GPU, then it must have a non-zero value for the + * device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. Setting the preferred location + * does not cause data to migrate to that location immediately. Instead, it guides the migration policy + * when a fault occurs on that memory region. If the data is already in its preferred location and the + * faulting processor can establish a mapping without requiring the data to be migrated, then + * data migration will be avoided. On the other hand, if the data is not in its preferred location + * or if a direct mapping cannot be established, then it will be migrated to the processor accessing + * it. It is important to note that setting the preferred location does not prevent data prefetching + * done using ::cuMemPrefetchAsync. + * Having a preferred location can override the page thrash detection and resolution logic in the Unified + * Memory driver. Normally, if a page is detected to be constantly thrashing between for example host and device + * memory, the page may eventually be pinned to host memory by the Unified Memory driver. But + * if the preferred location is set as device memory, then the page will continue to thrash indefinitely. + * If ::CU_MEM_ADVISE_SET_READ_MOSTLY is also set on this memory region or any subset of it, then the + * policies associated with that advice will override the policies of this advice, unless read accesses from + * \p device will not result in a read-only copy being created on that device as outlined in description for + * the advice ::CU_MEM_ADVISE_SET_READ_MOSTLY. + * If the memory region refers to valid system-allocated pageable memory, then \p device must have a non-zero + * value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. + * + * - ::CU_MEM_ADVISE_UNSET_PREFERRED_LOCATION: Undoes the effect of ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION + * and changes the preferred location to none. + * + * - ::CU_MEM_ADVISE_SET_ACCESSED_BY: This advice implies that the data will be accessed by \p device. + * Passing in ::CU_DEVICE_CPU for \p device will set the advice for the CPU. If \p device is a GPU, then + * the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS must be non-zero. + * This advice does not cause data migration and has no impact on the location of the data per se. Instead, + * it causes the data to always be mapped in the specified processor's page tables, as long as the + * location of the data permits a mapping to be established. If the data gets migrated for any reason, + * the mappings are updated accordingly. + * This advice is recommended in scenarios where data locality is not important, but avoiding faults is. + * Consider for example a system containing multiple GPUs with peer-to-peer access enabled, where the + * data located on one GPU is occasionally accessed by peer GPUs. In such scenarios, migrating data + * over to the other GPUs is not as important because the accesses are infrequent and the overhead of + * migration may be too high. But preventing faults can still help improve performance, and so having + * a mapping set up in advance is useful. Note that on CPU access of this data, the data may be migrated + * to host memory because the CPU typically cannot access device memory directly. Any GPU that had the + * ::CU_MEM_ADVISE_SET_ACCESSED_BY flag set for this data will now have its mapping updated to point to the + * page in host memory. + * If ::CU_MEM_ADVISE_SET_READ_MOSTLY is also set on this memory region or any subset of it, then the + * policies associated with that advice will override the policies of this advice. Additionally, if the + * preferred location of this memory region or any subset of it is also \p device, then the policies + * associated with ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION will override the policies of this advice. + * If the memory region refers to valid system-allocated pageable memory, then \p device must have a non-zero + * value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. Additionally, if \p device has + * a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, + * then this call has no effect. + * + * - ::CU_MEM_ADVISE_UNSET_ACCESSED_BY: Undoes the effect of ::CU_MEM_ADVISE_SET_ACCESSED_BY. Any mappings to + * the data from \p device may be removed at any time causing accesses to result in non-fatal page faults. + * If the memory region refers to valid system-allocated pageable memory, then \p device must have a non-zero + * value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. Additionally, if \p device has + * a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, + * then this call has no effect. + * + * \param devPtr - Pointer to memory to set the advice for + * \param count - Size in bytes of the memory range + * \param advice - Advice to be applied for the specified memory range + * \param device - Device to apply the advice for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemcpy, ::cuMemcpyPeer, ::cuMemcpyAsync, + * ::cuMemcpy3DPeerAsync, ::cuMemPrefetchAsync, ::cuMemAdvise_v2 + * ::cudaMemAdvise + */ +CUresult CUDAAPI cuMemAdvise(CUdeviceptr devPtr, size_t count, CUmem_advise advice, CUdevice device); + +/** + * \brief Advise about the usage of a given memory range + * + * Advise the Unified Memory subsystem about the usage pattern for the memory range + * starting at \p devPtr with a size of \p count bytes. The start address and end address of the memory + * range will be rounded down and rounded up respectively to be aligned to CPU page size before the + * advice is applied. The memory range must refer to managed memory allocated via ::cuMemAllocManaged + * or declared via __managed__ variables. The memory range could also refer to system-allocated pageable + * memory provided it represents a valid, host-accessible region of memory and all additional constraints + * imposed by \p advice as outlined below are also satisfied. Specifying an invalid system-allocated pageable + * memory range results in an error being returned. + * + * The \p advice parameter can take the following values: + * - ::CU_MEM_ADVISE_SET_READ_MOSTLY: This implies that the data is mostly going to be read + * from and only occasionally written to. Any read accesses from any processor to this region will create a + * read-only copy of at least the accessed pages in that processor's memory. Additionally, if ::cuMemPrefetchAsync + * or ::cuMemPrefetchAsync_v2 is called on this region, it will create a read-only copy of the data on the destination processor. + * If the target location for ::cuMemPrefetchAsync_v2 is a host NUMA node and a read-only copy already exists on + * another host NUMA node, that copy will be migrated to the targeted host NUMA node. + * If any processor writes to this region, all copies of the corresponding page will be invalidated + * except for the one where the write occurred. If the writing processor is the CPU and the preferred location of + * the page is a host NUMA node, then the page will also be migrated to that host NUMA node. The \p location argument is ignored for this advice. + * Note that for a page to be read-duplicated, the accessing processor must either be the CPU or a GPU + * that has a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * Also, if a context is created on a device that does not have the device attribute + * ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS set, then read-duplication will not occur until + * all such contexts are destroyed. + * If the memory region refers to valid system-allocated pageable memory, then the accessing device must + * have a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS for a read-only + * copy to be created on that device. Note however that if the accessing device also has a non-zero value for the + * device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, then setting this advice + * will not create a read-only copy when that device accesses this memory region. + * + * - ::CU_MEM_ADVISE_UNSET_READ_MOSTLY: Undoes the effect of ::CU_MEM_ADVISE_SET_READ_MOSTLY and also prevents the + * Unified Memory driver from attempting heuristic read-duplication on the memory range. Any read-duplicated + * copies of the data will be collapsed into a single copy. The location for the collapsed + * copy will be the preferred location if the page has a preferred location and one of the read-duplicated + * copies was resident at that location. Otherwise, the location chosen is arbitrary. + * Note: The \p location argument is ignored for this advice. + * + * - ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION: This advice sets the preferred location for the + * data to be the memory belonging to \p location. When ::CUmemLocation::type is ::CU_MEM_LOCATION_TYPE_HOST, + * ::CUmemLocation::id is ignored and the preferred location is set to be host memory. To set the preferred location + * to a specific host NUMA node, applications must set ::CUmemLocation::type to ::CU_MEM_LOCATION_TYPE_HOST_NUMA and + * ::CUmemLocation::id must specify the NUMA ID of the host NUMA node. If ::CUmemLocation::type is set to ::CU_MEM_LOCATION_TYPE_HOST_NUMA_CURRENT, + * ::CUmemLocation::id will be ignored and the the host NUMA node closest to the calling thread's CPU will be used as the preferred location. + * If ::CUmemLocation::type is a ::CU_MEM_LOCATION_TYPE_DEVICE, then ::CUmemLocation::id must be a valid device ordinal + * and the device must have a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * Setting the preferred location does not cause data to migrate to that location immediately. Instead, it guides the migration policy + * when a fault occurs on that memory region. If the data is already in its preferred location and the + * faulting processor can establish a mapping without requiring the data to be migrated, then + * data migration will be avoided. On the other hand, if the data is not in its preferred location + * or if a direct mapping cannot be established, then it will be migrated to the processor accessing + * it. It is important to note that setting the preferred location does not prevent data prefetching + * done using ::cuMemPrefetchAsync. + * Having a preferred location can override the page thrash detection and resolution logic in the Unified + * Memory driver. Normally, if a page is detected to be constantly thrashing between for example host and device + * memory, the page may eventually be pinned to host memory by the Unified Memory driver. But + * if the preferred location is set as device memory, then the page will continue to thrash indefinitely. + * If ::CU_MEM_ADVISE_SET_READ_MOSTLY is also set on this memory region or any subset of it, then the + * policies associated with that advice will override the policies of this advice, unless read accesses from + * \p location will not result in a read-only copy being created on that procesor as outlined in description for + * the advice ::CU_MEM_ADVISE_SET_READ_MOSTLY. + * If the memory region refers to valid system-allocated pageable memory, and ::CUmemLocation::type is CU_MEM_LOCATION_TYPE_DEVICE + * then ::CUmemLocation::id must be a valid device that has a non-zero alue for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. + * + * - ::CU_MEM_ADVISE_UNSET_PREFERRED_LOCATION: Undoes the effect of ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION + * and changes the preferred location to none. The \p location argument is ignored for this advice. + * + * - ::CU_MEM_ADVISE_SET_ACCESSED_BY: This advice implies that the data will be accessed by processor \p location. + * The ::CUmemLocation::type must be either ::CU_MEM_LOCATION_TYPE_DEVICE with ::CUmemLocation::id representing a valid device + * ordinal or ::CU_MEM_LOCATION_TYPE_HOST and ::CUmemLocation::id will be ignored. All other location types are invalid. + * If ::CUmemLocation::id is a GPU, then the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS must be non-zero. + * This advice does not cause data migration and has no impact on the location of the data per se. Instead, + * it causes the data to always be mapped in the specified processor's page tables, as long as the + * location of the data permits a mapping to be established. If the data gets migrated for any reason, + * the mappings are updated accordingly. + * This advice is recommended in scenarios where data locality is not important, but avoiding faults is. + * Consider for example a system containing multiple GPUs with peer-to-peer access enabled, where the + * data located on one GPU is occasionally accessed by peer GPUs. In such scenarios, migrating data + * over to the other GPUs is not as important because the accesses are infrequent and the overhead of + * migration may be too high. But preventing faults can still help improve performance, and so having + * a mapping set up in advance is useful. Note that on CPU access of this data, the data may be migrated + * to host memory because the CPU typically cannot access device memory directly. Any GPU that had the + * ::CU_MEM_ADVISE_SET_ACCESSED_BY flag set for this data will now have its mapping updated to point to the + * page in host memory. + * If ::CU_MEM_ADVISE_SET_READ_MOSTLY is also set on this memory region or any subset of it, then the + * policies associated with that advice will override the policies of this advice. Additionally, if the + * preferred location of this memory region or any subset of it is also \p location, then the policies + * associated with ::CU_MEM_ADVISE_SET_PREFERRED_LOCATION will override the policies of this advice. + * If the memory region refers to valid system-allocated pageable memory, and ::CUmemLocation::type is ::CU_MEM_LOCATION_TYPE_DEVICE + * then device in ::CUmemLocation::id must have a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. + * Additionally, if ::CUmemLocation::id has a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, + * then this call has no effect. + * + * - ::CU_MEM_ADVISE_UNSET_ACCESSED_BY: Undoes the effect of ::CU_MEM_ADVISE_SET_ACCESSED_BY. Any mappings to + * the data from \p location may be removed at any time causing accesses to result in non-fatal page faults. + * If the memory region refers to valid system-allocated pageable memory, and ::CUmemLocation::type is ::CU_MEM_LOCATION_TYPE_DEVICE + * then device in ::CUmemLocation::id must have a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. + * Additionally, if ::CUmemLocation::id has a non-zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS_USES_HOST_PAGE_TABLES, + * then this call has no effect. + * + * \param devPtr - Pointer to memory to set the advice for + * \param count - Size in bytes of the memory range + * \param advice - Advice to be applied for the specified memory range + * \param location - location to apply the advice for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemcpy, ::cuMemcpyPeer, ::cuMemcpyAsync, + * ::cuMemcpy3DPeerAsync, ::cuMemPrefetchAsync, ::cuMemAdvise + * ::cudaMemAdvise + */ +CUresult CUDAAPI cuMemAdvise_v2(CUdeviceptr devPtr, size_t count, CUmem_advise advice, CUmemLocation location); + +/** + * \brief Query an attribute of a given memory range + * + * Query an attribute about the memory range starting at \p devPtr with a size of \p count bytes. The + * memory range must refer to managed memory allocated via ::cuMemAllocManaged or declared via + * __managed__ variables. + * + * The \p attribute parameter can take the following values: + * - ::CU_MEM_RANGE_ATTRIBUTE_READ_MOSTLY: If this attribute is specified, \p data will be interpreted + * as a 32-bit integer, and \p dataSize must be 4. The result returned will be 1 if all pages in the given + * memory range have read-duplication enabled, or 0 otherwise. + * - ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION: If this attribute is specified, \p data will be + * interpreted as a 32-bit integer, and \p dataSize must be 4. The result returned will be a GPU device + * id if all pages in the memory range have that GPU as their preferred location, or it will be CU_DEVICE_CPU + * if all pages in the memory range have the CPU as their preferred location, or it will be CU_DEVICE_INVALID + * if either all the pages don't have the same preferred location or some of the pages don't have a + * preferred location at all. Note that the actual location of the pages in the memory range at the time of + * the query may be different from the preferred location. + * - ::CU_MEM_RANGE_ATTRIBUTE_ACCESSED_BY: If this attribute is specified, \p data will be interpreted + * as an array of 32-bit integers, and \p dataSize must be a non-zero multiple of 4. The result returned + * will be a list of device ids that had ::CU_MEM_ADVISE_SET_ACCESSED_BY set for that entire memory range. + * If any device does not have that advice set for the entire memory range, that device will not be included. + * If \p data is larger than the number of devices that have that advice set for that memory range, + * CU_DEVICE_INVALID will be returned in all the extra space provided. For ex., if \p dataSize is 12 + * (i.e. \p data has 3 elements) and only device 0 has the advice set, then the result returned will be + * { 0, CU_DEVICE_INVALID, CU_DEVICE_INVALID }. If \p data is smaller than the number of devices that have + * that advice set, then only as many devices will be returned as can fit in the array. There is no + * guarantee on which specific devices will be returned, however. + * - ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION: If this attribute is specified, \p data will be + * interpreted as a 32-bit integer, and \p dataSize must be 4. The result returned will be the last location + * to which all pages in the memory range were prefetched explicitly via ::cuMemPrefetchAsync. This will either be + * a GPU id or CU_DEVICE_CPU depending on whether the last location for prefetch was a GPU or the CPU + * respectively. If any page in the memory range was never explicitly prefetched or if all pages were not + * prefetched to the same location, CU_DEVICE_INVALID will be returned. Note that this simply returns the + * last location that the application requested to prefetch the memory range to. It gives no indication as to + * whether the prefetch operation to that location has completed or even begun. + * - ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_TYPE: If this attribute is specified, \p data will be + * interpreted as a ::CUmemLocationType, and \p dataSize must be sizeof(CUmemLocationType). The ::CUmemLocationType returned will be + * ::CU_MEM_LOCATION_TYPE_DEVICE if all pages in the memory range have the same GPU as their preferred location, or ::CUmemLocationType + * will be ::CU_MEM_LOCATION_TYPE_HOST if all pages in the memory range have the CPU as their preferred location, or it will be ::CU_MEM_LOCATION_TYPE_HOST_NUMA + * if all the pages in the memory range have the same host NUMA node ID as their preferred location or it will be ::CU_MEM_LOCATION_TYPE_INVALID + * if either all the pages don't have the same preferred location or some of the pages don't have a preferred location at all. + * Note that the actual location type of the pages in the memory range at the time of the query may be different from the preferred location type. + * - ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_ID: If this attribute is specified, \p data will be + * interpreted as a 32-bit integer, and \p dataSize must be 4. If the ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_TYPE query for the same address range + * returns ::CU_MEM_LOCATION_TYPE_DEVICE, it will be a valid device ordinal or if it returns ::CU_MEM_LOCATION_TYPE_HOST_NUMA, it will be a valid host NUMA node ID + * or if it returns any other location type, the id should be ignored. + * - ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_TYPE: If this attribute is specified, \p data will be + * interpreted as a ::CUmemLocationType, and \p dataSize must be sizeof(CUmemLocationType). The result returned will be the last location + * to which all pages in the memory range were prefetched explicitly via ::cuMemPrefetchAsync. The ::CUmemLocationType returned + * will be ::CU_MEM_LOCATION_TYPE_DEVICE if the last prefetch location was a GPU or ::CU_MEM_LOCATION_TYPE_HOST if it was the CPU or ::CU_MEM_LOCATION_TYPE_HOST_NUMA if + * the last prefetch location was a specific host NUMA node. If any page in the memory range was never explicitly prefetched or if all pages were not + * prefetched to the same location, ::CUmemLocationType will be ::CU_MEM_LOCATION_TYPE_INVALID. + * Note that this simply returns the last location type that the application requested to prefetch the memory range to. It gives no indication as to + * whether the prefetch operation to that location has completed or even begun. + * - ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_ID: If this attribute is specified, \p data will be + * interpreted as a 32-bit integer, and \p dataSize must be 4. If the ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_TYPE query for the same address range + * returns ::CU_MEM_LOCATION_TYPE_DEVICE, it will be a valid device ordinal or if it returns ::CU_MEM_LOCATION_TYPE_HOST_NUMA, it will be a valid host NUMA node ID + * or if it returns any other location type, the id should be ignored. + * + * \param data - A pointers to a memory location where the result + * of each attribute query will be written to. + * \param dataSize - Array containing the size of data + * \param attribute - The attribute to query + * \param devPtr - Start of the range to query + * \param count - Size of the range to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * \note_async + * \note_null_stream + * + * \sa ::cuMemRangeGetAttributes, ::cuMemPrefetchAsync, + * ::cuMemAdvise, + * ::cudaMemRangeGetAttribute + */ +CUresult CUDAAPI cuMemRangeGetAttribute(void *data, size_t dataSize, CUmem_range_attribute attribute, CUdeviceptr devPtr, size_t count); + +/** + * \brief Query attributes of a given memory range. + * + * Query attributes of the memory range starting at \p devPtr with a size of \p count bytes. The + * memory range must refer to managed memory allocated via ::cuMemAllocManaged or declared via + * __managed__ variables. The \p attributes array will be interpreted to have \p numAttributes + * entries. The \p dataSizes array will also be interpreted to have \p numAttributes entries. + * The results of the query will be stored in \p data. + * + * The list of supported attributes are given below. Please refer to ::cuMemRangeGetAttribute for + * attribute descriptions and restrictions. + * + * - ::CU_MEM_RANGE_ATTRIBUTE_READ_MOSTLY + * - ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION + * - ::CU_MEM_RANGE_ATTRIBUTE_ACCESSED_BY + * - ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION + * - ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_TYPE + * - ::CU_MEM_RANGE_ATTRIBUTE_PREFERRED_LOCATION_ID + * - ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_TYPE + * - ::CU_MEM_RANGE_ATTRIBUTE_LAST_PREFETCH_LOCATION_ID + * + * \param data - A two-dimensional array containing pointers to memory + * locations where the result of each attribute query will be written to. + * \param dataSizes - Array containing the sizes of each result + * \param attributes - An array of attributes to query + * (numAttributes and the number of attributes in this array should match) + * \param numAttributes - Number of attributes to query + * \param devPtr - Start of the range to query + * \param count - Size of the range to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa ::cuMemRangeGetAttribute, ::cuMemAdvise, + * ::cuMemPrefetchAsync, + * ::cudaMemRangeGetAttributes + */ +CUresult CUDAAPI cuMemRangeGetAttributes(void **data, size_t *dataSizes, CUmem_range_attribute *attributes, size_t numAttributes, CUdeviceptr devPtr, size_t count); + +/** + * \brief Set attributes on a previously allocated memory region + * + * The supported attributes are: + * + * - ::CU_POINTER_ATTRIBUTE_SYNC_MEMOPS: + * + * A boolean attribute that can either be set (1) or unset (0). When set, + * the region of memory that \p ptr points to is guaranteed to always synchronize + * memory operations that are synchronous. If there are some previously initiated + * synchronous memory operations that are pending when this attribute is set, the + * function does not return until those memory operations are complete. + * See further documentation in the section titled "API synchronization behavior" + * to learn more about cases when synchronous memory operations can + * exhibit asynchronous behavior. + * \p value will be considered as a pointer to an unsigned integer to which this attribute is to be set. + * + * \param value - Pointer to memory containing the value to be set + * \param attribute - Pointer attribute to set + * \param ptr - Pointer to a memory region allocated using CUDA memory allocation APIs + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa ::cuPointerGetAttribute, + * ::cuPointerGetAttributes, + * ::cuMemAlloc, + * ::cuMemFree, + * ::cuMemAllocHost, + * ::cuMemFreeHost, + * ::cuMemHostAlloc, + * ::cuMemHostRegister, + * ::cuMemHostUnregister + */ +CUresult CUDAAPI cuPointerSetAttribute(const void *value, CUpointer_attribute attribute, CUdeviceptr ptr); + +/** + * \brief Returns information about a pointer. + * + * The supported attributes are (refer to ::cuPointerGetAttribute for attribute descriptions and restrictions): + * + * - ::CU_POINTER_ATTRIBUTE_CONTEXT + * - ::CU_POINTER_ATTRIBUTE_MEMORY_TYPE + * - ::CU_POINTER_ATTRIBUTE_DEVICE_POINTER + * - ::CU_POINTER_ATTRIBUTE_HOST_POINTER + * - ::CU_POINTER_ATTRIBUTE_SYNC_MEMOPS + * - ::CU_POINTER_ATTRIBUTE_BUFFER_ID + * - ::CU_POINTER_ATTRIBUTE_IS_MANAGED + * - ::CU_POINTER_ATTRIBUTE_DEVICE_ORDINAL + * - ::CU_POINTER_ATTRIBUTE_RANGE_START_ADDR + * - ::CU_POINTER_ATTRIBUTE_RANGE_SIZE + * - ::CU_POINTER_ATTRIBUTE_MAPPED + * - ::CU_POINTER_ATTRIBUTE_IS_LEGACY_CUDA_IPC_CAPABLE + * - ::CU_POINTER_ATTRIBUTE_ALLOWED_HANDLE_TYPES + * - ::CU_POINTER_ATTRIBUTE_MEMPOOL_HANDLE + * + * \param numAttributes - Number of attributes to query + * \param attributes - An array of attributes to query + * (numAttributes and the number of attributes in this array should match) + * \param data - A two-dimensional array containing pointers to memory + * locations where the result of each attribute query will be written to. + * \param ptr - Pointer to query + * + * Unlike ::cuPointerGetAttribute, this function will not return an error when the \p ptr + * encountered is not a valid CUDA pointer. Instead, the attributes are assigned default NULL values + * and CUDA_SUCCESS is returned. + * + * If \p ptr was not allocated by, mapped by, or registered with a ::CUcontext which uses UVA + * (Unified Virtual Addressing), ::CUDA_ERROR_INVALID_CONTEXT is returned. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuPointerGetAttribute, + * ::cuPointerSetAttribute, + * ::cudaPointerGetAttributes + */ +CUresult CUDAAPI cuPointerGetAttributes(unsigned int numAttributes, CUpointer_attribute *attributes, void **data, CUdeviceptr ptr); + +/** @} */ /* END CUDA_UNIFIED */ + +/** + * \defgroup CUDA_STREAM Stream Management + * + * ___MANBRIEF___ stream management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the stream management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Create a stream + * + * Creates a stream and returns a handle in \p phStream. The \p Flags argument + * determines behaviors of the stream. + * + * Valid values for \p Flags are: + * - ::CU_STREAM_DEFAULT: Default stream creation flag. + * - ::CU_STREAM_NON_BLOCKING: Specifies that work running in the created + * stream may run concurrently with work in stream 0 (the NULL stream), and that + * the created stream should perform no implicit synchronization with stream 0. + * + * \param phStream - Returned newly created stream + * \param Flags - Parameters for stream creation + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreateWithPriority, + * ::cuGreenCtxStreamCreate, + * ::cuStreamGetPriority, + * ::cuStreamGetFlags, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamCreate, + * ::cudaStreamCreateWithFlags + */ +CUresult CUDAAPI cuStreamCreate(CUstream *phStream, unsigned int Flags); + +/** + * \brief Create a stream with the given priority + * + * Creates a stream with the specified priority and returns a handle in \p phStream. + * This affects the scheduling priority of work in the stream. Priorities provide a + * hint to preferentially run work with higher priority when possible, but do + * not preempt already-running work or provide any other functional guarantee on + * execution order. + * + * \p priority follows a convention where lower numbers represent higher priorities. + * '0' represents default priority. The range of meaningful numerical priorities can + * be queried using ::cuCtxGetStreamPriorityRange. If the specified priority is + * outside the numerical range returned by ::cuCtxGetStreamPriorityRange, + * it will automatically be clamped to the lowest or the highest number in the range. + * + * \param phStream - Returned newly created stream + * \param flags - Flags for stream creation. See ::cuStreamCreate for a list of + * valid flags + * \param priority - Stream priority. Lower numbers represent higher priorities. + * See ::cuCtxGetStreamPriorityRange for more information about + * meaningful stream priorities that can be passed. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \note Stream priorities are supported only on GPUs + * with compute capability 3.5 or higher. + * + * \note In the current implementation, only compute kernels launched in + * priority streams are affected by the stream's priority. Stream priorities have + * no effect on host-to-device and device-to-host memory operations. + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreate, + * ::cuGreenCtxStreamCreate, + * ::cuStreamGetPriority, + * ::cuCtxGetStreamPriorityRange, + * ::cuStreamGetFlags, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamCreateWithPriority + */ +CUresult CUDAAPI cuStreamCreateWithPriority(CUstream *phStream, unsigned int flags, int priority); + + +/** + * \brief Query the priority of a given stream + * + * Query the priority of a stream created using ::cuStreamCreate, ::cuStreamCreateWithPriority or ::cuGreenCtxStreamCreate + * and return the priority in \p priority. Note that if the stream was created with a + * priority outside the numerical range returned by ::cuCtxGetStreamPriorityRange, + * this function returns the clamped priority. + * See ::cuStreamCreateWithPriority for details about priority clamping. + * + * \param hStream - Handle to the stream to be queried + * \param priority - Pointer to a signed integer in which the stream's priority is returned + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreate, + * ::cuStreamCreateWithPriority, + * ::cuGreenCtxStreamCreate, + * ::cuCtxGetStreamPriorityRange, + * ::cuStreamGetFlags, + * ::cudaStreamGetPriority + */ +CUresult CUDAAPI cuStreamGetPriority(CUstream hStream, int *priority); + +/** + * \brief Query the flags of a given stream + * + * Query the flags of a stream created using ::cuStreamCreate, ::cuStreamCreateWithPriority or ::cuGreenCtxStreamCreate + * and return the flags in \p flags. + * + * \param hStream - Handle to the stream to be queried + * \param flags - Pointer to an unsigned integer in which the stream's flags are returned + * The value returned in \p flags is a logical 'OR' of all flags that + * were used while creating this stream. See ::cuStreamCreate for the list + * of valid flags + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreate, + * ::cuGreenCtxStreamCreate, + * ::cuStreamGetPriority, + * ::cudaStreamGetFlags + */ +CUresult CUDAAPI cuStreamGetFlags(CUstream hStream, unsigned int *flags); + +/** + * \brief Returns the unique Id associated with the stream handle supplied + * + * Returns in \p streamId the unique Id which is associated with the given stream handle. + * The Id is unique for the life of the program. + * + * The stream handle \p hStream can refer to any of the following: + *

      + *
    • a stream created via any of the CUDA driver APIs such as ::cuStreamCreate + * and ::cuStreamCreateWithPriority, or their runtime API equivalents such as + * ::cudaStreamCreate, ::cudaStreamCreateWithFlags and ::cudaStreamCreateWithPriority. + * Passing an invalid handle will result in undefined behavior.
    • + *
    • any of the special streams such as the NULL stream, ::CU_STREAM_LEGACY and + * ::CU_STREAM_PER_THREAD. The runtime API equivalents of these are also accepted, + * which are NULL, ::cudaStreamLegacy and ::cudaStreamPerThread respectively.
    • + *
    + * + * \param hStream - Handle to the stream to be queried + * \param streamId - Pointer to store the Id of the stream + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreate, + * ::cuStreamGetPriority, + * ::cudaStreamGetId + */ +CUresult CUDAAPI cuStreamGetId(CUstream hStream, unsigned long long *streamId); + +/** + * \brief Query the context associated with a stream + * + * Returns the CUDA context that the stream is associated with. + * + * Note there is a later version of this API, ::cuStreamGetCtx_v2. It will + * supplant this version in CUDA 13.0. It is recommended to use ::cuStreamGetCtx_v2 + * till then as this version will return ::CUDA_ERROR_NOT_SUPPORTED for streams created via the API ::cuGreenCtxStreamCreate. + * + * The stream handle \p hStream can refer to any of the following: + *
      + *
    • a stream created via any of the CUDA driver APIs such as ::cuStreamCreate + * and ::cuStreamCreateWithPriority, or their runtime API equivalents such as + * ::cudaStreamCreate, ::cudaStreamCreateWithFlags and ::cudaStreamCreateWithPriority. + * The returned context is the context that was active in the calling thread when the + * stream was created. Passing an invalid handle will result in undefined behavior.
    • + *
    • any of the special streams such as the NULL stream, ::CU_STREAM_LEGACY and + * ::CU_STREAM_PER_THREAD. The runtime API equivalents of these are also accepted, + * which are NULL, ::cudaStreamLegacy and ::cudaStreamPerThread respectively. + * Specifying any of the special handles will return the context current to the + * calling thread. If no context is current to the calling thread, + * ::CUDA_ERROR_INVALID_CONTEXT is returned.
    • + *
    + * + * \param hStream - Handle to the stream to be queried + * \param pctx - Returned context associated with the stream + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreateWithPriority, + * ::cuStreamGetPriority, + * ::cuStreamGetFlags, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamCreate, + * ::cuStreamGetCtx_v2, + * ::cudaStreamCreateWithFlags + */ +CUresult CUDAAPI cuStreamGetCtx(CUstream hStream, CUcontext *pctx); + +/** + * \brief Query the contexts associated with a stream + * + * Returns the contexts that the stream is associated with. + * + * If the stream is associated with a green context, the API returns the green context in \p pGreenCtx + * and the primary context of the associated device in \p pCtx. + * + * If the stream is associated with a regular context, the API returns the regular context in \p pCtx + * and NULL in \p pGreenCtx. + * + * The stream handle \p hStream can refer to any of the following: + *
      + *
    • a stream created via any of the CUDA driver APIs such as ::cuStreamCreate, + * ::cuStreamCreateWithPriority and ::cuGreenCtxStreamCreate, or their runtime API equivalents such as + * ::cudaStreamCreate, ::cudaStreamCreateWithFlags and ::cudaStreamCreateWithPriority. + * Passing an invalid handle will result in undefined behavior.
    • + *
    • any of the special streams such as the NULL stream, ::CU_STREAM_LEGACY and + * ::CU_STREAM_PER_THREAD. The runtime API equivalents of these are also accepted, + * which are NULL, ::cudaStreamLegacy and ::cudaStreamPerThread respectively. + * If any of the special handles are specified, the API will operate on the context current to the + * calling thread. If a green context (that was converted via ::cuCtxFromGreenCtx() before setting it current) + * is current to the calling thread, the API will return the green context in \p pGreenCtx + * and the primary context of the associated device in \p pCtx. If a regular context is current, + * the API returns the regular context in \p pCtx and NULL in \p pGreenCtx. + * Note that specifying ::CU_STREAM_PER_THREAD or ::cudaStreamPerThread will return ::CUDA_ERROR_INVALID_HANDLE + * if a green context is current to the calling thread. + * If no context is current to the calling thread, ::CUDA_ERROR_INVALID_CONTEXT is returned.
    • + *
    + * + * \param hStream - Handle to the stream to be queried + * \param pCtx - Returned regular context associated with the stream + * \param pGreenCtx - Returned green context if the stream is associated with a green context or NULL if not + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreate + * ::cuStreamCreateWithPriority, + * ::cuGreenCtxStreamCreate, + * ::cuStreamGetPriority, + * ::cuStreamGetFlags, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamCreate, + * ::cudaStreamCreateWithFlags, + */ +CUresult CUDAAPI cuStreamGetCtx_v2(CUstream hStream, CUcontext *pCtx, CUgreenCtx *pGreenCtx); + +/** + * \brief Make a compute stream wait on an event + * + * Makes all future work submitted to \p hStream wait for all work captured in + * \p hEvent. See ::cuEventRecord() for details on what is captured by an event. + * The synchronization will be performed efficiently on the device when applicable. + * \p hEvent may be from a different context or device than \p hStream. + * + * flags include: + * - ::CU_EVENT_WAIT_DEFAULT: Default event creation flag. + * - ::CU_EVENT_WAIT_EXTERNAL: Event is captured in the graph as an external + * event node when performing stream capture. This flag is invalid outside + * of stream capture. + * + * \param hStream - Stream to wait + * \param hEvent - Event to wait on (may not be NULL) + * \param Flags - See ::CUevent_capture_flags + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * \note_null_stream + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuEventRecord, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cuStreamDestroy, + * ::cudaStreamWaitEvent + */ +CUresult CUDAAPI cuStreamWaitEvent(CUstream hStream, CUevent hEvent, unsigned int Flags); + +/** + * \brief Add a callback to a compute stream + * + * \note This function is slated for eventual deprecation and removal. If + * you do not require the callback to execute in case of a device error, + * consider using ::cuLaunchHostFunc. Additionally, this function is not + * supported with ::cuStreamBeginCapture and ::cuStreamEndCapture, unlike + * ::cuLaunchHostFunc. + * + * Adds a callback to be called on the host after all currently enqueued + * items in the stream have completed. For each + * cuStreamAddCallback call, the callback will be executed exactly once. + * The callback will block later work in the stream until it is finished. + * + * The callback may be passed ::CUDA_SUCCESS or an error code. In the event + * of a device error, all subsequently executed callbacks will receive an + * appropriate ::CUresult. + * + * Callbacks must not make any CUDA API calls. Attempting to use a CUDA API + * will result in ::CUDA_ERROR_NOT_PERMITTED. Callbacks must not perform any + * synchronization that may depend on outstanding device work or other callbacks + * that are not mandated to run earlier. Callbacks without a mandated order + * (in independent streams) execute in undefined order and may be serialized. + * + * For the purposes of Unified Memory, callback execution makes a number of + * guarantees: + *
      + *
    • The callback stream is considered idle for the duration of the + * callback. Thus, for example, a callback may always use memory attached + * to the callback stream.
    • + *
    • The start of execution of a callback has the same effect as + * synchronizing an event recorded in the same stream immediately prior to + * the callback. It thus synchronizes streams which have been "joined" + * prior to the callback.
    • + *
    • Adding device work to any stream does not have the effect of making + * the stream active until all preceding host functions and stream callbacks + * have executed. Thus, for + * example, a callback might use global attached memory even if work has + * been added to another stream, if the work has been ordered behind the + * callback with an event.
    • + *
    • Completion of a callback does not cause a stream to become + * active except as described above. The callback stream will remain idle + * if no device work follows the callback, and will remain idle across + * consecutive callbacks without device work in between. Thus, for example, + * stream synchronization can be done by signaling from a callback at the + * end of the stream.
    • + *
    + * + * \param hStream - Stream to add callback to + * \param callback - The function to call once preceding stream operations are complete + * \param userData - User specified data to be passed to the callback function + * \param flags - Reserved for future use, must be 0 + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_null_stream + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamWaitEvent, + * ::cuStreamDestroy, + * ::cuMemAllocManaged, + * ::cuStreamAttachMemAsync, + * ::cuLaunchHostFunc, + * ::cudaStreamAddCallback + */ +CUresult CUDAAPI cuStreamAddCallback(CUstream hStream, CUstreamCallback callback, void *userData, unsigned int flags); + +/** + * \brief Begins graph capture on a stream + * + * Begin graph capture on \p hStream. When a stream is in capture mode, all operations + * pushed into the stream will not be executed, but will instead be captured into + * a graph, which will be returned via ::cuStreamEndCapture. Capture may not be initiated + * if \p stream is CU_STREAM_LEGACY. Capture must be ended on the same stream in which + * it was initiated, and it may only be initiated if the stream is not already in capture + * mode. The capture mode may be queried via ::cuStreamIsCapturing. A unique id + * representing the capture sequence may be queried via ::cuStreamGetCaptureInfo. + * + * If \p mode is not ::CU_STREAM_CAPTURE_MODE_RELAXED, ::cuStreamEndCapture must be + * called on this stream from the same thread. + * + * \param hStream - Stream in which to initiate capture + * \param mode - Controls the interaction of this capture sequence with other API + * calls that are potentially unsafe. For more details see + * ::cuThreadExchangeStreamCaptureMode. + * + * \note Kernels captured using this API must not use texture and surface references. + * Reading or writing through any texture or surface reference is undefined + * behavior. This restriction does not apply to texture and surface objects. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuStreamCreate, + * ::cuStreamIsCapturing, + * ::cuStreamEndCapture, + * ::cuThreadExchangeStreamCaptureMode + */ +CUresult CUDAAPI cuStreamBeginCapture(CUstream hStream, CUstreamCaptureMode mode); + +/** + * \brief Begins graph capture on a stream to an existing graph + * + * Begin graph capture on \p hStream, placing new nodes into an existing graph. When a stream is + * in capture mode, all operations pushed into the stream will not be executed, but will instead + * be captured into \p hGraph. The graph will not be instantiable until the user calls + * ::cuStreamEndCapture. + * + * Capture may not be initiated if \p stream is CU_STREAM_LEGACY. Capture must be ended on the + * same stream in which it was initiated, and it may only be initiated if the stream is not + * already in capture mode. The capture mode may be queried via ::cuStreamIsCapturing. A unique id + * representing the capture sequence may be queried via ::cuStreamGetCaptureInfo. + * + * If \p mode is not ::CU_STREAM_CAPTURE_MODE_RELAXED, ::cuStreamEndCapture must be + * called on this stream from the same thread. + * + * \param hStream - Stream in which to initiate capture. + * \param hGraph - Graph to capture into. + * \param dependencies - Dependencies of the first node captured in the stream. Can be NULL if numDependencies is 0. + * \param dependencyData - Optional array of data associated with each dependency. + * \param numDependencies - Number of dependencies. + * \param mode - Controls the interaction of this capture sequence with other API + * calls that are potentially unsafe. For more details see + * ::cuThreadExchangeStreamCaptureMode. + * + * \note Kernels captured using this API must not use texture and surface references. + * Reading or writing through any texture or surface reference is undefined + * behavior. This restriction does not apply to texture and surface objects. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuStreamBeginCapture, + * ::cuStreamCreate, + * ::cuStreamIsCapturing, + * ::cuStreamEndCapture, + * ::cuThreadExchangeStreamCaptureMode, + * ::cuGraphAddNode, + */ +CUresult CUDAAPI cuStreamBeginCaptureToGraph(CUstream hStream, CUgraph hGraph, const CUgraphNode *dependencies, const CUgraphEdgeData *dependencyData, size_t numDependencies, CUstreamCaptureMode mode); + +/** + * \brief Swaps the stream capture interaction mode for a thread + * + * Sets the calling thread's stream capture interaction mode to the value contained + * in \p *mode, and overwrites \p *mode with the previous mode for the thread. To + * facilitate deterministic behavior across function or module boundaries, callers + * are encouraged to use this API in a push-pop fashion: \code + CUstreamCaptureMode mode = desiredMode; + cuThreadExchangeStreamCaptureMode(&mode); + ... + cuThreadExchangeStreamCaptureMode(&mode); // restore previous mode + * \endcode + * + * During stream capture (see ::cuStreamBeginCapture), some actions, such as a call + * to ::cudaMalloc, may be unsafe. In the case of ::cudaMalloc, the operation is + * not enqueued asynchronously to a stream, and is not observed by stream capture. + * Therefore, if the sequence of operations captured via ::cuStreamBeginCapture + * depended on the allocation being replayed whenever the graph is launched, the + * captured graph would be invalid. + * + * Therefore, stream capture places restrictions on API calls that can be made within + * or concurrently to a ::cuStreamBeginCapture-::cuStreamEndCapture sequence. This + * behavior can be controlled via this API and flags to ::cuStreamBeginCapture. + * + * A thread's mode is one of the following: + * - \p CU_STREAM_CAPTURE_MODE_GLOBAL: This is the default mode. If the local thread has + * an ongoing capture sequence that was not initiated with + * \p CU_STREAM_CAPTURE_MODE_RELAXED at \p cuStreamBeginCapture, or if any other thread + * has a concurrent capture sequence initiated with \p CU_STREAM_CAPTURE_MODE_GLOBAL, + * this thread is prohibited from potentially unsafe API calls. + * - \p CU_STREAM_CAPTURE_MODE_THREAD_LOCAL: If the local thread has an ongoing capture + * sequence not initiated with \p CU_STREAM_CAPTURE_MODE_RELAXED, it is prohibited + * from potentially unsafe API calls. Concurrent capture sequences in other threads + * are ignored. + * - \p CU_STREAM_CAPTURE_MODE_RELAXED: The local thread is not prohibited from potentially + * unsafe API calls. Note that the thread is still prohibited from API calls which + * necessarily conflict with stream capture, for example, attempting ::cuEventQuery + * on an event that was last recorded inside a capture sequence. + * + * \param mode - Pointer to mode value to swap with the current mode + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuStreamBeginCapture + */ +CUresult CUDAAPI cuThreadExchangeStreamCaptureMode(CUstreamCaptureMode *mode); + +/** + * \brief Ends capture on a stream, returning the captured graph + * + * End capture on \p hStream, returning the captured graph via \p phGraph. + * Capture must have been initiated on \p hStream via a call to ::cuStreamBeginCapture. + * If capture was invalidated, due to a violation of the rules of stream capture, then + * a NULL graph will be returned. + * + * If the \p mode argument to ::cuStreamBeginCapture was not + * ::CU_STREAM_CAPTURE_MODE_RELAXED, this call must be from the same thread as + * ::cuStreamBeginCapture. + * + * \param hStream - Stream to query + * \param phGraph - The captured graph + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_STREAM_CAPTURE_WRONG_THREAD + * \notefnerr + * + * \sa + * ::cuStreamCreate, + * ::cuStreamBeginCapture, + * ::cuStreamIsCapturing, + * ::cuGraphDestroy + */ +CUresult CUDAAPI cuStreamEndCapture(CUstream hStream, CUgraph *phGraph); + +/** + * \brief Returns a stream's capture status + * + * Return the capture status of \p hStream via \p captureStatus. After a successful + * call, \p *captureStatus will contain one of the following: + * - ::CU_STREAM_CAPTURE_STATUS_NONE: The stream is not capturing. + * - ::CU_STREAM_CAPTURE_STATUS_ACTIVE: The stream is capturing. + * - ::CU_STREAM_CAPTURE_STATUS_INVALIDATED: The stream was capturing but an error + * has invalidated the capture sequence. The capture sequence must be terminated + * with ::cuStreamEndCapture on the stream where it was initiated in order to + * continue using \p hStream. + * + * Note that, if this is called on ::CU_STREAM_LEGACY (the "null stream") while + * a blocking stream in the same context is capturing, it will return + * ::CUDA_ERROR_STREAM_CAPTURE_IMPLICIT and \p *captureStatus is unspecified + * after the call. The blocking stream capture is not invalidated. + * + * When a blocking stream is capturing, the legacy stream is in an + * unusable state until the blocking stream capture is terminated. The legacy + * stream is not supported for stream capture, but attempted use would have an + * implicit dependency on the capturing stream(s). + * + * \param hStream - Stream to query + * \param captureStatus - Returns the stream's capture status + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_STREAM_CAPTURE_IMPLICIT + * \notefnerr + * + * \sa + * ::cuStreamCreate, + * ::cuStreamBeginCapture, + * ::cuStreamEndCapture + */ +CUresult CUDAAPI cuStreamIsCapturing(CUstream hStream, CUstreamCaptureStatus *captureStatus); + + +/** + * \brief Query a stream's capture state + * + * Query stream state related to stream capture. + * + * If called on ::CU_STREAM_LEGACY (the "null stream") while a stream not created + * with ::CU_STREAM_NON_BLOCKING is capturing, returns ::CUDA_ERROR_STREAM_CAPTURE_IMPLICIT. + * + * Valid data (other than capture status) is returned only if both of the following are true: + * - the call returns CUDA_SUCCESS + * - the returned capture status is ::CU_STREAM_CAPTURE_STATUS_ACTIVE + * + * \param hStream - The stream to query + * \param captureStatus_out - Location to return the capture status of the stream; required + * \param id_out - Optional location to return an id for the capture sequence, which is + * unique over the lifetime of the process + * \param graph_out - Optional location to return the graph being captured into. All + * operations other than destroy and node removal are permitted on the graph + * while the capture sequence is in progress. This API does not transfer + * ownership of the graph, which is transferred or destroyed at + * ::cuStreamEndCapture. Note that the graph handle may be invalidated before + * end of capture for certain errors. Nodes that are or become + * unreachable from the original stream at ::cuStreamEndCapture due to direct + * actions on the graph do not trigger ::CUDA_ERROR_STREAM_CAPTURE_UNJOINED. + * \param dependencies_out - Optional location to store a pointer to an array of nodes. + * The next node to be captured in the stream will depend on this set of nodes, + * absent operations such as event wait which modify this set. The array pointer + * is valid until the next API call which operates on the stream or until the + * capture is terminated. The node handles may be copied out and are valid until + * they or the graph is destroyed. The driver-owned array may also be passed + * directly to APIs that operate on the graph (not the stream) without copying. + * \param numDependencies_out - Optional location to store the size of the array + * returned in dependencies_out. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_STREAM_CAPTURE_IMPLICIT + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuStreamGetCaptureInfo_v3 + * ::cuStreamBeginCapture, + * ::cuStreamIsCapturing, + * ::cuStreamUpdateCaptureDependencies + */ +CUresult CUDAAPI cuStreamGetCaptureInfo(CUstream hStream, CUstreamCaptureStatus *captureStatus_out, + cuuint64_t *id_out, CUgraph *graph_out, const CUgraphNode **dependencies_out, size_t *numDependencies_out); + +/** + * \brief Query a stream's capture state (12.3+) + * + * Query stream state related to stream capture. + * + * If called on ::CU_STREAM_LEGACY (the "null stream") while a stream not created + * with ::CU_STREAM_NON_BLOCKING is capturing, returns ::CUDA_ERROR_STREAM_CAPTURE_IMPLICIT. + * + * Valid data (other than capture status) is returned only if both of the following are true: + * - the call returns CUDA_SUCCESS + * - the returned capture status is ::CU_STREAM_CAPTURE_STATUS_ACTIVE + * + * If \p edgeData_out is non-NULL then \p dependencies_out must be as well. If + * \p dependencies_out is non-NULL and \p edgeData_out is NULL, but there is non-zero edge + * data for one or more of the current stream dependencies, the call will return + * ::CUDA_ERROR_LOSSY_QUERY. + * + * \param hStream - The stream to query + * \param captureStatus_out - Location to return the capture status of the stream; required + * \param id_out - Optional location to return an id for the capture sequence, which is + * unique over the lifetime of the process + * \param graph_out - Optional location to return the graph being captured into. All + * operations other than destroy and node removal are permitted on the graph + * while the capture sequence is in progress. This API does not transfer + * ownership of the graph, which is transferred or destroyed at + * ::cuStreamEndCapture. Note that the graph handle may be invalidated before + * end of capture for certain errors. Nodes that are or become + * unreachable from the original stream at ::cuStreamEndCapture due to direct + * actions on the graph do not trigger ::CUDA_ERROR_STREAM_CAPTURE_UNJOINED. + * \param dependencies_out - Optional location to store a pointer to an array of nodes. + * The next node to be captured in the stream will depend on this set of nodes, + * absent operations such as event wait which modify this set. The array pointer + * is valid until the next API call which operates on the stream or until the + * capture is terminated. The node handles may be copied out and are valid until + * they or the graph is destroyed. The driver-owned array may also be passed + * directly to APIs that operate on the graph (not the stream) without copying. + * \param edgeData_out - Optional location to store a pointer to an array of graph edge + * data. This array parallels \c dependencies_out; the next node to be added + * has an edge to \c dependencies_out[i] with annotation \c edgeData_out[i] for + * each \c i. The array pointer is valid until the next API call which operates + * on the stream or until the capture is terminated. + * \param numDependencies_out - Optional location to store the size of the array + * returned in dependencies_out. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_STREAM_CAPTURE_IMPLICIT, + * ::CUDA_ERROR_LOSSY_QUERY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuStreamGetCaptureInfo + * ::cuStreamBeginCapture, + * ::cuStreamIsCapturing, + * ::cuStreamUpdateCaptureDependencies + */ +CUresult CUDAAPI cuStreamGetCaptureInfo_v3(CUstream hStream, CUstreamCaptureStatus *captureStatus_out, + cuuint64_t *id_out, CUgraph *graph_out, const CUgraphNode **dependencies_out, + const CUgraphEdgeData **edgeData_out, size_t *numDependencies_out); + +/** + * \brief Update the set of dependencies in a capturing stream (11.3+) + * + * Modifies the dependency set of a capturing stream. The dependency set is the set + * of nodes that the next captured node in the stream will depend on. + * + * Valid flags are ::CU_STREAM_ADD_CAPTURE_DEPENDENCIES and + * ::CU_STREAM_SET_CAPTURE_DEPENDENCIES. These control whether the set passed to + * the API is added to the existing set or replaces it. A flags value of 0 defaults + * to ::CU_STREAM_ADD_CAPTURE_DEPENDENCIES. + * + * Nodes that are removed from the dependency set via this API do not result in + * ::CUDA_ERROR_STREAM_CAPTURE_UNJOINED if they are unreachable from the stream at + * ::cuStreamEndCapture. + * + * Returns ::CUDA_ERROR_ILLEGAL_STATE if the stream is not capturing. + * + * This API is new in CUDA 11.3. Developers requiring compatibility across minor + * versions to CUDA 11.0 should not use this API or provide a fallback. + * + * \param hStream - The stream to update + * \param dependencies - The set of dependencies to add + * \param numDependencies - The size of the dependencies array + * \param flags - See above + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_ILLEGAL_STATE + * + * \sa + * ::cuStreamBeginCapture, + * ::cuStreamGetCaptureInfo, + */ +CUresult CUDAAPI cuStreamUpdateCaptureDependencies(CUstream hStream, CUgraphNode *dependencies, size_t numDependencies, unsigned int flags); + +/** + * \brief Update the set of dependencies in a capturing stream (12.3+) + * + * Modifies the dependency set of a capturing stream. The dependency set is the set + * of nodes that the next captured node in the stream will depend on along with the + * edge data for those dependencies. + * + * Valid flags are ::CU_STREAM_ADD_CAPTURE_DEPENDENCIES and + * ::CU_STREAM_SET_CAPTURE_DEPENDENCIES. These control whether the set passed to + * the API is added to the existing set or replaces it. A flags value of 0 defaults + * to ::CU_STREAM_ADD_CAPTURE_DEPENDENCIES. + * + * Nodes that are removed from the dependency set via this API do not result in + * ::CUDA_ERROR_STREAM_CAPTURE_UNJOINED if they are unreachable from the stream at + * ::cuStreamEndCapture. + * + * Returns ::CUDA_ERROR_ILLEGAL_STATE if the stream is not capturing. + * + * \param hStream - The stream to update + * \param dependencies - The set of dependencies to add + * \param dependencyData - Optional array of data associated with each dependency. + * \param numDependencies - The size of the dependencies array + * \param flags - See above + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_ILLEGAL_STATE + * + * \sa + * ::cuStreamBeginCapture, + * ::cuStreamGetCaptureInfo, + */ +CUresult CUDAAPI cuStreamUpdateCaptureDependencies_v2(CUstream hStream, CUgraphNode *dependencies, + const CUgraphEdgeData *dependencyData, size_t numDependencies, unsigned int flags); + +/** + * \brief Attach memory to a stream asynchronously + * + * Enqueues an operation in \p hStream to specify stream association of + * \p length bytes of memory starting from \p dptr. This function is a + * stream-ordered operation, meaning that it is dependent on, and will + * only take effect when, previous work in stream has completed. Any + * previous association is automatically replaced. + * + * \p dptr must point to one of the following types of memories: + * - managed memory declared using the __managed__ keyword or allocated with + * ::cuMemAllocManaged. + * - a valid host-accessible region of system-allocated pageable memory. This + * type of memory may only be specified if the device associated with the + * stream reports a non-zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_PAGEABLE_MEMORY_ACCESS. + * + * For managed allocations, \p length must be either zero or the entire + * allocation's size. Both indicate that the entire allocation's stream + * association is being changed. Currently, it is not possible to change stream + * association for a portion of a managed allocation. + * + * For pageable host allocations, \p length must be non-zero. + * + * The stream association is specified using \p flags which must be + * one of ::CUmemAttach_flags. + * If the ::CU_MEM_ATTACH_GLOBAL flag is specified, the memory can be accessed + * by any stream on any device. + * If the ::CU_MEM_ATTACH_HOST flag is specified, the program makes a guarantee + * that it won't access the memory on the device from any stream on a device that + * has a zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. + * If the ::CU_MEM_ATTACH_SINGLE flag is specified and \p hStream is associated with + * a device that has a zero value for the device attribute ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS, + * the program makes a guarantee that it will only access the memory on the device + * from \p hStream. It is illegal to attach singly to the NULL stream, because the + * NULL stream is a virtual global stream and not a specific stream. An error will + * be returned in this case. + * + * When memory is associated with a single stream, the Unified Memory system will + * allow CPU access to this memory region so long as all operations in \p hStream + * have completed, regardless of whether other streams are active. In effect, + * this constrains exclusive ownership of the managed memory region by + * an active GPU to per-stream activity instead of whole-GPU activity. + * + * Accessing memory on the device from streams that are not associated with + * it will produce undefined results. No error checking is performed by the + * Unified Memory system to ensure that kernels launched into other streams + * do not access this region. + * + * It is a program's responsibility to order calls to ::cuStreamAttachMemAsync + * via events, synchronization or other means to ensure legal access to memory + * at all times. Data visibility and coherency will be changed appropriately + * for all kernels which follow a stream-association change. + * + * If \p hStream is destroyed while data is associated with it, the association is + * removed and the association reverts to the default visibility of the allocation + * as specified at ::cuMemAllocManaged. For __managed__ variables, the default + * association is always ::CU_MEM_ATTACH_GLOBAL. Note that destroying a stream is an + * asynchronous operation, and as a result, the change to default association won't + * happen until all work in the stream has completed. + * + * \param hStream - Stream in which to enqueue the attach operation + * \param dptr - Pointer to memory (must be a pointer to managed memory or + * to a valid host-accessible region of system-allocated + * pageable memory) + * \param length - Length of memory + * \param flags - Must be one of ::CUmemAttach_flags + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_null_stream + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamWaitEvent, + * ::cuStreamDestroy, + * ::cuMemAllocManaged, + * ::cudaStreamAttachMemAsync + */ +CUresult CUDAAPI cuStreamAttachMemAsync(CUstream hStream, CUdeviceptr dptr, size_t length, unsigned int flags); + +/** + * \brief Determine status of a compute stream + * + * Returns ::CUDA_SUCCESS if all operations in the stream specified by + * \p hStream have completed, or ::CUDA_ERROR_NOT_READY if not. + * + * For the purposes of Unified Memory, a return value of ::CUDA_SUCCESS + * is equivalent to having called ::cuStreamSynchronize(). + * + * \param hStream - Stream to query status of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_READY + * \note_null_stream + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuStreamWaitEvent, + * ::cuStreamDestroy, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamQuery + */ +CUresult CUDAAPI cuStreamQuery(CUstream hStream); + +/** + * \brief Wait until a stream's tasks are completed + * + * Waits until the device has completed all operations in the stream specified + * by \p hStream. If the context was created with the + * ::CU_CTX_SCHED_BLOCKING_SYNC flag, the CPU thread will block until the + * stream is finished with all of its tasks. + * + * \param hStream - Stream to wait for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE + + * \note_null_stream + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuStreamDestroy, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamAddCallback, + * ::cudaStreamSynchronize + */ +CUresult CUDAAPI cuStreamSynchronize(CUstream hStream); + +/** + * \brief Destroys a stream + * + * Destroys the stream specified by \p hStream. + * + * In case the device is still doing work in the stream \p hStream + * when ::cuStreamDestroy() is called, the function will return immediately + * and the resources associated with \p hStream will be released automatically + * once the device has completed all work in \p hStream. + * + * \param hStream - Stream to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamDestroy + */ +CUresult CUDAAPI cuStreamDestroy(CUstream hStream); + +/** + * \brief Copies attributes from source stream to destination stream. + * + * Copies attributes from source stream \p src to destination stream \p dst. + * Both streams must have the same context. + * + * \param[out] dst Destination stream + * \param[in] src Source stream + * For list of attributes see ::CUstreamAttrID + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuStreamCopyAttributes(CUstream dst, CUstream src); + +/** + * \brief Queries stream attribute. + * + * Queries attribute \p attr from \p hStream and stores it in corresponding + * member of \p value_out. + * + * \param[in] hStream + * \param[in] attr + * \param[out] value_out + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuStreamGetAttribute(CUstream hStream, CUstreamAttrID attr, + CUstreamAttrValue *value_out); + +/** + * \brief Sets stream attribute. + * + * Sets attribute \p attr on \p hStream from corresponding attribute of + * \p value. The updated attribute will be applied to subsequent work + * submitted to the stream. It will not affect previously submitted work. + * + * \param[out] hStream + * \param[in] attr + * \param[in] value + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuStreamSetAttribute(CUstream hStream, CUstreamAttrID attr, + const CUstreamAttrValue *value); + +/** @} */ /* END CUDA_STREAM */ + + +/** + * \defgroup CUDA_EVENT Event Management + * + * ___MANBRIEF___ event management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the event management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Creates an event + * + * Creates an event *phEvent for the current context with the flags specified via + * \p Flags. Valid flags include: + * - ::CU_EVENT_DEFAULT: Default event creation flag. + * - ::CU_EVENT_BLOCKING_SYNC: Specifies that the created event should use blocking + * synchronization. A CPU thread that uses ::cuEventSynchronize() to wait on + * an event created with this flag will block until the event has actually + * been recorded. + * - ::CU_EVENT_DISABLE_TIMING: Specifies that the created event does not need + * to record timing data. Events created with this flag specified and + * the ::CU_EVENT_BLOCKING_SYNC flag not specified will provide the best + * performance when used with ::cuStreamWaitEvent() and ::cuEventQuery(). + * - ::CU_EVENT_INTERPROCESS: Specifies that the created event may be used as an + * interprocess event by ::cuIpcGetEventHandle(). ::CU_EVENT_INTERPROCESS must + * be specified along with ::CU_EVENT_DISABLE_TIMING. + * + * \param phEvent - Returns newly created event + * \param Flags - Event creation flags + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \sa + * ::cuEventRecord, + * ::cuEventQuery, + * ::cuEventSynchronize, + * ::cuEventDestroy, + * ::cuEventElapsedTime, + * ::cudaEventCreate, + * ::cudaEventCreateWithFlags + */ +CUresult CUDAAPI cuEventCreate(CUevent *phEvent, unsigned int Flags); + +/** + * \brief Records an event + * + * Captures in \p hEvent the contents of \p hStream at the time of this call. + * \p hEvent and \p hStream must be from the same context otherwise + * ::CUDA_ERROR_INVALID_HANDLE is returned. + * Calls such as ::cuEventQuery() or ::cuStreamWaitEvent() will then + * examine or wait for completion of the work that was captured. Uses of + * \p hStream after this call do not modify \p hEvent. See note on default + * stream behavior for what is captured in the default case. + * + * ::cuEventRecord() can be called multiple times on the same event and + * will overwrite the previously captured state. Other APIs such as + * ::cuStreamWaitEvent() use the most recently captured state at the time + * of the API call, and are not affected by later calls to + * ::cuEventRecord(). Before the first call to ::cuEventRecord(), an + * event represents an empty set of work, so for example ::cuEventQuery() + * would return ::CUDA_SUCCESS. + * + * \param hEvent - Event to record + * \param hStream - Stream to record event for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * \note_null_stream + * \notefnerr + * + * \sa ::cuEventCreate, + * ::cuEventQuery, + * ::cuEventSynchronize, + * ::cuStreamWaitEvent, + * ::cuEventDestroy, + * ::cuEventElapsedTime, + * ::cudaEventRecord, + * ::cuEventRecordWithFlags + */ +CUresult CUDAAPI cuEventRecord(CUevent hEvent, CUstream hStream); + +/** + * \brief Records an event + * + * Captures in \p hEvent the contents of \p hStream at the time of this call. + * \p hEvent and \p hStream must be from the same context otherwise + * ::CUDA_ERROR_INVALID_HANDLE is returned. + * Calls such as ::cuEventQuery() or ::cuStreamWaitEvent() will then + * examine or wait for completion of the work that was captured. Uses of + * \p hStream after this call do not modify \p hEvent. See note on default + * stream behavior for what is captured in the default case. + * + * ::cuEventRecordWithFlags() can be called multiple times on the same event and + * will overwrite the previously captured state. Other APIs such as + * ::cuStreamWaitEvent() use the most recently captured state at the time + * of the API call, and are not affected by later calls to + * ::cuEventRecordWithFlags(). Before the first call to ::cuEventRecordWithFlags(), an + * event represents an empty set of work, so for example ::cuEventQuery() + * would return ::CUDA_SUCCESS. + * + * flags include: + * - ::CU_EVENT_RECORD_DEFAULT: Default event creation flag. + * - ::CU_EVENT_RECORD_EXTERNAL: Event is captured in the graph as an external + * event node when performing stream capture. This flag is invalid outside + * of stream capture. + * + * \param hEvent - Event to record + * \param hStream - Stream to record event for + * \param flags - See ::CUevent_capture_flags + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * \note_null_stream + * \notefnerr + * + * \sa ::cuEventCreate, + * ::cuEventQuery, + * ::cuEventSynchronize, + * ::cuStreamWaitEvent, + * ::cuEventDestroy, + * ::cuEventElapsedTime, + * ::cuEventRecord, + * ::cudaEventRecord + */ +CUresult CUDAAPI cuEventRecordWithFlags(CUevent hEvent, CUstream hStream, unsigned int flags); + +/** + * \brief Queries an event's status + * + * Queries the status of all work currently captured by \p hEvent. See + * ::cuEventRecord() for details on what is captured by an event. + * + * Returns ::CUDA_SUCCESS if all captured work has been completed, or + * ::CUDA_ERROR_NOT_READY if any captured work is incomplete. + * + * For the purposes of Unified Memory, a return value of ::CUDA_SUCCESS + * is equivalent to having called ::cuEventSynchronize(). + * + * \param hEvent - Event to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_READY + * \notefnerr + * + * \sa ::cuEventCreate, + * ::cuEventRecord, + * ::cuEventSynchronize, + * ::cuEventDestroy, + * ::cuEventElapsedTime, + * ::cudaEventQuery + */ +CUresult CUDAAPI cuEventQuery(CUevent hEvent); + +/** + * \brief Waits for an event to complete + * + * Waits until the completion of all work currently captured in \p hEvent. + * See ::cuEventRecord() for details on what is captured by an event. + * + * Waiting for an event that was created with the ::CU_EVENT_BLOCKING_SYNC + * flag will cause the calling CPU thread to block until the event has + * been completed by the device. If the ::CU_EVENT_BLOCKING_SYNC flag has + * not been set, then the CPU thread will busy-wait until the event has + * been completed by the device. + * + * \param hEvent - Event to wait for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuEventCreate, + * ::cuEventRecord, + * ::cuEventQuery, + * ::cuEventDestroy, + * ::cuEventElapsedTime, + * ::cudaEventSynchronize + */ +CUresult CUDAAPI cuEventSynchronize(CUevent hEvent); + +/** + * \brief Destroys an event + * + * Destroys the event specified by \p hEvent. + * + * An event may be destroyed before it is complete (i.e., while + * ::cuEventQuery() would return ::CUDA_ERROR_NOT_READY). In this case, the + * call does not block on completion of the event, and any associated + * resources will automatically be released asynchronously at completion. + * + * \param hEvent - Event to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuEventCreate, + * ::cuEventRecord, + * ::cuEventQuery, + * ::cuEventSynchronize, + * ::cuEventElapsedTime, + * ::cudaEventDestroy + */ +CUresult CUDAAPI cuEventDestroy(CUevent hEvent); + +/** + * \brief Computes the elapsed time between two events + * + * Computes the elapsed time between two events (in milliseconds with a + * resolution of around 0.5 microseconds). + * + * If either event was last recorded in a non-NULL stream, the resulting time + * may be greater than expected (even if both used the same stream handle). This + * happens because the ::cuEventRecord() operation takes place asynchronously + * and there is no guarantee that the measured latency is actually just between + * the two events. Any number of other different stream operations could execute + * in between the two measured events, thus altering the timing in a significant + * way. + * + * If ::cuEventRecord() has not been called on either event then + * ::CUDA_ERROR_INVALID_HANDLE is returned. If ::cuEventRecord() has been called + * on both events but one or both of them has not yet been completed (that is, + * ::cuEventQuery() would return ::CUDA_ERROR_NOT_READY on at least one of the + * events), ::CUDA_ERROR_NOT_READY is returned. If either event was created with + * the ::CU_EVENT_DISABLE_TIMING flag, then this function will return + * ::CUDA_ERROR_INVALID_HANDLE. + * + * \param pMilliseconds - Time between \p hStart and \p hEnd in ms + * \param hStart - Starting event + * \param hEnd - Ending event + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_READY, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa ::cuEventCreate, + * ::cuEventRecord, + * ::cuEventQuery, + * ::cuEventSynchronize, + * ::cuEventDestroy, + * ::cudaEventElapsedTime + */ +CUresult CUDAAPI cuEventElapsedTime(float *pMilliseconds, CUevent hStart, CUevent hEnd); + +/** @} */ /* END CUDA_EVENT */ + +/** + * \defgroup CUDA_EXTRES_INTEROP External Resource Interoperability + * + * ___MANBRIEF___ External resource interoperability functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the external resource interoperability functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + + /** + * \brief Imports an external memory object + * + * Imports an externally allocated memory object and returns + * a handle to that in \p extMem_out. + * + * The properties of the handle being imported must be described in + * \p memHandleDesc. The ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC structure + * is defined as follows: + * + * \code + typedef struct CUDA_EXTERNAL_MEMORY_HANDLE_DESC_st { + CUexternalMemoryHandleType type; + union { + int fd; + struct { + void *handle; + const void *name; + } win32; + const void *nvSciBufObject; + } handle; + unsigned long long size; + unsigned int flags; + } CUDA_EXTERNAL_MEMORY_HANDLE_DESC; + * \endcode + * + * where ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type specifies the type + * of handle being imported. ::CUexternalMemoryHandleType is + * defined as: + * + * \code + typedef enum CUexternalMemoryHandleType_enum { + CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD = 1, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32 = 2, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT = 3, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP = 4, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE = 5, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE = 6, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE_KMT = 7, + CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF = 8 + } CUexternalMemoryHandleType; + * \endcode + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD, then + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::fd must be a valid + * file descriptor referencing a memory object. Ownership of + * the file descriptor is transferred to the CUDA driver when the + * handle is imported successfully. Performing any operations on the + * file descriptor after it is imported results in undefined behavior. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32, then exactly one + * of ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle and + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name must not be + * NULL. If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle + * is not NULL, then it must represent a valid shared NT handle that + * references a memory object. Ownership of this handle is + * not transferred to CUDA after the import operation, so the + * application must release the handle using the appropriate system + * call. If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name + * is not NULL, then it must point to a NULL-terminated array of + * UTF-16 characters that refers to a memory object. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT, then + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle must + * be non-NULL and + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name + * must be NULL. The handle specified must be a globally shared KMT + * handle. This handle does not hold a reference to the underlying + * object, and thus will be invalid when all references to the + * memory object are destroyed. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP, then exactly one + * of ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle and + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name must not be + * NULL. If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle + * is not NULL, then it must represent a valid shared NT handle that + * is returned by ID3D12Device::CreateSharedHandle when referring to a + * ID3D12Heap object. This handle holds a reference to the underlying + * object. If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name + * is not NULL, then it must point to a NULL-terminated array of + * UTF-16 characters that refers to a ID3D12Heap object. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE, then exactly one + * of ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle and + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name must not be + * NULL. If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle + * is not NULL, then it must represent a valid shared NT handle that + * is returned by ID3D12Device::CreateSharedHandle when referring to a + * ID3D12Resource object. This handle holds a reference to the + * underlying object. If + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name + * is not NULL, then it must point to a NULL-terminated array of + * UTF-16 characters that refers to a ID3D12Resource object. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE, then + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle must + * represent a valid shared NT handle that is returned by + * IDXGIResource1::CreateSharedHandle when referring to a + * ID3D11Resource object. If + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name + * is not NULL, then it must point to a NULL-terminated array of + * UTF-16 characters that refers to a ID3D11Resource object. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE_KMT, then + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::handle must + * represent a valid shared KMT handle that is returned by + * IDXGIResource::GetSharedHandle when referring to a + * ID3D11Resource object and + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::win32::name + * must be NULL. + * + * If ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type is + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF, then + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::handle::nvSciBufObject must be non-NULL + * and reference a valid NvSciBuf object. + * If the NvSciBuf object imported into CUDA is also mapped by other drivers, then the + * application must use ::cuWaitExternalSemaphoresAsync or ::cuSignalExternalSemaphoresAsync + * as appropriate barriers to maintain coherence between CUDA and the other drivers. + * See ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_SKIP_NVSCIBUF_MEMSYNC and ::CUDA_EXTERNAL_SEMAPHORE_WAIT_SKIP_NVSCIBUF_MEMSYNC + * for memory synchronization. + * + * + * The size of the memory object must be specified in + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::size. + * + * Specifying the flag ::CUDA_EXTERNAL_MEMORY_DEDICATED in + * ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::flags indicates that the + * resource is a dedicated resource. The definition of what a + * dedicated resource is outside the scope of this extension. + * This flag must be set if ::CUDA_EXTERNAL_MEMORY_HANDLE_DESC::type + * is one of the following: + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_RESOURCE_KMT + * + * \param extMem_out - Returned handle to an external memory object + * \param memHandleDesc - Memory import handle descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OPERATING_SYSTEM + * \notefnerr + * + * \note If the Vulkan memory imported into CUDA is mapped on the CPU then the + * application must use vkInvalidateMappedMemoryRanges/vkFlushMappedMemoryRanges + * as well as appropriate Vulkan pipeline barriers to maintain coherence between + * CPU and GPU. For more information on these APIs, please refer to "Synchronization + * and Cache Control" chapter from Vulkan specification. + * + * \sa ::cuDestroyExternalMemory, + * ::cuExternalMemoryGetMappedBuffer, + * ::cuExternalMemoryGetMappedMipmappedArray + */ +CUresult CUDAAPI cuImportExternalMemory(CUexternalMemory *extMem_out, const CUDA_EXTERNAL_MEMORY_HANDLE_DESC *memHandleDesc); + +/** + * \brief Maps a buffer onto an imported memory object + * + * Maps a buffer onto an imported memory object and returns a device + * pointer in \p devPtr. + * + * The properties of the buffer being mapped must be described in + * \p bufferDesc. The ::CUDA_EXTERNAL_MEMORY_BUFFER_DESC structure is + * defined as follows: + * + * \code + typedef struct CUDA_EXTERNAL_MEMORY_BUFFER_DESC_st { + unsigned long long offset; + unsigned long long size; + unsigned int flags; + } CUDA_EXTERNAL_MEMORY_BUFFER_DESC; + * \endcode + * + * where ::CUDA_EXTERNAL_MEMORY_BUFFER_DESC::offset is the offset in + * the memory object where the buffer's base address is. + * ::CUDA_EXTERNAL_MEMORY_BUFFER_DESC::size is the size of the buffer. + * ::CUDA_EXTERNAL_MEMORY_BUFFER_DESC::flags must be zero. + * + * The offset and size have to be suitably aligned to match the + * requirements of the external API. Mapping two buffers whose ranges + * overlap may or may not result in the same virtual address being + * returned for the overlapped portion. In such cases, the application + * must ensure that all accesses to that region from the GPU are + * volatile. Otherwise writes made via one address are not guaranteed + * to be visible via the other address, even if they're issued by the + * same thread. It is recommended that applications map the combined + * range instead of mapping separate buffers and then apply the + * appropriate offsets to the returned pointer to derive the + * individual buffers. + * + * The returned pointer \p devPtr must be freed using ::cuMemFree. + * + * \param devPtr - Returned device pointer to buffer + * \param extMem - Handle to external memory object + * \param bufferDesc - Buffer descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuImportExternalMemory, + * ::cuDestroyExternalMemory, + * ::cuExternalMemoryGetMappedMipmappedArray + */ +CUresult CUDAAPI cuExternalMemoryGetMappedBuffer(CUdeviceptr *devPtr, CUexternalMemory extMem, const CUDA_EXTERNAL_MEMORY_BUFFER_DESC *bufferDesc); + +/** + * \brief Maps a CUDA mipmapped array onto an external memory object + * + * Maps a CUDA mipmapped array onto an external object and returns a + * handle to it in \p mipmap. + * + * The properties of the CUDA mipmapped array being mapped must be + * described in \p mipmapDesc. The structure + * ::CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC is defined as follows: + * + * \code + typedef struct CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC_st { + unsigned long long offset; + CUDA_ARRAY3D_DESCRIPTOR arrayDesc; + unsigned int numLevels; + } CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC; + * \endcode + * + * where ::CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC::offset is the + * offset in the memory object where the base level of the mipmap + * chain is. + * ::CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC::arrayDesc describes + * the format, dimensions and type of the base level of the mipmap + * chain. For further details on these parameters, please refer to the + * documentation for ::cuMipmappedArrayCreate. Note that if the mipmapped + * array is bound as a color target in the graphics API, then the flag + * ::CUDA_ARRAY3D_COLOR_ATTACHMENT must be specified in + * ::CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC::arrayDesc::Flags. + * ::CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC::numLevels specifies + * the total number of levels in the mipmap chain. + * + * If \p extMem was imported from a handle of type ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF, then + * ::CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC::numLevels must be equal to 1. + * + * The returned CUDA mipmapped array must be freed using ::cuMipmappedArrayDestroy. + * + * \param mipmap - Returned CUDA mipmapped array + * \param extMem - Handle to external memory object + * \param mipmapDesc - CUDA array descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuImportExternalMemory, + * ::cuDestroyExternalMemory, + * ::cuExternalMemoryGetMappedBuffer + */ +CUresult CUDAAPI cuExternalMemoryGetMappedMipmappedArray(CUmipmappedArray *mipmap, CUexternalMemory extMem, const CUDA_EXTERNAL_MEMORY_MIPMAPPED_ARRAY_DESC *mipmapDesc); + +/** + * \brief Destroys an external memory object. + * + * Destroys the specified external memory object. Any existing buffers + * and CUDA mipmapped arrays mapped onto this object must no longer be + * used and must be explicitly freed using ::cuMemFree and + * ::cuMipmappedArrayDestroy respectively. + * + * \param extMem - External memory object to be destroyed + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuImportExternalMemory, + * ::cuExternalMemoryGetMappedBuffer, + * ::cuExternalMemoryGetMappedMipmappedArray + */ +CUresult CUDAAPI cuDestroyExternalMemory(CUexternalMemory extMem); + +/** + * \brief Imports an external semaphore + * + * Imports an externally allocated synchronization object and returns + * a handle to that in \p extSem_out. + * + * The properties of the handle being imported must be described in + * \p semHandleDesc. The ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC is + * defined as follows: + * + * \code + typedef struct CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC_st { + CUexternalSemaphoreHandleType type; + union { + int fd; + struct { + void *handle; + const void *name; + } win32; + const void* NvSciSyncObj; + } handle; + unsigned int flags; + } CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC; + * \endcode + * + * where ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type specifies the type of + * handle being imported. ::CUexternalSemaphoreHandleType is defined + * as: + * + * \code + typedef enum CUexternalSemaphoreHandleType_enum { + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD = 1, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32 = 2, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT = 3, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE = 4, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_FENCE = 5, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC = 6, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX = 7, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX_KMT = 8, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_FD = 9, + CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_WIN32 = 10 + } CUexternalSemaphoreHandleType; + * \endcode + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::fd must be a valid + * file descriptor referencing a synchronization object. Ownership of + * the file descriptor is transferred to the CUDA driver when the + * handle is imported successfully. Performing any operations on the + * file descriptor after it is imported results in undefined behavior. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32, then exactly one + * of ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle and + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name must not be + * NULL. If + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle + * is not NULL, then it must represent a valid shared NT handle that + * references a synchronization object. Ownership of this handle is + * not transferred to CUDA after the import operation, so the + * application must release the handle using the appropriate system + * call. If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name + * is not NULL, then it must name a valid synchronization object. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle must + * be non-NULL and + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name + * must be NULL. The handle specified must be a globally shared KMT + * handle. This handle does not hold a reference to the underlying + * object, and thus will be invalid when all references to the + * synchronization object are destroyed. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE, then exactly one + * of ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle and + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name must not be + * NULL. If + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle + * is not NULL, then it must represent a valid shared NT handle that + * is returned by ID3D12Device::CreateSharedHandle when referring to a + * ID3D12Fence object. This handle holds a reference to the underlying + * object. If + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name + * is not NULL, then it must name a valid synchronization object that + * refers to a valid ID3D12Fence object. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_FENCE, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle + * represents a valid shared NT handle that is returned by + * ID3D11Fence::CreateSharedHandle. If + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name + * is not NULL, then it must name a valid synchronization object that + * refers to a valid ID3D11Fence object. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::nvSciSyncObj + * represents a valid NvSciSyncObj. + * + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle + * represents a valid shared NT handle that + * is returned by IDXGIResource1::CreateSharedHandle when referring to + * a IDXGIKeyedMutex object. If + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name + * is not NULL, then it must name a valid synchronization object that + * refers to a valid IDXGIKeyedMutex object. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX_KMT, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle + * represents a valid shared KMT handle that + * is returned by IDXGIResource::GetSharedHandle when referring to + * a IDXGIKeyedMutex object and + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name must be NULL. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_FD, then + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::fd must be a valid + * file descriptor referencing a synchronization object. Ownership of + * the file descriptor is transferred to the CUDA driver when the + * handle is imported successfully. Performing any operations on the + * file descriptor after it is imported results in undefined behavior. + * + * If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::type is + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_WIN32, then exactly one + * of ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle and + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name must not be + * NULL. If + * ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::handle + * is not NULL, then it must represent a valid shared NT handle that + * references a synchronization object. Ownership of this handle is + * not transferred to CUDA after the import operation, so the + * application must release the handle using the appropriate system + * call. If ::CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC::handle::win32::name + * is not NULL, then it must name a valid synchronization object. + * + * \param extSem_out - Returned handle to an external semaphore + * \param semHandleDesc - Semaphore import handle descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OPERATING_SYSTEM + * \notefnerr + * + * \sa ::cuDestroyExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuImportExternalSemaphore(CUexternalSemaphore *extSem_out, const CUDA_EXTERNAL_SEMAPHORE_HANDLE_DESC *semHandleDesc); + +/** + * \brief Signals a set of external semaphore objects + * + * Enqueues a signal operation on a set of externally allocated + * semaphore object in the specified stream. The operations will be + * executed when all prior operations in the stream complete. + * + * The exact semantics of signaling a semaphore depends on the type of + * the object. + * + * If the semaphore object is any one of the following types: + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT + * then signaling the semaphore will set it to the signaled state. + * + * If the semaphore object is any one of the following types: + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_FENCE, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_FD, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_WIN32 + * then the semaphore will be set to the value specified in + * ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS::params::fence::value. + * + * If the semaphore object is of the type ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC + * this API sets ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS::params::nvSciSync::fence + * to a value that can be used by subsequent waiters of the same NvSciSync object + * to order operations with those currently submitted in \p stream. Such an update + * will overwrite previous contents of + * ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS::params::nvSciSync::fence. By default, + * signaling such an external semaphore object causes appropriate memory synchronization + * operations to be performed over all external memory objects that are imported as + * ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF. This ensures that any subsequent accesses + * made by other importers of the same set of NvSciBuf memory object(s) are coherent. + * These operations can be skipped by specifying the flag + * ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_SKIP_NVSCIBUF_MEMSYNC, which can be used as a + * performance optimization when data coherency is not required. But specifying this + * flag in scenarios where data coherency is required results in undefined behavior. + * Also, for semaphore object of the type ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC, + * if the NvSciSyncAttrList used to create the NvSciSyncObj had not set the flags in + * ::cuDeviceGetNvSciSyncAttributes to CUDA_NVSCISYNC_ATTR_SIGNAL, this API will return + * CUDA_ERROR_NOT_SUPPORTED. + * NvSciSyncFence associated with semaphore object of the type + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC can be deterministic. For this the + * NvSciSyncAttrList used to create the semaphore object must have value of + * NvSciSyncAttrKey_RequireDeterministicFences key set to true. Deterministic fences + * allow users to enqueue a wait over the semaphore object even before corresponding + * signal is enqueued. For such a semaphore object, CUDA guarantees that each signal + * operation will increment the fence value by '1'. Users are expected to track count + * of signals enqueued on the semaphore object and insert waits accordingly. When such + * a semaphore object is signaled from multiple streams, due to concurrent stream + * execution, it is possible that the order in which the semaphore gets signaled is + * indeterministic. This could lead to waiters of the semaphore getting unblocked + * incorrectly. Users are expected to handle such situations, either by not using the + * same semaphore object with deterministic fence support enabled in different streams + * or by adding explicit dependency amongst such streams so that the semaphore is + * signaled in order. + * + * If the semaphore object is any one of the following types: + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX_KMT + * then the keyed mutex will be released with the key specified in + * ::CUDA_EXTERNAL_SEMAPHORE_PARAMS::params::keyedmutex::key. + * + * \param extSemArray - Set of external semaphores to be signaled + * \param paramsArray - Array of semaphore parameters + * \param numExtSems - Number of semaphores to signal + * \param stream - Stream to enqueue the signal operations in + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuImportExternalSemaphore, + * ::cuDestroyExternalSemaphore, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuSignalExternalSemaphoresAsync(const CUexternalSemaphore *extSemArray, const CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS *paramsArray, unsigned int numExtSems, CUstream stream); + +/** + * \brief Waits on a set of external semaphore objects + * + * Enqueues a wait operation on a set of externally allocated + * semaphore object in the specified stream. The operations will be + * executed when all prior operations in the stream complete. + * + * The exact semantics of waiting on a semaphore depends on the type + * of the object. + * + * If the semaphore object is any one of the following types: + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT + * then waiting on the semaphore will wait until the semaphore reaches + * the signaled state. The semaphore will then be reset to the + * unsignaled state. Therefore for every signal operation, there can + * only be one wait operation. + * + * If the semaphore object is any one of the following types: + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_FENCE, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_FD, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_TIMELINE_SEMAPHORE_WIN32 + * then waiting on the semaphore will wait until the value of the + * semaphore is greater than or equal to + * ::CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS::params::fence::value. + * + * If the semaphore object is of the type ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC + * then, waiting on the semaphore will wait until the + * ::CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS::params::nvSciSync::fence is signaled by the + * signaler of the NvSciSyncObj that was associated with this semaphore object. + * By default, waiting on such an external semaphore object causes appropriate + * memory synchronization operations to be performed over all external memory objects + * that are imported as ::CU_EXTERNAL_MEMORY_HANDLE_TYPE_NVSCIBUF. This ensures that + * any subsequent accesses made by other importers of the same set of NvSciBuf memory + * object(s) are coherent. These operations can be skipped by specifying the flag + * ::CUDA_EXTERNAL_SEMAPHORE_WAIT_SKIP_NVSCIBUF_MEMSYNC, which can be used as a + * performance optimization when data coherency is not required. But specifying this + * flag in scenarios where data coherency is required results in undefined behavior. + * Also, for semaphore object of the type ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_NVSCISYNC, + * if the NvSciSyncAttrList used to create the NvSciSyncObj had not set the flags in + * ::cuDeviceGetNvSciSyncAttributes to CUDA_NVSCISYNC_ATTR_WAIT, this API will return + * CUDA_ERROR_NOT_SUPPORTED. + * + * If the semaphore object is any one of the following types: + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX, + * ::CU_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D11_KEYED_MUTEX_KMT + * then the keyed mutex will be acquired when it is released with the key + * specified in ::CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS::params::keyedmutex::key + * or until the timeout specified by + * ::CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS::params::keyedmutex::timeoutMs + * has lapsed. The timeout interval can either be a finite value + * specified in milliseconds or an infinite value. In case an infinite + * value is specified the timeout never elapses. The windows INFINITE + * macro must be used to specify infinite timeout. + * + * \param extSemArray - External semaphores to be waited on + * \param paramsArray - Array of semaphore parameters + * \param numExtSems - Number of semaphores to wait on + * \param stream - Stream to enqueue the wait operations in + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_TIMEOUT + * \notefnerr + * + * \sa ::cuImportExternalSemaphore, + * ::cuDestroyExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync + */ +CUresult CUDAAPI cuWaitExternalSemaphoresAsync(const CUexternalSemaphore *extSemArray, const CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS *paramsArray, unsigned int numExtSems, CUstream stream); + +/** + * \brief Destroys an external semaphore + * + * Destroys an external semaphore object and releases any references + * to the underlying resource. Any outstanding signals or waits must + * have completed before the semaphore is destroyed. + * + * \param extSem - External semaphore to be destroyed + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa ::cuImportExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuDestroyExternalSemaphore(CUexternalSemaphore extSem); + +/** @} */ /* END CUDA_EXTRES_INTEROP */ + +/** + * \defgroup CUDA_MEMOP Stream Memory Operations + * + * ___MANBRIEF___ Stream memory operations of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the stream memory operations of the low-level CUDA + * driver application programming interface. + * + * Support for the ::CU_STREAM_WAIT_VALUE_NOR flag can be queried with + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_STREAM_WAIT_VALUE_NOR_V2. + * + * Support for the ::cuStreamWriteValue64() and ::cuStreamWaitValue64() + * functions, as well as for the ::CU_STREAM_MEM_OP_WAIT_VALUE_64 and + * ::CU_STREAM_MEM_OP_WRITE_VALUE_64 flags, can be queried with + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_64_BIT_STREAM_MEM_OPS. + * + * Support for both ::CU_STREAM_WAIT_VALUE_FLUSH and + * ::CU_STREAM_MEM_OP_FLUSH_REMOTE_WRITES requires dedicated platform + * hardware features and can be queried with ::cuDeviceGetAttribute() and + * ::CU_DEVICE_ATTRIBUTE_CAN_FLUSH_REMOTE_WRITES. + * + * Note that all memory pointers passed as parameters to these operations + * are device pointers. Where necessary a device pointer should be + * obtained, for example with ::cuMemHostGetDevicePointer(). + * + * None of the operations accepts pointers to managed memory buffers + * (::cuMemAllocManaged). + * + * \note + * Warning: + * Improper use of these APIs may deadlock the application. Synchronization + * ordering established through these APIs is not visible to CUDA. CUDA tasks + * that are (even indirectly) ordered by these APIs should also have that order + * expressed with CUDA-visible dependencies such as events. This ensures that + * the scheduler does not serialize them in an improper order. + * + * @{ + */ + +/** + * \brief Wait on a memory location + * + * Enqueues a synchronization of the stream on the given memory location. Work + * ordered after the operation will block until the given condition on the + * memory is satisfied. By default, the condition is to wait for + * (int32_t)(*addr - value) >= 0, a cyclic greater-or-equal. + * Other condition types can be specified via \p flags. + * + * If the memory was registered via ::cuMemHostRegister(), the device pointer + * should be obtained with ::cuMemHostGetDevicePointer(). This function cannot + * be used with managed memory (::cuMemAllocManaged). + * + * Support for CU_STREAM_WAIT_VALUE_NOR can be queried with ::cuDeviceGetAttribute() and + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_STREAM_WAIT_VALUE_NOR_V2. + * + * \note + * Warning: + * Improper use of this API may deadlock the application. Synchronization + * ordering established through this API is not visible to CUDA. CUDA tasks + * that are (even indirectly) ordered by this API should also have that order + * expressed with CUDA-visible dependencies such as events. This ensures that + * the scheduler does not serialize them in an improper order. + * + * \param stream The stream to synchronize on the memory location. + * \param addr The memory location to wait on. + * \param value The value to compare with the memory location. + * \param flags See ::CUstreamWaitValue_flags. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuStreamWaitValue64, + * ::cuStreamWriteValue32, + * ::cuStreamWriteValue64, + * ::cuStreamBatchMemOp, + * ::cuMemHostRegister, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuStreamWaitValue32(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + +/** + * \brief Wait on a memory location + * + * Enqueues a synchronization of the stream on the given memory location. Work + * ordered after the operation will block until the given condition on the + * memory is satisfied. By default, the condition is to wait for + * (int64_t)(*addr - value) >= 0, a cyclic greater-or-equal. + * Other condition types can be specified via \p flags. + * + * If the memory was registered via ::cuMemHostRegister(), the device pointer + * should be obtained with ::cuMemHostGetDevicePointer(). + * + * Support for this can be queried with ::cuDeviceGetAttribute() and + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_64_BIT_STREAM_MEM_OPS. + * + * \note + * Warning: + * Improper use of this API may deadlock the application. Synchronization + * ordering established through this API is not visible to CUDA. CUDA tasks + * that are (even indirectly) ordered by this API should also have that order + * expressed with CUDA-visible dependencies such as events. This ensures that + * the scheduler does not serialize them in an improper order. + * + * \param stream The stream to synchronize on the memory location. + * \param addr The memory location to wait on. + * \param value The value to compare with the memory location. + * \param flags See ::CUstreamWaitValue_flags. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuStreamWaitValue32, + * ::cuStreamWriteValue32, + * ::cuStreamWriteValue64, + * ::cuStreamBatchMemOp, + * ::cuMemHostRegister, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuStreamWaitValue64(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + +/** + * \brief Write a value to memory + * + * Write a value to memory. + * + * If the memory was registered via ::cuMemHostRegister(), the device pointer + * should be obtained with ::cuMemHostGetDevicePointer(). This function cannot + * be used with managed memory (::cuMemAllocManaged). + * + * \param stream The stream to do the write in. + * \param addr The device address to write to. + * \param value The value to write. + * \param flags See ::CUstreamWriteValue_flags. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuStreamWriteValue64, + * ::cuStreamWaitValue32, + * ::cuStreamWaitValue64, + * ::cuStreamBatchMemOp, + * ::cuMemHostRegister, + * ::cuEventRecord + */ +CUresult CUDAAPI cuStreamWriteValue32(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + +/** + * \brief Write a value to memory + * + * Write a value to memory. + * + * If the memory was registered via ::cuMemHostRegister(), the device pointer + * should be obtained with ::cuMemHostGetDevicePointer(). + * + * Support for this can be queried with ::cuDeviceGetAttribute() and + * ::CU_DEVICE_ATTRIBUTE_CAN_USE_64_BIT_STREAM_MEM_OPS. + * + * \param stream The stream to do the write in. + * \param addr The device address to write to. + * \param value The value to write. + * \param flags See ::CUstreamWriteValue_flags. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuStreamWriteValue32, + * ::cuStreamWaitValue32, + * ::cuStreamWaitValue64, + * ::cuStreamBatchMemOp, + * ::cuMemHostRegister, + * ::cuEventRecord + */ +CUresult CUDAAPI cuStreamWriteValue64(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + +/** + * \brief Batch operations to synchronize the stream via memory operations + * + * This is a batch version of ::cuStreamWaitValue32() and ::cuStreamWriteValue32(). + * Batching operations may avoid some performance overhead in both the API call + * and the device execution versus adding them to the stream in separate API + * calls. The operations are enqueued in the order they appear in the array. + * + * See ::CUstreamBatchMemOpType for the full set of supported operations, and + * ::cuStreamWaitValue32(), ::cuStreamWaitValue64(), ::cuStreamWriteValue32(), + * and ::cuStreamWriteValue64() for details of specific operations. + * + * See related APIs for details on querying support for specific operations. + * + * \note + * Warning: + * Improper use of this API may deadlock the application. Synchronization + * ordering established through this API is not visible to CUDA. CUDA tasks + * that are (even indirectly) ordered by this API should also have that order + * expressed with CUDA-visible dependencies such as events. This ensures that + * the scheduler does not serialize them in an improper order. For more + * information, see the Stream Memory Operations section in the programming + * guide(https://docs.nvidia.com/cuda/cuda-c-programming-guide/index.html). + * + * \param stream The stream to enqueue the operations in. + * \param count The number of operations in the array. Must be less than 256. + * \param paramArray The types and parameters of the individual operations. + * \param flags Reserved for future expansion; must be 0. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \notefnerr + * + * \sa ::cuStreamWaitValue32, + * ::cuStreamWaitValue64, + * ::cuStreamWriteValue32, + * ::cuStreamWriteValue64, + * ::cuMemHostRegister + */ +CUresult CUDAAPI cuStreamBatchMemOp(CUstream stream, unsigned int count, CUstreamBatchMemOpParams *paramArray, unsigned int flags); + +/** @} */ /* END CUDA_MEMOP */ + +/** + * \defgroup CUDA_EXEC Execution Control + * + * ___MANBRIEF___ execution control functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the execution control functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns information about a function + * + * Returns in \p *pi the integer value of the attribute \p attrib on the kernel + * given by \p hfunc. The supported attributes are: + * - ::CU_FUNC_ATTRIBUTE_MAX_THREADS_PER_BLOCK: The maximum number of threads + * per block, beyond which a launch of the function would fail. This number + * depends on both the function and the device on which the function is + * currently loaded. + * - ::CU_FUNC_ATTRIBUTE_SHARED_SIZE_BYTES: The size in bytes of + * statically-allocated shared memory per block required by this function. + * This does not include dynamically-allocated shared memory requested by + * the user at runtime. + * - ::CU_FUNC_ATTRIBUTE_CONST_SIZE_BYTES: The size in bytes of user-allocated + * constant memory required by this function. + * - ::CU_FUNC_ATTRIBUTE_LOCAL_SIZE_BYTES: The size in bytes of local memory + * used by each thread of this function. + * - ::CU_FUNC_ATTRIBUTE_NUM_REGS: The number of registers used by each thread + * of this function. + * - ::CU_FUNC_ATTRIBUTE_PTX_VERSION: The PTX virtual architecture version for + * which the function was compiled. This value is the major PTX version * 10 + * + the minor PTX version, so a PTX version 1.3 function would return the + * value 13. Note that this may return the undefined value of 0 for cubins + * compiled prior to CUDA 3.0. + * - ::CU_FUNC_ATTRIBUTE_BINARY_VERSION: The binary architecture version for + * which the function was compiled. This value is the major binary + * version * 10 + the minor binary version, so a binary version 1.3 function + * would return the value 13. Note that this will return a value of 10 for + * legacy cubins that do not have a properly-encoded binary architecture + * version. + * - ::CU_FUNC_CACHE_MODE_CA: The attribute to indicate whether the function has + * been compiled with user specified option "-Xptxas --dlcm=ca" set . + * - ::CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES: The maximum size in bytes of + * dynamically-allocated shared memory. + * - ::CU_FUNC_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT: Preferred shared memory-L1 + * cache split ratio in percent of total shared memory. + * - ::CU_FUNC_ATTRIBUTE_CLUSTER_SIZE_MUST_BE_SET: If this attribute is set, the + * kernel must launch with a valid cluster size specified. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_WIDTH: The required cluster width in + * blocks. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_HEIGHT: The required cluster height in + * blocks. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_DEPTH: The required cluster depth in + * blocks. + * - ::CU_FUNC_ATTRIBUTE_NON_PORTABLE_CLUSTER_SIZE_ALLOWED: Indicates whether + * the function can be launched with non-portable cluster size. 1 is allowed, + * 0 is disallowed. A non-portable cluster size may only function on the + * specific SKUs the program is tested on. The launch might fail if the + * program is run on a different hardware platform. CUDA API provides + * cudaOccupancyMaxActiveClusters to assist with checking whether the desired + * size can be launched on the current device. A portable cluster size is + * guaranteed to be functional on all compute capabilities higher than the + * target compute capability. The portable cluster size for sm_90 is 8 blocks + * per cluster. This value may increase for future compute capabilities. The + * specific hardware unit may support higher cluster sizes that’s not + * guaranteed to be portable. + * - ::CU_FUNC_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE: The block + * scheduling policy of a function. The value type is CUclusterSchedulingPolicy. + * + * With a few execeptions, function attributes may also be queried on unloaded + * function handles returned from ::cuModuleEnumerateFunctions. + * ::CUDA_ERROR_FUNCTION_NOT_LOADED is returned if the attribute requires a fully + * loaded function but the function is not loaded. The loading state of a function + * may be queried using ::cuFuncIsloaded. ::cuFuncLoad may be called to explicitly + * load a function before querying the following attributes that require the function + * to be loaded: + * - ::CU_FUNC_ATTRIBUTE_MAX_THREADS_PER_BLOCK + * - ::CU_FUNC_ATTRIBUTE_CONST_SIZE_BYTES + * - ::CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES + * + * \param pi - Returned attribute value + * \param attrib - Attribute requested + * \param hfunc - Function to query attribute of + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_FUNCTION_NOT_LOADED + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncSetCacheConfig, + * ::cuLaunchKernel, + * ::cudaFuncGetAttributes, + * ::cudaFuncSetAttribute, + * ::cuFuncIsLoaded, + * ::cuFuncLoad, + * ::cuKernelGetAttribute + */ +CUresult CUDAAPI cuFuncGetAttribute(int *pi, CUfunction_attribute attrib, CUfunction hfunc); + +/** + * \brief Sets information about a function + * + * This call sets the value of a specified attribute \p attrib on the kernel given + * by \p hfunc to an integer value specified by \p val + * This function returns CUDA_SUCCESS if the new value of the attribute could be + * successfully set. If the set fails, this call will return an error. + * Not all attributes can have values set. Attempting to set a value on a read-only + * attribute will result in an error (CUDA_ERROR_INVALID_VALUE) + * + * Supported attributes for the cuFuncSetAttribute call are: + * - ::CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES: This maximum size in bytes of + * dynamically-allocated shared memory. The value should contain the requested + * maximum size of dynamically-allocated shared memory. The sum of this value and + * the function attribute ::CU_FUNC_ATTRIBUTE_SHARED_SIZE_BYTES cannot exceed the + * device attribute ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK_OPTIN. + * The maximal size of requestable dynamic shared memory may differ by GPU + * architecture. + * - ::CU_FUNC_ATTRIBUTE_PREFERRED_SHARED_MEMORY_CARVEOUT: On devices where the L1 + * cache and shared memory use the same hardware resources, this sets the shared memory + * carveout preference, in percent of the total shared memory. + * See ::CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_MULTIPROCESSOR + * This is only a hint, and the driver can choose a different ratio if required to execute the function. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_WIDTH: The required cluster width in + * blocks. The width, height, and depth values must either all be 0 or all be + * positive. The validity of the cluster dimensions is checked at launch time. + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_HEIGHT: The required cluster height in + * blocks. The width, height, and depth values must either all be 0 or all be + * positive. The validity of the cluster dimensions is checked at launch time. + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * - ::CU_FUNC_ATTRIBUTE_REQUIRED_CLUSTER_DEPTH: The required cluster depth in + * blocks. The width, height, and depth values must either all be 0 or all be + * positive. The validity of the cluster dimensions is checked at launch time. + * If the value is set during compile time, it cannot be set at runtime. + * Setting it at runtime will return CUDA_ERROR_NOT_PERMITTED. + * - ::CU_FUNC_ATTRIBUTE_NON_PORTABLE_CLUSTER_SIZE_ALLOWED: Indicates whether + * the function can be launched with non-portable cluster size. 1 is allowed, + * 0 is disallowed. + * - ::CU_FUNC_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE: The block + * scheduling policy of a function. The value type is CUclusterSchedulingPolicy. + * + * \param hfunc - Function to query attribute of + * \param attrib - Attribute requested + * \param value - The value to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncSetCacheConfig, + * ::cuLaunchKernel, + * ::cudaFuncGetAttributes, + * ::cudaFuncSetAttribute, + * ::cuKernelSetAttribute + */ +CUresult CUDAAPI cuFuncSetAttribute(CUfunction hfunc, CUfunction_attribute attrib, int value); + +/** + * \brief Sets the preferred cache configuration for a device function + * + * On devices where the L1 cache and shared memory use the same hardware + * resources, this sets through \p config the preferred cache configuration for + * the device function \p hfunc. This is only a preference. The driver will use + * the requested configuration if possible, but it is free to choose a different + * configuration if required to execute \p hfunc. Any context-wide preference + * set via ::cuCtxSetCacheConfig() will be overridden by this per-function + * setting unless the per-function setting is ::CU_FUNC_CACHE_PREFER_NONE. In + * that case, the current context-wide setting will be used. + * + * This setting does nothing on devices where the size of the L1 cache and + * shared memory are fixed. + * + * Launching a kernel with a different preference than the most recent + * preference setting may insert a device-side synchronization point. + * + * + * The supported cache configurations are: + * - ::CU_FUNC_CACHE_PREFER_NONE: no preference for shared memory or L1 (default) + * - ::CU_FUNC_CACHE_PREFER_SHARED: prefer larger shared memory and smaller L1 cache + * - ::CU_FUNC_CACHE_PREFER_L1: prefer larger L1 cache and smaller shared memory + * - ::CU_FUNC_CACHE_PREFER_EQUAL: prefer equal sized L1 cache and shared memory + * + * \param hfunc - Kernel to configure cache for + * \param config - Requested cache configuration + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cuLaunchKernel, + * ::cudaFuncSetCacheConfig, + * ::cuKernelSetCacheConfig + */ +CUresult CUDAAPI cuFuncSetCacheConfig(CUfunction hfunc, CUfunc_cache config); + + +/** + * \brief Returns a module handle + * + * Returns in \p *hmod the handle of the module that function \p hfunc + * is located in. The lifetime of the module corresponds to the lifetime of + * the context it was loaded in or until the module is explicitly unloaded. + * + * The CUDA runtime manages its own modules loaded into the primary context. + * If the handle returned by this API refers to a module loaded by the CUDA runtime, + * calling ::cuModuleUnload() on that module will result in undefined behavior. + * + * \param hmod - Returned module handle + * \param hfunc - Function to retrieve module for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_FOUND + * \notefnerr + * + */ +CUresult CUDAAPI cuFuncGetModule(CUmodule *hmod, CUfunction hfunc); + +/** + * \brief Returns the function name for a ::CUfunction handle + * + * Returns in \p **name the function name associated with the function handle \p hfunc . + * The function name is returned as a null-terminated string. The returned name is only + * valid when the function handle is valid. If the module is unloaded or reloaded, one + * must call the API again to get the updated name. This API may return a mangled name if + * the function is not declared as having C linkage. If either \p **name or \p hfunc + * is NULL, ::CUDA_ERROR_INVALID_VALUE is returned. + * + * \param name - The returned name of the function + * \param hfunc - The function handle to retrieve the name for + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * + */ +CUresult CUDAAPI cuFuncGetName(const char **name, CUfunction hfunc); + +/** + * \brief Returns the offset and size of a kernel parameter in the device-side parameter layout + * + * Queries the kernel parameter at \p paramIndex into \p func's list of parameters, and returns + * in \p paramOffset and \p paramSize the offset and size, respectively, where the parameter + * will reside in the device-side parameter layout. This information can be used to update kernel + * node parameters from the device via ::cudaGraphKernelNodeSetParam() and + * ::cudaGraphKernelNodeUpdatesApply(). \p paramIndex must be less than the number of parameters + * that \p func takes. \p paramSize can be set to NULL if only the parameter offset is desired. + * + * \param func - The function to query + * \param paramIndex - The parameter index to query + * \param paramOffset - Returns the offset into the device-side parameter layout at which the parameter resides + * \param paramSize - Optionally returns the size of the parameter in the device-side parameter layout + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \notefnerr + * +* \sa ::cuKernelGetParamInfo + */ +CUresult CUDAAPI cuFuncGetParamInfo(CUfunction func, size_t paramIndex, size_t *paramOffset, size_t *paramSize); + +typedef enum CUfunctionLoadingState_enum { + CU_FUNCTION_LOADING_STATE_UNLOADED = 0, + CU_FUNCTION_LOADING_STATE_LOADED = 1, + CU_FUNCTION_LOADING_STATE_MAX +} CUfunctionLoadingState; + +/** + * \brief Returns if the function is loaded + * + * Returns in \p state the loading state of \p function. + * + * \param state - returned loading state + * \param function - the function to check + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuFuncLoad, + * ::cuModuleEnumerateFunctions + */ +CUresult CUDAAPI cuFuncIsLoaded(CUfunctionLoadingState *state, CUfunction function); + +/** + * \brief Loads a function + * + * Finalizes function loading for \p function. Calling this API with a + * fully loaded function has no effect. + * + * \param function - the function to load + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuModuleEnumerateFunctions, + * ::cuFuncIsLoaded + */ +CUresult CUDAAPI cuFuncLoad(CUfunction function); + +/** + * \brief Launches a CUDA function ::CUfunction or a CUDA kernel ::CUkernel + * + * Invokes the function ::CUfunction or the kernel ::CUkernel \p f + * on a \p gridDimX x \p gridDimY x \p gridDimZ grid of blocks. + * Each block contains \p blockDimX x \p blockDimY x + * \p blockDimZ threads. + * + * \p sharedMemBytes sets the amount of dynamic shared memory that will be + * available to each thread block. + * + * Kernel parameters to \p f can be specified in one of two ways: + * + * 1) Kernel parameters can be specified via \p kernelParams. If \p f + * has N parameters, then \p kernelParams needs to be an array of N + * pointers. Each of \p kernelParams[0] through \p kernelParams[N-1] + * must point to a region of memory from which the actual kernel + * parameter will be copied. The number of kernel parameters and their + * offsets and sizes do not need to be specified as that information is + * retrieved directly from the kernel's image. + * + * 2) Kernel parameters can also be packaged by the application into + * a single buffer that is passed in via the \p extra parameter. + * This places the burden on the application of knowing each kernel + * parameter's size and alignment/padding within the buffer. Here is + * an example of using the \p extra parameter in this manner: + * \code + size_t argBufferSize; + char argBuffer[256]; + + // populate argBuffer and argBufferSize + + void *config[] = { + CU_LAUNCH_PARAM_BUFFER_POINTER, argBuffer, + CU_LAUNCH_PARAM_BUFFER_SIZE, &argBufferSize, + CU_LAUNCH_PARAM_END + }; + status = cuLaunchKernel(f, gx, gy, gz, bx, by, bz, sh, s, NULL, config); + * \endcode + * + * The \p extra parameter exists to allow ::cuLaunchKernel to take + * additional less commonly used arguments. \p extra specifies a list of + * names of extra settings and their corresponding values. Each extra + * setting name is immediately followed by the corresponding value. The + * list must be terminated with either NULL or ::CU_LAUNCH_PARAM_END. + * + * - ::CU_LAUNCH_PARAM_END, which indicates the end of the \p extra + * array; + * - ::CU_LAUNCH_PARAM_BUFFER_POINTER, which specifies that the next + * value in \p extra will be a pointer to a buffer containing all + * the kernel parameters for launching kernel \p f; + * - ::CU_LAUNCH_PARAM_BUFFER_SIZE, which specifies that the next + * value in \p extra will be a pointer to a size_t containing the + * size of the buffer specified with ::CU_LAUNCH_PARAM_BUFFER_POINTER; + * + * The error ::CUDA_ERROR_INVALID_VALUE will be returned if kernel + * parameters are specified with both \p kernelParams and \p extra + * (i.e. both \p kernelParams and \p extra are non-NULL). + * + * Calling ::cuLaunchKernel() invalidates the persistent function state + * set through the following deprecated APIs: + * ::cuFuncSetBlockShape(), + * ::cuFuncSetSharedSize(), + * ::cuParamSetSize(), + * ::cuParamSeti(), + * ::cuParamSetf(), + * ::cuParamSetv(). + * + * Note that to use ::cuLaunchKernel(), the kernel \p f must either have + * been compiled with toolchain version 3.2 or later so that it will + * contain kernel parameter information, or have no kernel parameters. + * If either of these conditions is not met, then ::cuLaunchKernel() will + * return ::CUDA_ERROR_INVALID_IMAGE. + * + * Note that the API can also be used to launch context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to launch + * the kernel on will either be taken from the specified stream \p hStream + * or the current context in case of NULL stream. + * + * \param f - Function ::CUfunction or Kernel ::CUkernel to launch + * \param gridDimX - Width of grid in blocks + * \param gridDimY - Height of grid in blocks + * \param gridDimZ - Depth of grid in blocks + * \param blockDimX - X dimension of each thread block + * \param blockDimY - Y dimension of each thread block + * \param blockDimZ - Z dimension of each thread block + * \param sharedMemBytes - Dynamic shared-memory size per thread block in bytes + * \param hStream - Stream identifier + * \param kernelParams - Array of pointers to kernel parameters + * \param extra - Extra options + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_IMAGE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_NOT_FOUND + * \note_null_stream + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cudaLaunchKernel, + * ::cuLibraryGetKernel, + * ::cuKernelSetCacheConfig, + * ::cuKernelGetAttribute, + * ::cuKernelSetAttribute + */ +CUresult CUDAAPI cuLaunchKernel(CUfunction f, + unsigned int gridDimX, + unsigned int gridDimY, + unsigned int gridDimZ, + unsigned int blockDimX, + unsigned int blockDimY, + unsigned int blockDimZ, + unsigned int sharedMemBytes, + CUstream hStream, + void **kernelParams, + void **extra); + +/** + * \brief Launches a CUDA function ::CUfunction or a CUDA kernel ::CUkernel with launch-time configuration + * + * Invokes the function ::CUfunction or the kernel ::CUkernel \p f with the specified launch-time configuration + * \p config. + * + * The ::CUlaunchConfig structure is defined as: + * + * \code + * typedef struct CUlaunchConfig_st { + * unsigned int gridDimX; + * unsigned int gridDimY; + * unsigned int gridDimZ; + * unsigned int blockDimX; + * unsigned int blockDimY; + * unsigned int blockDimZ; + * unsigned int sharedMemBytes; + * CUstream hStream; + * CUlaunchAttribute *attrs; + * unsigned int numAttrs; + * } CUlaunchConfig; + * \endcode + * + * where: + * - ::CUlaunchConfig::gridDimX is the width of the grid in blocks. + * - ::CUlaunchConfig::gridDimY is the height of the grid in blocks. + * - ::CUlaunchConfig::gridDimZ is the depth of the grid in blocks. + * - ::CUlaunchConfig::blockDimX is the X dimension of each thread block. + * - ::CUlaunchConfig::blockDimX is the Y dimension of each thread block. + * - ::CUlaunchConfig::blockDimZ is the Z dimension of each thread block. + * - ::CUlaunchConfig::sharedMemBytes is the dynamic shared-memory size per + * thread block in bytes. + * - ::CUlaunchConfig::hStream is the handle to the stream to perform the launch + * in. The CUDA context associated with this stream must match that associated + * with function f. + * - ::CUlaunchConfig::attrs is an array of ::CUlaunchConfig::numAttrs + * continguous ::CUlaunchAttribute elements. The value of this pointer is not + * considered if ::CUlaunchConfig::numAttrs is zero. However, in that case, it + * is recommended to set the pointer to NULL. + * - ::CUlaunchConfig::numAttrs is the number of attributes populating the + * first ::CUlaunchConfig::numAttrs positions of the ::CUlaunchConfig::attrs + * array. + * + * Launch-time configuration is specified by adding entries to + * ::CUlaunchConfig::attrs. Each entry is an attribute ID and a corresponding + * attribute value. + * + * The ::CUlaunchAttribute structure is defined as: + * \code + * typedef struct CUlaunchAttribute_st { + * CUlaunchAttributeID id; + * CUlaunchAttributeValue value; + * } CUlaunchAttribute; + * \endcode + * where: + * - ::CUlaunchAttribute::id is a unique enum identifying the attribute. + * - ::CUlaunchAttribute::value is a union that hold the attribute value. + * + * An example of using the \p config parameter: + * \code + * CUlaunchAttribute coopAttr = {.id = CU_LAUNCH_ATTRIBUTE_COOPERATIVE, + * .value = 1}; + * CUlaunchConfig config = {... // set block and grid dimensions + * .attrs = &coopAttr, + * .numAttrs = 1}; + * + * cuLaunchKernelEx(&config, kernel, NULL, NULL); + * \endcode + * + * The ::CUlaunchAttributeID enum is defined as: + * \code + * typedef enum CUlaunchAttributeID_enum { + * CU_LAUNCH_ATTRIBUTE_IGNORE = 0, + * CU_LAUNCH_ATTRIBUTE_ACCESS_POLICY_WINDOW = 1, + * CU_LAUNCH_ATTRIBUTE_COOPERATIVE = 2, + * CU_LAUNCH_ATTRIBUTE_SYNCHRONIZATION_POLICY = 3, + * CU_LAUNCH_ATTRIBUTE_CLUSTER_DIMENSION = 4, + * CU_LAUNCH_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE = 5, + * CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_STREAM_SERIALIZATION = 6, + * CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_EVENT = 7, + * CU_LAUNCH_ATTRIBUTE_PRIORITY = 8, + * CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN_MAP = 9, + * CU_LAUNCH_ATTRIBUTE_MEM_SYNC_DOMAIN = 10, + * CU_LAUNCH_ATTRIBUTE_LAUNCH_COMPLETION_EVENT = 12, + * CU_LAUNCH_ATTRIBUTE_DEVICE_UPDATABLE_KERNEL_NODE = 13, + * } CUlaunchAttributeID; + * \endcode + * + * and the corresponding ::CUlaunchAttributeValue union as : + * \code + * typedef union CUlaunchAttributeValue_union { + * CUaccessPolicyWindow accessPolicyWindow; + * int cooperative; + * CUsynchronizationPolicy syncPolicy; + * struct { + * unsigned int x; + * unsigned int y; + * unsigned int z; + * } clusterDim; + * CUclusterSchedulingPolicy clusterSchedulingPolicyPreference; + * int programmaticStreamSerializationAllowed; + * struct { + * CUevent event; + * int flags; + * int triggerAtBlockStart; + * } programmaticEvent; + * int priority; + * CUlaunchMemSyncDomainMap memSyncDomainMap; + * CUlaunchMemSyncDomain memSyncDomain; + * struct { + * CUevent event; + * int flags; + * } launchCompletionEvent; + * struct { + * int deviceUpdatable; + * CUgraphDeviceNode devNode; + * } deviceUpdatableKernelNode; + * } CUlaunchAttributeValue; + * \endcode + * + * Setting ::CU_LAUNCH_ATTRIBUTE_COOPERATIVE to a non-zero value causes the + * kernel launch to be a cooperative launch, with exactly the same usage and + * semantics of ::cuLaunchCooperativeKernel. + * + * Setting ::CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_STREAM_SERIALIZATION to a non-zero + * values causes the kernel to use programmatic means to resolve its stream + * dependency -- enabling the CUDA runtime to opportunistically allow the grid's + * execution to overlap with the previous kernel in the stream, if that kernel + * requests the overlap. + * + * ::CU_LAUNCH_ATTRIBUTE_PROGRAMMATIC_EVENT records an event along with the + * kernel launch. Event recorded through this launch attribute is guaranteed to + * only trigger after all block in the associated kernel trigger the event. A + * block can trigger the event through PTX launchdep.release or CUDA builtin + * function cudaTriggerProgrammaticLaunchCompletion(). A trigger can also be + * inserted at the beginning of each block's execution if triggerAtBlockStart is + * set to non-0. Note that dependents (including the CPU thread calling + * cuEventSynchronize()) are not guaranteed to observe the release precisely + * when it is released. For example, cuEventSynchronize() may only observe the + * event trigger long after the associated kernel has completed. This recording + * type is primarily meant for establishing programmatic dependency between + * device tasks. The event supplied must not be an interprocess or interop + * event. The event must disable timing (i.e. created with + * ::CU_EVENT_DISABLE_TIMING flag set). + * + * ::CU_LAUNCH_ATTRIBUTE_LAUNCH_COMPLETION_EVENT records an event along with + * the kernel launch. Nominally, the event is triggered once all blocks of the + * kernel have begun execution. Currently this is a best effort. If a kernel B + * has a launch completion dependency on a kernel A, B may wait until A is + * complete. Alternatively, blocks of B may begin before all blocks of A have + * begun, for example: + * + * - If B can claim execution resources unavaiable to A, for example if they + * run on different GPUs. + * - If B is a higher priority than A. + * + * Exercise caution if such an ordering inversion could lead to deadlock. The + * event supplied must not be an interprocess or interop event. The event must + * disable timing (i.e. must be created with the ::CU_EVENT_DISABLE_TIMING flag + * set). + * + * Setting ::CU_LAUNCH_ATTRIBUTE_DEVICE_UPDATABLE_KERNEL_NODE to 1 + * on a captured launch causes the resulting kernel node to be device-updatable. + * This attribute is specific to graphs, and passing it to a launch in a + * non-capturing stream results in an error. Passing a value other than 0 or 1 is + * not allowed. + * + * On success, a handle will be returned via + * ::CUlaunchAttributeValue::deviceUpdatableKernelNode::devNode which can be passed + * to the various device-side update functions to update the node's kernel parameters + * from within another kernel. For more information on the types of device updates + * that can be made, as well as the relevant limitations thereof, see + * ::cudaGraphKernelNodeUpdatesApply. + * + * Kernel nodes which are device-updatable have additional restrictions compared to regular + * kernel nodes. Firstly, device-updatable nodes cannot be removed from their graph via + * ::cuGraphDestroyNode. Additionally, once opted-in to this functionality, a node cannot + * opt out, and any attempt to set the attribute to 0 will result in an error. Graphs + * containing one or more device-updatable node also do not allow multiple instantiation. + * + * + * The effect of other attributes is consistent with their effect when set via + * persistent APIs. + * + * See ::cuStreamSetAttribute for + * - ::CU_LAUNCH_ATTRIBUTE_ACCESS_POLICY_WINDOW + * - ::CU_LAUNCH_ATTRIBUTE_SYNCHRONIZATION_POLICY + * + * See ::cuFuncSetAttribute for + * - ::CU_LAUNCH_ATTRIBUTE_CLUSTER_DIMENSION + * - ::CU_LAUNCH_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE + * + * Kernel parameters to \p f can be specified in the same ways that they can be + * using ::cuLaunchKernel. + * + * Note that the API can also be used to launch context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to launch + * the kernel on will either be taken from the specified stream ::CUlaunchConfig::hStream + * or the current context in case of NULL stream. + * + * \param config - Config to launch + * \param f - Function ::CUfunction or Kernel ::CUkernel to launch + * \param kernelParams - Array of pointers to kernel parameters + * \param extra - Extra options + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_IMAGE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_COOPERATIVE_LAUNCH_TOO_LARGE, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_NOT_FOUND + * \note_null_stream + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cudaLaunchKernel, + * ::cudaLaunchKernelEx, + * ::cuLibraryGetKernel, + * ::cuKernelSetCacheConfig, + * ::cuKernelGetAttribute, + * ::cuKernelSetAttribute + */ +CUresult CUDAAPI cuLaunchKernelEx(const CUlaunchConfig *config, + CUfunction f, + void **kernelParams, + void **extra); + +/** + * \brief Launches a CUDA function ::CUfunction or a CUDA kernel ::CUkernel where thread blocks + * can cooperate and synchronize as they execute + * + * Invokes the function ::CUfunction or the kernel ::CUkernel \p f on a \p gridDimX x \p gridDimY x \p gridDimZ + * grid of blocks. Each block contains \p blockDimX x \p blockDimY x + * \p blockDimZ threads. + * + * \p sharedMemBytes sets the amount of dynamic shared memory that will be + * available to each thread block. + * + * The device on which this kernel is invoked must have a non-zero value for + * the device attribute ::CU_DEVICE_ATTRIBUTE_COOPERATIVE_LAUNCH. + * + * The total number of blocks launched cannot exceed the maximum number of blocks per + * multiprocessor as returned by ::cuOccupancyMaxActiveBlocksPerMultiprocessor (or + * ::cuOccupancyMaxActiveBlocksPerMultiprocessorWithFlags) times the number of multiprocessors + * as specified by the device attribute ::CU_DEVICE_ATTRIBUTE_MULTIPROCESSOR_COUNT. + * + * The kernel cannot make use of CUDA dynamic parallelism. + * + * Kernel parameters must be specified via \p kernelParams. If \p f + * has N parameters, then \p kernelParams needs to be an array of N + * pointers. Each of \p kernelParams[0] through \p kernelParams[N-1] + * must point to a region of memory from which the actual kernel + * parameter will be copied. The number of kernel parameters and their + * offsets and sizes do not need to be specified as that information is + * retrieved directly from the kernel's image. + * + * Calling ::cuLaunchCooperativeKernel() sets persistent function state that is + * the same as function state set through ::cuLaunchKernel API + * + * When the kernel \p f is launched via ::cuLaunchCooperativeKernel(), the previous + * block shape, shared size and parameter info associated with \p f + * is overwritten. + * + * Note that to use ::cuLaunchCooperativeKernel(), the kernel \p f must either have + * been compiled with toolchain version 3.2 or later so that it will + * contain kernel parameter information, or have no kernel parameters. + * If either of these conditions is not met, then ::cuLaunchCooperativeKernel() will + * return ::CUDA_ERROR_INVALID_IMAGE. + * + * Note that the API can also be used to launch context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to launch + * the kernel on will either be taken from the specified stream \p hStream + * or the current context in case of NULL stream. + * + * \param f - Function ::CUfunction or Kernel ::CUkernel to launch + * \param gridDimX - Width of grid in blocks + * \param gridDimY - Height of grid in blocks + * \param gridDimZ - Depth of grid in blocks + * \param blockDimX - X dimension of each thread block + * \param blockDimY - Y dimension of each thread block + * \param blockDimZ - Z dimension of each thread block + * \param sharedMemBytes - Dynamic shared-memory size per thread block in bytes + * \param hStream - Stream identifier + * \param kernelParams - Array of pointers to kernel parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_IMAGE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_COOPERATIVE_LAUNCH_TOO_LARGE, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED, + * ::CUDA_ERROR_NOT_FOUND + * \note_null_stream + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cuLaunchCooperativeKernelMultiDevice, + * ::cudaLaunchCooperativeKernel, + * ::cuLibraryGetKernel, + * ::cuKernelSetCacheConfig, + * ::cuKernelGetAttribute, + * ::cuKernelSetAttribute + */ +CUresult CUDAAPI cuLaunchCooperativeKernel(CUfunction f, + unsigned int gridDimX, + unsigned int gridDimY, + unsigned int gridDimZ, + unsigned int blockDimX, + unsigned int blockDimY, + unsigned int blockDimZ, + unsigned int sharedMemBytes, + CUstream hStream, + void **kernelParams); + +/** + * \brief Launches CUDA functions on multiple devices where thread blocks can cooperate and synchronize as they execute + * + * \deprecated This function is deprecated as of CUDA 11.3. + * + * Invokes kernels as specified in the \p launchParamsList array where each element + * of the array specifies all the parameters required to perform a single kernel launch. + * These kernels can cooperate and synchronize as they execute. The size of the array is + * specified by \p numDevices. + * + * No two kernels can be launched on the same device. All the devices targeted by this + * multi-device launch must be identical. All devices must have a non-zero value for the + * device attribute ::CU_DEVICE_ATTRIBUTE_COOPERATIVE_MULTI_DEVICE_LAUNCH. + * + * All kernels launched must be identical with respect to the compiled code. Note that + * any __device__, __constant__ or __managed__ variables present in the module that owns + * the kernel launched on each device, are independently instantiated on every device. + * It is the application's responsibility to ensure these variables are initialized and + * used appropriately. + * + * The size of the grids as specified in blocks, the size of the blocks themselves + * and the amount of shared memory used by each thread block must also match across + * all launched kernels. + * + * The streams used to launch these kernels must have been created via either ::cuStreamCreate + * or ::cuStreamCreateWithPriority. The NULL stream or ::CU_STREAM_LEGACY or ::CU_STREAM_PER_THREAD + * cannot be used. + * + * The total number of blocks launched per kernel cannot exceed the maximum number of blocks + * per multiprocessor as returned by ::cuOccupancyMaxActiveBlocksPerMultiprocessor (or + * ::cuOccupancyMaxActiveBlocksPerMultiprocessorWithFlags) times the number of multiprocessors + * as specified by the device attribute ::CU_DEVICE_ATTRIBUTE_MULTIPROCESSOR_COUNT. Since the + * total number of blocks launched per device has to match across all devices, the maximum + * number of blocks that can be launched per device will be limited by the device with the + * least number of multiprocessors. + * + * The kernels cannot make use of CUDA dynamic parallelism. + * + * The ::CUDA_LAUNCH_PARAMS structure is defined as: + * \code + typedef struct CUDA_LAUNCH_PARAMS_st + { + CUfunction function; + unsigned int gridDimX; + unsigned int gridDimY; + unsigned int gridDimZ; + unsigned int blockDimX; + unsigned int blockDimY; + unsigned int blockDimZ; + unsigned int sharedMemBytes; + CUstream hStream; + void **kernelParams; + } CUDA_LAUNCH_PARAMS; + * \endcode + * where: + * - ::CUDA_LAUNCH_PARAMS::function specifies the kernel to be launched. All functions must + * be identical with respect to the compiled code. + * Note that you can also specify context-less kernel ::CUkernel by querying the handle + * using ::cuLibraryGetKernel() and then casting to ::CUfunction. In this case, the context to + * launch the kernel on be taken from the specified stream ::CUDA_LAUNCH_PARAMS::hStream. + * - ::CUDA_LAUNCH_PARAMS::gridDimX is the width of the grid in blocks. This must match across + * all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::gridDimY is the height of the grid in blocks. This must match across + * all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::gridDimZ is the depth of the grid in blocks. This must match across + * all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::blockDimX is the X dimension of each thread block. This must match across + * all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::blockDimX is the Y dimension of each thread block. This must match across + * all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::blockDimZ is the Z dimension of each thread block. This must match across + * all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::sharedMemBytes is the dynamic shared-memory size per thread block in bytes. + * This must match across all kernels launched. + * - ::CUDA_LAUNCH_PARAMS::hStream is the handle to the stream to perform the launch in. This cannot + * be the NULL stream or ::CU_STREAM_LEGACY or ::CU_STREAM_PER_THREAD. The CUDA context associated + * with this stream must match that associated with ::CUDA_LAUNCH_PARAMS::function. + * - ::CUDA_LAUNCH_PARAMS::kernelParams is an array of pointers to kernel parameters. If + * ::CUDA_LAUNCH_PARAMS::function has N parameters, then ::CUDA_LAUNCH_PARAMS::kernelParams + * needs to be an array of N pointers. Each of ::CUDA_LAUNCH_PARAMS::kernelParams[0] through + * ::CUDA_LAUNCH_PARAMS::kernelParams[N-1] must point to a region of memory from which the actual + * kernel parameter will be copied. The number of kernel parameters and their offsets and sizes + * do not need to be specified as that information is retrieved directly from the kernel's image. + * + * By default, the kernel won't begin execution on any GPU until all prior work in all the specified + * streams has completed. This behavior can be overridden by specifying the flag + * ::CUDA_COOPERATIVE_LAUNCH_MULTI_DEVICE_NO_PRE_LAUNCH_SYNC. When this flag is specified, each kernel + * will only wait for prior work in the stream corresponding to that GPU to complete before it begins + * execution. + * + * Similarly, by default, any subsequent work pushed in any of the specified streams will not begin + * execution until the kernels on all GPUs have completed. This behavior can be overridden by specifying + * the flag ::CUDA_COOPERATIVE_LAUNCH_MULTI_DEVICE_NO_POST_LAUNCH_SYNC. When this flag is specified, + * any subsequent work pushed in any of the specified streams will only wait for the kernel launched + * on the GPU corresponding to that stream to complete before it begins execution. + * + * Calling ::cuLaunchCooperativeKernelMultiDevice() sets persistent function state that is + * the same as function state set through ::cuLaunchKernel API when called individually for each + * element in \p launchParamsList. + * + * When kernels are launched via ::cuLaunchCooperativeKernelMultiDevice(), the previous + * block shape, shared size and parameter info associated with each ::CUDA_LAUNCH_PARAMS::function + * in \p launchParamsList is overwritten. + * + * Note that to use ::cuLaunchCooperativeKernelMultiDevice(), the kernels must either have + * been compiled with toolchain version 3.2 or later so that it will + * contain kernel parameter information, or have no kernel parameters. + * If either of these conditions is not met, then ::cuLaunchCooperativeKernelMultiDevice() will + * return ::CUDA_ERROR_INVALID_IMAGE. + * + * \param launchParamsList - List of launch parameters, one per device + * \param numDevices - Size of the \p launchParamsList array + * \param flags - Flags to control launch behavior + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_IMAGE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_COOPERATIVE_LAUNCH_TOO_LARGE, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED + * \note_null_stream + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuFuncSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cuLaunchCooperativeKernel, + * ::cudaLaunchCooperativeKernelMultiDevice + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuLaunchCooperativeKernelMultiDevice(CUDA_LAUNCH_PARAMS *launchParamsList, unsigned int numDevices, unsigned int flags); + +/** + * \brief Enqueues a host function call in a stream + * + * Enqueues a host function to run in a stream. The function will be called + * after currently enqueued work and will block work added after it. + * + * The host function must not make any CUDA API calls. Attempting to use a + * CUDA API may result in ::CUDA_ERROR_NOT_PERMITTED, but this is not required. + * The host function must not perform any synchronization that may depend on + * outstanding CUDA work not mandated to run earlier. Host functions without a + * mandated order (such as in independent streams) execute in undefined order + * and may be serialized. + * + * For the purposes of Unified Memory, execution makes a number of guarantees: + *
      + *
    • The stream is considered idle for the duration of the function's + * execution. Thus, for example, the function may always use memory attached + * to the stream it was enqueued in.
    • + *
    • The start of execution of the function has the same effect as + * synchronizing an event recorded in the same stream immediately prior to + * the function. It thus synchronizes streams which have been "joined" + * prior to the function.
    • + *
    • Adding device work to any stream does not have the effect of making + * the stream active until all preceding host functions and stream callbacks + * have executed. Thus, for + * example, a function might use global attached memory even if work has + * been added to another stream, if the work has been ordered behind the + * function call with an event.
    • + *
    • Completion of the function does not cause a stream to become + * active except as described above. The stream will remain idle + * if no device work follows the function, and will remain idle across + * consecutive host functions or stream callbacks without device work in + * between. Thus, for example, + * stream synchronization can be done by signaling from a host function at the + * end of the stream.
    • + *
    + * + * Note that, in contrast to ::cuStreamAddCallback, the function will not be + * called in the event of an error in the CUDA context. + * + * \param hStream - Stream to enqueue function call in + * \param fn - The function to call once preceding stream operations are complete + * \param userData - User-specified data to be passed to the function + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_null_stream + * \notefnerr + * + * \sa ::cuStreamCreate, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamWaitEvent, + * ::cuStreamDestroy, + * ::cuMemAllocManaged, + * ::cuStreamAttachMemAsync, + * ::cuStreamAddCallback + */ +CUresult CUDAAPI cuLaunchHostFunc(CUstream hStream, CUhostFn fn, void *userData); + +/** @} */ /* END CUDA_EXEC */ + +/** + * \defgroup CUDA_EXEC_DEPRECATED Execution Control [DEPRECATED] + * + * ___MANBRIEF___ deprecated execution control functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the deprecated execution control functions of the + * low-level CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Sets the block-dimensions for the function + * + * \deprecated + * + * Specifies the \p x, \p y, and \p z dimensions of the thread blocks that are + * created when the kernel given by \p hfunc is launched. + * + * \param hfunc - Kernel to specify dimensions of + * \param x - X dimension + * \param y - Y dimension + * \param z - Z dimension + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuFuncSetSharedSize, + * ::cuFuncSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSeti, + * ::cuParamSetf, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuFuncSetBlockShape(CUfunction hfunc, int x, int y, int z); + +/** + * \brief Sets the dynamic shared-memory size for the function + * + * \deprecated + * + * Sets through \p bytes the amount of dynamic shared memory that will be + * available to each thread block when the kernel given by \p hfunc is launched. + * + * \param hfunc - Kernel to specify dynamic shared-memory size for + * \param bytes - Dynamic shared-memory size per thread in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetCacheConfig, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSeti, + * ::cuParamSetf, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuFuncSetSharedSize(CUfunction hfunc, unsigned int bytes); + +/** + * \brief Sets the parameter size for the function + * + * \deprecated + * + * Sets through \p numbytes the total size in bytes needed by the function + * parameters of the kernel corresponding to \p hfunc. + * + * \param hfunc - Kernel to set parameter size for + * \param numbytes - Size of parameter list in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetf, + * ::cuParamSeti, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuParamSetSize(CUfunction hfunc, unsigned int numbytes); + +/** + * \brief Adds an integer parameter to the function's argument list + * + * \deprecated + * + * Sets an integer parameter that will be specified the next time the + * kernel corresponding to \p hfunc will be invoked. \p offset is a byte offset. + * + * \param hfunc - Kernel to add parameter to + * \param offset - Offset to add parameter to argument list + * \param value - Value of parameter + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSetf, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuParamSeti(CUfunction hfunc, int offset, unsigned int value); + +/** + * \brief Adds a floating-point parameter to the function's argument list + * + * \deprecated + * + * Sets a floating-point parameter that will be specified the next time the + * kernel corresponding to \p hfunc will be invoked. \p offset is a byte offset. + * + * \param hfunc - Kernel to add parameter to + * \param offset - Offset to add parameter to argument list + * \param value - Value of parameter + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSeti, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuParamSetf(CUfunction hfunc, int offset, float value); + +/** + * \brief Adds arbitrary data to the function's argument list + * + * \deprecated + * + * Copies an arbitrary amount of data (specified in \p numbytes) from \p ptr + * into the parameter space of the kernel corresponding to \p hfunc. \p offset + * is a byte offset. + * + * \param hfunc - Kernel to add data to + * \param offset - Offset to add data to argument list + * \param ptr - Pointer to arbitrary data + * \param numbytes - Size of data to copy in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSetf, + * ::cuParamSeti, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuParamSetv(CUfunction hfunc, int offset, void *ptr, unsigned int numbytes); + +/** + * \brief Launches a CUDA function + * + * \deprecated + * + * Invokes the kernel \p f on a 1 x 1 x 1 grid of blocks. The block + * contains the number of threads specified by a previous call to + * ::cuFuncSetBlockShape(). + * + * The block shape, dynamic shared memory size, and parameter information + * must be set using + * ::cuFuncSetBlockShape(), + * ::cuFuncSetSharedSize(), + * ::cuParamSetSize(), + * ::cuParamSeti(), + * ::cuParamSetf(), and + * ::cuParamSetv() + * prior to calling this function. + * + * Launching a function via ::cuLaunchKernel() invalidates the function's + * block shape, dynamic shared memory size, and parameter information. After + * launching via cuLaunchKernel, this state must be re-initialized prior to + * calling this function. Failure to do so results in undefined behavior. + * + * \param f - Kernel to launch + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSetf, + * ::cuParamSeti, + * ::cuParamSetv, + * ::cuLaunchGrid, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuLaunch(CUfunction f); + +/** + * \brief Launches a CUDA function + * + * \deprecated + * + * Invokes the kernel \p f on a \p grid_width x \p grid_height grid of + * blocks. Each block contains the number of threads specified by a previous + * call to ::cuFuncSetBlockShape(). + * + * The block shape, dynamic shared memory size, and parameter information + * must be set using + * ::cuFuncSetBlockShape(), + * ::cuFuncSetSharedSize(), + * ::cuParamSetSize(), + * ::cuParamSeti(), + * ::cuParamSetf(), and + * ::cuParamSetv() + * prior to calling this function. + * + * Launching a function via ::cuLaunchKernel() invalidates the function's + * block shape, dynamic shared memory size, and parameter information. After + * launching via cuLaunchKernel, this state must be re-initialized prior to + * calling this function. Failure to do so results in undefined behavior. + * + * \param f - Kernel to launch + * \param grid_width - Width of grid in blocks + * \param grid_height - Height of grid in blocks + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSetf, + * ::cuParamSeti, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGridAsync, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuLaunchGrid(CUfunction f, int grid_width, int grid_height); + +/** + * \brief Launches a CUDA function + * + * \deprecated + * + * Invokes the kernel \p f on a \p grid_width x \p grid_height grid of + * blocks. Each block contains the number of threads specified by a previous + * call to ::cuFuncSetBlockShape(). + * + * The block shape, dynamic shared memory size, and parameter information + * must be set using + * ::cuFuncSetBlockShape(), + * ::cuFuncSetSharedSize(), + * ::cuParamSetSize(), + * ::cuParamSeti(), + * ::cuParamSetf(), and + * ::cuParamSetv() + * prior to calling this function. + * + * Launching a function via ::cuLaunchKernel() invalidates the function's + * block shape, dynamic shared memory size, and parameter information. After + * launching via cuLaunchKernel, this state must be re-initialized prior to + * calling this function. Failure to do so results in undefined behavior. + * + * \param f - Kernel to launch + * \param grid_width - Width of grid in blocks + * \param grid_height - Height of grid in blocks + * \param hStream - Stream identifier + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_LAUNCH_FAILED, + * ::CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES, + * ::CUDA_ERROR_LAUNCH_TIMEOUT, + * ::CUDA_ERROR_LAUNCH_INCOMPATIBLE_TEXTURING, + * ::CUDA_ERROR_SHARED_OBJECT_INIT_FAILED + * + * \note In certain cases where cubins are created with no ABI (i.e., using \p ptxas \p --abi-compile \p no), + * this function may serialize kernel launches. The CUDA driver retains asynchronous behavior by + * growing the per-thread stack as needed per launch and not shrinking it afterwards. + * + * \note_null_stream + * \notefnerr + * + * \sa ::cuFuncSetBlockShape, + * ::cuFuncSetSharedSize, + * ::cuFuncGetAttribute, + * ::cuParamSetSize, + * ::cuParamSetf, + * ::cuParamSeti, + * ::cuParamSetv, + * ::cuLaunch, + * ::cuLaunchGrid, + * ::cuLaunchKernel + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuLaunchGridAsync(CUfunction f, int grid_width, int grid_height, CUstream hStream); + + +/** + * \brief Adds a texture-reference to the function's argument list + * + * \deprecated + * + * Makes the CUDA array or linear memory bound to the texture reference + * \p hTexRef available to a device program as a texture. In this version of + * CUDA, the texture-reference must be obtained via ::cuModuleGetTexRef() and + * the \p texunit parameter must be set to ::CU_PARAM_TR_DEFAULT. + * + * \param hfunc - Kernel to add texture-reference to + * \param texunit - Texture unit (must be ::CU_PARAM_TR_DEFAULT) + * \param hTexRef - Texture-reference to add to argument list + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuParamSetTexRef(CUfunction hfunc, int texunit, CUtexref hTexRef); + +/** + * \brief Sets the shared memory configuration for a device function. + * + * \deprecated + * + * On devices with configurable shared memory banks, this function will + * force all subsequent launches of the specified device function to have + * the given shared memory bank size configuration. On any given launch of the + * function, the shared memory configuration of the device will be temporarily + * changed if needed to suit the function's preferred configuration. Changes in + * shared memory configuration between subsequent launches of functions, + * may introduce a device side synchronization point. + * + * Any per-function setting of shared memory bank size set via + * ::cuFuncSetSharedMemConfig will override the context wide setting set with + * ::cuCtxSetSharedMemConfig. + * + * Changing the shared memory bank size will not increase shared memory usage + * or affect occupancy of kernels, but may have major effects on performance. + * Larger bank sizes will allow for greater potential bandwidth to shared memory, + * but will change what kinds of accesses to shared memory will result in bank + * conflicts. + * + * This function will do nothing on devices with fixed shared memory bank size. + * + * The supported bank configurations are: + * - ::CU_SHARED_MEM_CONFIG_DEFAULT_BANK_SIZE: use the context's shared memory + * configuration when launching this function. + * - ::CU_SHARED_MEM_CONFIG_FOUR_BYTE_BANK_SIZE: set shared memory bank width to + * be natively four bytes when launching this function. + * - ::CU_SHARED_MEM_CONFIG_EIGHT_BYTE_BANK_SIZE: set shared memory bank width to + * be natively eight bytes when launching this function. + * + * \param hfunc - kernel to be given a shared memory config + * \param config - requested shared memory configuration + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT + * \notefnerr + * + * \sa ::cuCtxGetCacheConfig, + * ::cuCtxSetCacheConfig, + * ::cuCtxGetSharedMemConfig, + * ::cuCtxSetSharedMemConfig, + * ::cuFuncGetAttribute, + * ::cuLaunchKernel, + * ::cudaFuncSetSharedMemConfig + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuFuncSetSharedMemConfig(CUfunction hfunc, CUsharedconfig config); + +/** @} */ /* END CUDA_EXEC_DEPRECATED */ + +/** + * \defgroup CUDA_GRAPH Graph Management + * + * ___MANBRIEF___ graph management functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the graph management functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Creates a graph + * + * Creates an empty graph, which is returned via \p phGraph. + * + * \param phGraph - Returns newly created graph + * \param flags - Graph creation flags, must be 0 + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode, + * ::cuGraphInstantiate, + * ::cuGraphDestroy, + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphGetEdges, + * ::cuGraphClone + */ +CUresult CUDAAPI cuGraphCreate(CUgraph *phGraph, unsigned int flags); + +/** + * \brief Creates a kernel execution node and adds it to a graph + * + * Creates a new kernel execution node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and arguments specified in \p nodeParams. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * The CUDA_KERNEL_NODE_PARAMS structure is defined as: + * + * \code + * typedef struct CUDA_KERNEL_NODE_PARAMS_st { + * CUfunction func; + * unsigned int gridDimX; + * unsigned int gridDimY; + * unsigned int gridDimZ; + * unsigned int blockDimX; + * unsigned int blockDimY; + * unsigned int blockDimZ; + * unsigned int sharedMemBytes; + * void **kernelParams; + * void **extra; + * CUkernel kern; + * CUcontext ctx; + * } CUDA_KERNEL_NODE_PARAMS; + * \endcode + * + * When the graph is launched, the node will invoke kernel \p func on a (\p gridDimX x + * \p gridDimY x \p gridDimZ) grid of blocks. Each block contains + * (\p blockDimX x \p blockDimY x \p blockDimZ) threads. + * + * \p sharedMemBytes sets the amount of dynamic shared memory that will be + * available to each thread block. + * + * Kernel parameters to \p func can be specified in one of two ways: + * + * 1) Kernel parameters can be specified via \p kernelParams. If the kernel has N + * parameters, then \p kernelParams needs to be an array of N pointers. Each pointer, + * from \p kernelParams[0] to \p kernelParams[N-1], points to the region of memory from which the actual + * parameter will be copied. The number of kernel parameters and their offsets and sizes do not need + * to be specified as that information is retrieved directly from the kernel's image. + * + * 2) Kernel parameters for non-cooperative kernels can also be packaged by the application into a single + * buffer that is passed in via \p extra. This places the burden on the application of knowing each + * kernel parameter's size and alignment/padding within the buffer. The \p extra parameter exists + * to allow this function to take additional less commonly used arguments. \p extra specifies + * a list of names of extra settings and their corresponding values. Each extra setting name is + * immediately followed by the corresponding value. The list must be terminated with either NULL or + * CU_LAUNCH_PARAM_END. + * + * - ::CU_LAUNCH_PARAM_END, which indicates the end of the \p extra + * array; + * - ::CU_LAUNCH_PARAM_BUFFER_POINTER, which specifies that the next + * value in \p extra will be a pointer to a buffer + * containing all the kernel parameters for launching kernel + * \p func; + * - ::CU_LAUNCH_PARAM_BUFFER_SIZE, which specifies that the next + * value in \p extra will be a pointer to a size_t + * containing the size of the buffer specified with + * ::CU_LAUNCH_PARAM_BUFFER_POINTER; + * + * The error ::CUDA_ERROR_INVALID_VALUE will be returned if kernel parameters are specified with both + * \p kernelParams and \p extra (i.e. both \p kernelParams and \p extra are non-NULL). + * ::CUDA_ERROR_INVALID_VALUE will be returned if \p extra is used for a cooperative kernel. + * + * The \p kernelParams or \p extra array, as well as the argument values it points to, + * are copied during this call. + * + * \note Kernels launched using graphs must not use texture and surface references. Reading or + * writing through any texture or surface reference is undefined behavior. + * This restriction does not apply to texture and surface objects. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Parameters for the GPU execution node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuLaunchKernel, + * ::cuLaunchCooperativeKernel, + * ::cuGraphKernelNodeGetParams, + * ::cuGraphKernelNodeSetParams, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddKernelNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_KERNEL_NODE_PARAMS *nodeParams); + +/** + * \brief Returns a kernel node's parameters + * + * Returns the parameters of kernel node \p hNode in \p nodeParams. + * The \p kernelParams or \p extra array returned in \p nodeParams, + * as well as the argument values it points to, are owned by the node. + * This memory remains valid until the node is destroyed or its + * parameters are modified, and should not be modified + * directly. Use ::cuGraphKernelNodeSetParams to update the + * parameters of this node. + * + * The params will contain either \p kernelParams or \p extra, + * according to which of these was most recently set on the node. + * + * \param hNode - Node to get the parameters for + * \param nodeParams - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuLaunchKernel, + * ::cuGraphAddKernelNode, + * ::cuGraphKernelNodeSetParams + */ +CUresult CUDAAPI cuGraphKernelNodeGetParams(CUgraphNode hNode, CUDA_KERNEL_NODE_PARAMS *nodeParams); + +/** + * \brief Sets a kernel node's parameters + * + * Sets the parameters of kernel node \p hNode to \p nodeParams. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuLaunchKernel, + * ::cuGraphAddKernelNode, + * ::cuGraphKernelNodeGetParams + */ +CUresult CUDAAPI cuGraphKernelNodeSetParams(CUgraphNode hNode, const CUDA_KERNEL_NODE_PARAMS *nodeParams); + +/** + * \brief Creates a memcpy node and adds it to a graph + * + * Creates a new memcpy node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * When the graph is launched, the node will perform the memcpy described by \p copyParams. + * See ::cuMemcpy3D() for a description of the structure and its restrictions. + * + * Memcpy nodes have some additional restrictions with regards to managed memory, if the + * system contains at least one device which has a zero value for the device attribute + * ::CU_DEVICE_ATTRIBUTE_CONCURRENT_MANAGED_ACCESS. If one or more of the operands refer + * to managed memory, then using the memory type ::CU_MEMORYTYPE_UNIFIED is disallowed + * for those operand(s). The managed memory will be treated as residing on either the + * host or the device, depending on which memory type is specified. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param copyParams - Parameters for the memory copy + * \param ctx - Context on which to run the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuMemcpy3D, + * ::cuGraphMemcpyNodeGetParams, + * ::cuGraphMemcpyNodeSetParams, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddMemcpyNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_MEMCPY3D *copyParams, CUcontext ctx); + +/** + * \brief Returns a memcpy node's parameters + * + * Returns the parameters of memcpy node \p hNode in \p nodeParams. + * + * \param hNode - Node to get the parameters for + * \param nodeParams - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuMemcpy3D, + * ::cuGraphAddMemcpyNode, + * ::cuGraphMemcpyNodeSetParams + */ +CUresult CUDAAPI cuGraphMemcpyNodeGetParams(CUgraphNode hNode, CUDA_MEMCPY3D *nodeParams); + +/** + * \brief Sets a memcpy node's parameters + * + * Sets the parameters of memcpy node \p hNode to \p nodeParams. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuMemcpy3D, + * ::cuGraphAddMemcpyNode, + * ::cuGraphMemcpyNodeGetParams + */ +CUresult CUDAAPI cuGraphMemcpyNodeSetParams(CUgraphNode hNode, const CUDA_MEMCPY3D *nodeParams); + +/** + * \brief Creates a memset node and adds it to a graph + * + * Creates a new memset node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * The element size must be 1, 2, or 4 bytes. + * When the graph is launched, the node will perform the memset described by \p memsetParams. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param memsetParams - Parameters for the memory set + * \param ctx - Context on which to run the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_CONTEXT + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuMemsetD2D32, + * ::cuGraphMemsetNodeGetParams, + * ::cuGraphMemsetNodeSetParams, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemcpyNode + */ +CUresult CUDAAPI cuGraphAddMemsetNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_MEMSET_NODE_PARAMS *memsetParams, CUcontext ctx); + +/** + * \brief Returns a memset node's parameters + * + * Returns the parameters of memset node \p hNode in \p nodeParams. + * + * \param hNode - Node to get the parameters for + * \param nodeParams - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuMemsetD2D32, + * ::cuGraphAddMemsetNode, + * ::cuGraphMemsetNodeSetParams + */ +CUresult CUDAAPI cuGraphMemsetNodeGetParams(CUgraphNode hNode, CUDA_MEMSET_NODE_PARAMS *nodeParams); + +/** + * \brief Sets a memset node's parameters + * + * Sets the parameters of memset node \p hNode to \p nodeParams. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuMemsetD2D32, + * ::cuGraphAddMemsetNode, + * ::cuGraphMemsetNodeGetParams + */ +CUresult CUDAAPI cuGraphMemsetNodeSetParams(CUgraphNode hNode, const CUDA_MEMSET_NODE_PARAMS *nodeParams); + +/** + * \brief Creates a host execution node and adds it to a graph + * + * Creates a new CPU execution node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and arguments specified in \p nodeParams. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * When the graph is launched, the node will invoke the specified CPU function. + * Host nodes are not supported under MPS with pre-Volta GPUs. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Parameters for the host node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuLaunchHostFunc, + * ::cuGraphHostNodeGetParams, + * ::cuGraphHostNodeSetParams, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddHostNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_HOST_NODE_PARAMS *nodeParams); + +/** + * \brief Returns a host node's parameters + * + * Returns the parameters of host node \p hNode in \p nodeParams. + * + * \param hNode - Node to get the parameters for + * \param nodeParams - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuLaunchHostFunc, + * ::cuGraphAddHostNode, + * ::cuGraphHostNodeSetParams + */ +CUresult CUDAAPI cuGraphHostNodeGetParams(CUgraphNode hNode, CUDA_HOST_NODE_PARAMS *nodeParams); + +/** + * \brief Sets a host node's parameters + * + * Sets the parameters of host node \p hNode to \p nodeParams. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuLaunchHostFunc, + * ::cuGraphAddHostNode, + * ::cuGraphHostNodeGetParams + */ +CUresult CUDAAPI cuGraphHostNodeSetParams(CUgraphNode hNode, const CUDA_HOST_NODE_PARAMS *nodeParams); + +/** + * \brief Creates a child graph node and adds it to a graph + * + * Creates a new node which executes an embedded graph, and adds it to \p hGraph with + * \p numDependencies dependencies specified via \p dependencies. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * If \p hGraph contains allocation or free nodes, this call will return an error. + * + * The node executes an embedded child graph. The child graph is cloned in this call. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param childGraph - The graph to clone into this node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphChildGraphNodeGetGraph, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode, + * ::cuGraphClone + */ +CUresult CUDAAPI cuGraphAddChildGraphNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, CUgraph childGraph); + +/** + * \brief Gets a handle to the embedded graph of a child graph node + * + * Gets a handle to the embedded graph in a child graph node. This call + * does not clone the graph. Changes to the graph will be reflected in + * the node, and the node retains ownership of the graph. + * + * Allocation and free nodes cannot be added to the returned graph. + * Attempting to do so will return an error. + * + * \param hNode - Node to get the embedded graph for + * \param phGraph - Location to store a handle to the graph + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddChildGraphNode, + * ::cuGraphNodeFindInClone + */ +CUresult CUDAAPI cuGraphChildGraphNodeGetGraph(CUgraphNode hNode, CUgraph *phGraph); + +/** + * \brief Creates an empty node and adds it to a graph + * + * Creates a new node which performs no operation, and adds it to \p hGraph with + * \p numDependencies dependencies specified via \p dependencies. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * An empty node performs no operation during execution, but can be used for + * transitive ordering. For example, a phased execution graph with 2 groups of n + * nodes with a barrier between them can be represented using an empty node and + * 2*n dependency edges, rather than no empty node and n^2 dependency edges. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddEmptyNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies); + +/** + * \brief Creates an event record node and adds it to a graph + * + * Creates a new event record node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and event specified in \p event. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * Each launch of the graph will record \p event to capture execution of the + * node's dependencies. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param event - Event for the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphAddEventWaitNode, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddEventRecordNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, CUevent event); + +/** + * \brief Returns the event associated with an event record node + * + * Returns the event of event record node \p hNode in \p event_out. + * + * \param hNode - Node to get the event for + * \param event_out - Pointer to return the event + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddEventRecordNode, + * ::cuGraphEventRecordNodeSetEvent, + * ::cuGraphEventWaitNodeGetEvent, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuGraphEventRecordNodeGetEvent(CUgraphNode hNode, CUevent *event_out); + +/** + * \brief Sets an event record node's event + * + * Sets the event of event record node \p hNode to \p event. + * + * \param hNode - Node to set the event for + * \param event - Event to use + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuGraphAddEventRecordNode, + * ::cuGraphEventRecordNodeGetEvent, + * ::cuGraphEventWaitNodeSetEvent, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuGraphEventRecordNodeSetEvent(CUgraphNode hNode, CUevent event); + +/** + * \brief Creates an event wait node and adds it to a graph + * + * Creates a new event wait node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and event specified in \p event. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * The graph node will wait for all work captured in \p event. See ::cuEventRecord() + * for details on what is captured by an event. \p event may be from a different context + * or device than the launch stream. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param event - Event for the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphAddEventRecordNode, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddEventWaitNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, CUevent event); + +/** + * \brief Returns the event associated with an event wait node + * + * Returns the event of event wait node \p hNode in \p event_out. + * + * \param hNode - Node to get the event for + * \param event_out - Pointer to return the event + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddEventWaitNode, + * ::cuGraphEventWaitNodeSetEvent, + * ::cuGraphEventRecordNodeGetEvent, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuGraphEventWaitNodeGetEvent(CUgraphNode hNode, CUevent *event_out); + +/** + * \brief Sets an event wait node's event + * + * Sets the event of event wait node \p hNode to \p event. + * + * \param hNode - Node to set the event for + * \param event - Event to use + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuGraphAddEventWaitNode, + * ::cuGraphEventWaitNodeGetEvent, + * ::cuGraphEventRecordNodeSetEvent, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent + */ +CUresult CUDAAPI cuGraphEventWaitNodeSetEvent(CUgraphNode hNode, CUevent event); + +/** + * \brief Creates an external semaphore signal node and adds it to a graph + * + * Creates a new external semaphore signal node and adds it to \p hGraph with \p + * numDependencies dependencies specified via \p dependencies and arguments specified + * in \p nodeParams. It is possible for \p numDependencies to be 0, in which case the + * node will be placed at the root of the graph. \p dependencies may not have any + * duplicate entries. A handle to the new node will be returned in \p phGraphNode. + * + * Performs a signal operation on a set of externally allocated semaphore objects + * when the node is launched. The operation(s) will occur after all of the node's + * dependencies have completed. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Parameters for the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphExternalSemaphoresSignalNodeGetParams, + * ::cuGraphExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuImportExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddEventRecordNode, + * ::cuGraphAddEventWaitNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddExternalSemaphoresSignalNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_EXT_SEM_SIGNAL_NODE_PARAMS *nodeParams); + +/** + * \brief Returns an external semaphore signal node's parameters + * + * Returns the parameters of an external semaphore signal node \p hNode in \p params_out. + * The \p extSemArray and \p paramsArray returned in \p params_out, + * are owned by the node. This memory remains valid until the node is destroyed or its + * parameters are modified, and should not be modified + * directly. Use ::cuGraphExternalSemaphoresSignalNodeSetParams to update the + * parameters of this node. + * + * \param hNode - Node to get the parameters for + * \param params_out - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuLaunchKernel, + * ::cuGraphAddExternalSemaphoresSignalNode, + * ::cuGraphExternalSemaphoresSignalNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuGraphExternalSemaphoresSignalNodeGetParams(CUgraphNode hNode, CUDA_EXT_SEM_SIGNAL_NODE_PARAMS *params_out); + +/** + * \brief Sets an external semaphore signal node's parameters + * + * Sets the parameters of an external semaphore signal node \p hNode to \p nodeParams. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuGraphAddExternalSemaphoresSignalNode, + * ::cuGraphExternalSemaphoresSignalNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuGraphExternalSemaphoresSignalNodeSetParams(CUgraphNode hNode, const CUDA_EXT_SEM_SIGNAL_NODE_PARAMS *nodeParams); + +/** + * \brief Creates an external semaphore wait node and adds it to a graph + * + * Creates a new external semaphore wait node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and arguments specified in \p nodeParams. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. A handle + * to the new node will be returned in \p phGraphNode. + * + * Performs a wait operation on a set of externally allocated semaphore objects + * when the node is launched. The node's dependencies will not be launched until + * the wait operation has completed. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Parameters for the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphExternalSemaphoresWaitNodeGetParams, + * ::cuGraphExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphAddExternalSemaphoresSignalNode, + * ::cuImportExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddEventRecordNode, + * ::cuGraphAddEventWaitNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddExternalSemaphoresWaitNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_EXT_SEM_WAIT_NODE_PARAMS *nodeParams); + +/** + * \brief Returns an external semaphore wait node's parameters + * + * Returns the parameters of an external semaphore wait node \p hNode in \p params_out. + * The \p extSemArray and \p paramsArray returned in \p params_out, + * are owned by the node. This memory remains valid until the node is destroyed or its + * parameters are modified, and should not be modified + * directly. Use ::cuGraphExternalSemaphoresSignalNodeSetParams to update the + * parameters of this node. + * + * \param hNode - Node to get the parameters for + * \param params_out - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuLaunchKernel, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuGraphExternalSemaphoresWaitNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuGraphExternalSemaphoresWaitNodeGetParams(CUgraphNode hNode, CUDA_EXT_SEM_WAIT_NODE_PARAMS *params_out); + +/** + * \brief Sets an external semaphore wait node's parameters + * + * Sets the parameters of an external semaphore wait node \p hNode to \p nodeParams. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuGraphExternalSemaphoresWaitNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync + */ +CUresult CUDAAPI cuGraphExternalSemaphoresWaitNodeSetParams(CUgraphNode hNode, const CUDA_EXT_SEM_WAIT_NODE_PARAMS *nodeParams); + +/** + * \brief Creates a batch memory operation node and adds it to a graph + * + * Creates a new batch memory operation node and adds it to \p hGraph with \p + * numDependencies dependencies specified via \p dependencies and arguments specified in \p nodeParams. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. + * A handle to the new node will be returned in \p phGraphNode. + * + * When the node is added, the paramArray inside \p nodeParams is copied and therefore it can be + * freed after the call returns. + * + * \note + * Warning: + * Improper use of this API may deadlock the application. Synchronization + * ordering established through this API is not visible to CUDA. CUDA tasks + * that are (even indirectly) ordered by this API should also have that order + * expressed with CUDA-visible dependencies such as events. This ensures that + * the scheduler does not serialize them in an improper order. For more + * information, see the Stream Memory Operations section in the programming + * guide(https://docs.nvidia.com/cuda/cuda-c-programming-guide/index.html). + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Parameters for the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuStreamBatchMemOp, + * ::cuStreamWaitValue32, + * ::cuStreamWriteValue32, + * ::cuStreamWaitValue64, + * ::cuStreamWriteValue64, + * ::cuGraphBatchMemOpNodeGetParams, + * ::cuGraphBatchMemOpNodeSetParams, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddBatchMemOpNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_BATCH_MEM_OP_NODE_PARAMS *nodeParams); + +/** + * \brief Returns a batch mem op node's parameters + * + * Returns the parameters of batch mem op node \p hNode in \p nodeParams_out. + * The \p paramArray returned in \p nodeParams_out is owned by the node. + * This memory remains valid until the node is destroyed or its + * parameters are modified, and should not be modified + * directly. Use ::cuGraphBatchMemOpNodeSetParams to update the + * parameters of this node. + * + * \param hNode - Node to get the parameters for + * \param nodeParams_out - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuStreamBatchMemOp, + * ::cuGraphAddBatchMemOpNode, + * ::cuGraphBatchMemOpNodeSetParams + */ +CUresult CUDAAPI cuGraphBatchMemOpNodeGetParams(CUgraphNode hNode, CUDA_BATCH_MEM_OP_NODE_PARAMS *nodeParams_out); + +/** + * \brief Sets a batch mem op node's parameters + * + * Sets the parameters of batch mem op node \p hNode to \p nodeParams. + * + * The paramArray inside \p nodeParams is copied and therefore it can be + * freed after the call returns. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetParams, + * ::cuStreamBatchMemOp, + * ::cuGraphAddBatchMemOpNode, + * ::cuGraphBatchMemOpNodeGetParams + */ +CUresult CUDAAPI cuGraphBatchMemOpNodeSetParams(CUgraphNode hNode, const CUDA_BATCH_MEM_OP_NODE_PARAMS *nodeParams); + +/** + * \brief Sets the parameters for a batch mem op node in the given graphExec + * + * Sets the parameters of a batch mem op node in an executable graph \p hGraphExec. + * The node is identified by the corresponding node \p hNode in the + * non-executable graph, from which the executable graph was instantiated. + * + * The following fields on operations may be modified on an executable graph: + * + * op.waitValue.address + * op.waitValue.value[64] + * op.waitValue.flags bits corresponding to wait type (i.e. CU_STREAM_WAIT_VALUE_FLUSH bit cannot be modified) + * op.writeValue.address + * op.writeValue.value[64] + * + * Other fields, such as the context, count or type of operations, and other types of operations such as membars, + * may not be modified. + * + * \p hNode must not have been removed from the original graph. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * The paramArray inside \p nodeParams is copied and therefore it can be + * freed after the call returns. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Batch mem op node from the graph from which graphExec was instantiated + * \param nodeParams - Updated Parameters to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuStreamBatchMemOp, + * ::cuGraphAddBatchMemOpNode, + * ::cuGraphBatchMemOpNodeGetParams, + * ::cuGraphBatchMemOpNodeSetParams, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecBatchMemOpNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_BATCH_MEM_OP_NODE_PARAMS *nodeParams); + +/** + * \brief Creates an allocation node and adds it to a graph + * + * Creates a new allocation node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and arguments specified in \p nodeParams. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. A handle + * to the new node will be returned in \p phGraphNode. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Parameters for the node + * + * When ::cuGraphAddMemAllocNode creates an allocation node, it returns the address of the allocation in + * \p nodeParams.dptr. The allocation's address remains fixed across instantiations and launches. + * + * If the allocation is freed in the same graph, by creating a free node using ::cuGraphAddMemFreeNode, + * the allocation can be accessed by nodes ordered after the allocation node but before the free node. + * These allocations cannot be freed outside the owning graph, and they can only be freed once in the + * owning graph. + * + * If the allocation is not freed in the same graph, then it can be accessed not only by nodes in the + * graph which are ordered after the allocation node, but also by stream operations ordered after the + * graph's execution but before the allocation is freed. + * + * Allocations which are not freed in the same graph can be freed by: + * - passing the allocation to ::cuMemFreeAsync or ::cuMemFree; + * - launching a graph with a free node for that allocation; or + * - specifying ::CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH during instantiation, which makes + * each launch behave as though it called ::cuMemFreeAsync for every unfreed allocation. + * + * It is not possible to free an allocation in both the owning graph and another graph. If the allocation + * is freed in the same graph, a free node cannot be added to another graph. If the allocation is freed + * in another graph, a free node can no longer be added to the owning graph. + * + * The following restrictions apply to graphs which contain allocation and/or memory free nodes: + * - Nodes and edges of the graph cannot be deleted. + * - The graph cannot be used in a child node. + * - Only one instantiation of the graph may exist at any point in time. + * - The graph cannot be cloned. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphAddMemFreeNode, + * ::cuGraphMemAllocNodeGetParams, + * ::cuDeviceGraphMemTrim, + * ::cuDeviceGetGraphMemAttribute, + * ::cuDeviceSetGraphMemAttribute, + * ::cuMemAllocAsync, + * ::cuMemFreeAsync, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddEventRecordNode, + * ::cuGraphAddEventWaitNode, + * ::cuGraphAddExternalSemaphoresSignalNode, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddMemAllocNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, CUDA_MEM_ALLOC_NODE_PARAMS *nodeParams); + +/** + * \brief Returns a memory alloc node's parameters + * + * Returns the parameters of a memory alloc node \p hNode in \p params_out. + * The \p poolProps and \p accessDescs returned in \p params_out, are owned by the + * node. This memory remains valid until the node is destroyed. The returned + * parameters must not be modified. + * + * \param hNode - Node to get the parameters for + * \param params_out - Pointer to return the parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddMemAllocNode, + * ::cuGraphMemFreeNodeGetParams + */ +CUresult CUDAAPI cuGraphMemAllocNodeGetParams(CUgraphNode hNode, CUDA_MEM_ALLOC_NODE_PARAMS *params_out); + +/** + * \brief Creates a memory free node and adds it to a graph + * + * Creates a new memory free node and adds it to \p hGraph with \p numDependencies + * dependencies specified via \p dependencies and arguments specified in \p nodeParams. + * It is possible for \p numDependencies to be 0, in which case the node will be placed + * at the root of the graph. \p dependencies may not have any duplicate entries. A handle + * to the new node will be returned in \p phGraphNode. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param dptr - Address of memory to free + * + * ::cuGraphAddMemFreeNode will return ::CUDA_ERROR_INVALID_VALUE if the user attempts to free: + * - an allocation twice in the same graph. + * - an address that was not returned by an allocation node. + * - an invalid address. + * + * The following restrictions apply to graphs which contain allocation and/or memory free nodes: + * - Nodes and edges of the graph cannot be deleted. + * - The graph cannot be used in a child node. + * - Only one instantiation of the graph may exist at any point in time. + * - The graph cannot be cloned. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphAddMemAllocNode, + * ::cuGraphMemFreeNodeGetParams, + * ::cuDeviceGraphMemTrim, + * ::cuDeviceGetGraphMemAttribute, + * ::cuDeviceSetGraphMemAttribute, + * ::cuMemAllocAsync, + * ::cuMemFreeAsync, + * ::cuGraphCreate, + * ::cuGraphDestroyNode, + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddEventRecordNode, + * ::cuGraphAddEventWaitNode, + * ::cuGraphAddExternalSemaphoresSignalNode, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphAddMemFreeNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, CUdeviceptr dptr); + +/** + * \brief Returns a memory free node's parameters + * + * Returns the address of a memory free node \p hNode in \p dptr_out. + * + * \param hNode - Node to get the parameters for + * \param dptr_out - Pointer to return the device address + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddMemFreeNode, + * ::cuGraphMemAllocNodeGetParams + */ +CUresult CUDAAPI cuGraphMemFreeNodeGetParams(CUgraphNode hNode, CUdeviceptr *dptr_out); + +/** + * \brief Free unused memory that was cached on the specified device for use with graphs back to the OS. + * + * Blocks which are not in use by a graph that is either currently executing or scheduled to execute are + * freed back to the operating system. + * + * \param device - The device for which cached memory should be freed. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_DEVICE + * + * \sa + * ::cuGraphAddMemAllocNode, + * ::cuGraphAddMemFreeNode, + * ::cuDeviceSetGraphMemAttribute, + * ::cuDeviceGetGraphMemAttribute + */ +CUresult CUDAAPI cuDeviceGraphMemTrim(CUdevice device); + +/** + * \brief Query asynchronous allocation attributes related to graphs + * + * Valid attributes are: + * + * - ::CU_GRAPH_MEM_ATTR_USED_MEM_CURRENT: Amount of memory, in bytes, currently associated with graphs + * - ::CU_GRAPH_MEM_ATTR_USED_MEM_HIGH: High watermark of memory, in bytes, associated with graphs since the + * last time it was reset. High watermark can only be reset to zero. + * - ::CU_GRAPH_MEM_ATTR_RESERVED_MEM_CURRENT: Amount of memory, in bytes, currently allocated for use by + * the CUDA graphs asynchronous allocator. + * - ::CU_GRAPH_MEM_ATTR_RESERVED_MEM_HIGH: High watermark of memory, in bytes, currently allocated for use by + * the CUDA graphs asynchronous allocator. + * + * \param device - Specifies the scope of the query + * \param attr - attribute to get + * \param value - retrieved value + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_DEVICE + * + * \sa + * ::cuDeviceSetGraphMemAttribute, + * ::cuGraphAddMemAllocNode, + * ::cuGraphAddMemFreeNode + */ +CUresult CUDAAPI cuDeviceGetGraphMemAttribute(CUdevice device, CUgraphMem_attribute attr, void* value); + +/** + * \brief Set asynchronous allocation attributes related to graphs + * + * Valid attributes are: + * + * - ::CU_GRAPH_MEM_ATTR_USED_MEM_HIGH: High watermark of memory, in bytes, associated with graphs since the + * last time it was reset. High watermark can only be reset to zero. + * - ::CU_GRAPH_MEM_ATTR_RESERVED_MEM_HIGH: High watermark of memory, in bytes, currently allocated for use by + * the CUDA graphs asynchronous allocator. + * + * \param device - Specifies the scope of the query + * \param attr - attribute to get + * \param value - pointer to value to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_DEVICE + * + * \sa + * ::cuDeviceGetGraphMemAttribute, + * ::cuGraphAddMemAllocNode, + * ::cuGraphAddMemFreeNode + */ +CUresult CUDAAPI cuDeviceSetGraphMemAttribute(CUdevice device, CUgraphMem_attribute attr, void* value); + +/** + * \brief Clones a graph + * + * This function creates a copy of \p originalGraph and returns it in \p phGraphClone. + * All parameters are copied into the cloned graph. The original graph may be modified + * after this call without affecting the clone. + * + * Child graph nodes in the original graph are recursively copied into the clone. + * + * \param phGraphClone - Returns newly created cloned graph + * \param originalGraph - Graph to clone + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate, + * ::cuGraphNodeFindInClone + */ +CUresult CUDAAPI cuGraphClone(CUgraph *phGraphClone, CUgraph originalGraph); + +/** + * \brief Finds a cloned version of a node + * + * This function returns the node in \p hClonedGraph corresponding to \p hOriginalNode + * in the original graph. + * + * \p hClonedGraph must have been cloned from \p hOriginalGraph via ::cuGraphClone. + * \p hOriginalNode must have been in \p hOriginalGraph at the time of the call to + * ::cuGraphClone, and the corresponding cloned node in \p hClonedGraph must not have + * been removed. The cloned node is then returned via \p phClonedNode. + * + * \param phNode - Returns handle to the cloned node + * \param hOriginalNode - Handle to the original node + * \param hClonedGraph - Cloned graph to query + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphClone + */ +CUresult CUDAAPI cuGraphNodeFindInClone(CUgraphNode *phNode, CUgraphNode hOriginalNode, CUgraph hClonedGraph); + +/** + * \brief Returns a node's type + * + * Returns the node type of \p hNode in \p type. + * + * \param hNode - Node to query + * \param type - Pointer to return the node type + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphChildGraphNodeGetGraph, + * ::cuGraphKernelNodeGetParams, + * ::cuGraphKernelNodeSetParams, + * ::cuGraphHostNodeGetParams, + * ::cuGraphHostNodeSetParams, + * ::cuGraphMemcpyNodeGetParams, + * ::cuGraphMemcpyNodeSetParams, + * ::cuGraphMemsetNodeGetParams, + * ::cuGraphMemsetNodeSetParams + */ +CUresult CUDAAPI cuGraphNodeGetType(CUgraphNode hNode, CUgraphNodeType *type); + +/** + * \brief Returns a graph's nodes + * + * Returns a list of \p hGraph's nodes. \p nodes may be NULL, in which case this + * function will return the number of nodes in \p numNodes. Otherwise, + * \p numNodes entries will be filled in. If \p numNodes is higher than the actual + * number of nodes, the remaining entries in \p nodes will be set to NULL, and the + * number of nodes actually obtained will be returned in \p numNodes. + * + * \param hGraph - Graph to query + * \param nodes - Pointer to return the nodes + * \param numNodes - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate, + * ::cuGraphGetRootNodes, + * ::cuGraphGetEdges, + * ::cuGraphNodeGetType, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphGetNodes(CUgraph hGraph, CUgraphNode *nodes, size_t *numNodes); + +/** + * \brief Returns a graph's root nodes + * + * Returns a list of \p hGraph's root nodes. \p rootNodes may be NULL, in which case this + * function will return the number of root nodes in \p numRootNodes. Otherwise, + * \p numRootNodes entries will be filled in. If \p numRootNodes is higher than the actual + * number of root nodes, the remaining entries in \p rootNodes will be set to NULL, and the + * number of nodes actually obtained will be returned in \p numRootNodes. + * + * \param hGraph - Graph to query + * \param rootNodes - Pointer to return the root nodes + * \param numRootNodes - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate, + * ::cuGraphGetNodes, + * ::cuGraphGetEdges, + * ::cuGraphNodeGetType, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphGetRootNodes(CUgraph hGraph, CUgraphNode *rootNodes, size_t *numRootNodes); + +/** + * \brief Returns a graph's dependency edges + * + * Returns a list of \p hGraph's dependency edges. Edges are returned via corresponding + * indices in \p from and \p to; that is, the node in \p to[i] has a dependency on the + * node in \p from[i]. \p from and \p to may both be NULL, in which + * case this function only returns the number of edges in \p numEdges. Otherwise, + * \p numEdges entries will be filled in. If \p numEdges is higher than the actual + * number of edges, the remaining entries in \p from and \p to will be set to NULL, and + * the number of edges actually returned will be written to \p numEdges. + * + * \param hGraph - Graph to get the edges from + * \param from - Location to return edge endpoints + * \param to - Location to return edge endpoints + * \param numEdges - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphAddDependencies, + * ::cuGraphRemoveDependencies, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphGetEdges(CUgraph hGraph, CUgraphNode *from, CUgraphNode *to, size_t *numEdges); + +/** + * \brief Returns a graph's dependency edges (12.3+) + * + * Returns a list of \p hGraph's dependency edges. Edges are returned via corresponding + * indices in \p from, \p to and \p edgeData; that is, the node in \p to[i] has a + * dependency on the node in \p from[i] with data \p edgeData[i]. \p from and \p to may + * both be NULL, in which case this function only returns the number of edges in + * \p numEdges. Otherwise, \p numEdges entries will be filled in. If \p numEdges is higher + * than the actual number of edges, the remaining entries in \p from and \p to will be + * set to NULL, and the number of edges actually returned will be written to \p numEdges. + * \p edgeData may alone be NULL, in which case the edges must all have default (zeroed) + * edge data. Attempting a lossy query via NULL \p edgeData will result in + * ::CUDA_ERROR_LOSSY_QUERY. If \p edgeData is non-NULL then \p from and \p to must be + * as well. + * + * \param hGraph - Graph to get the edges from + * \param from - Location to return edge endpoints + * \param to - Location to return edge endpoints + * \param edgeData - Optional location to return edge data + * \param numEdges - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_LOSSY_QUERY, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphAddDependencies, + * ::cuGraphRemoveDependencies, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphGetEdges_v2(CUgraph hGraph, CUgraphNode *from, CUgraphNode *to, CUgraphEdgeData *edgeData, size_t *numEdges); + +/** + * \brief Returns a node's dependencies + * + * Returns a list of \p node's dependencies. \p dependencies may be NULL, in which case this + * function will return the number of dependencies in \p numDependencies. Otherwise, + * \p numDependencies entries will be filled in. If \p numDependencies is higher than the actual + * number of dependencies, the remaining entries in \p dependencies will be set to NULL, and the + * number of nodes actually obtained will be returned in \p numDependencies. + * + * \param hNode - Node to query + * \param dependencies - Pointer to return the dependencies + * \param numDependencies - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeGetDependentNodes, + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphGetEdges, + * ::cuGraphAddDependencies, + * ::cuGraphRemoveDependencies + */ +CUresult CUDAAPI cuGraphNodeGetDependencies(CUgraphNode hNode, CUgraphNode *dependencies, size_t *numDependencies); + +/** + * \brief Returns a node's dependencies (12.3+) + * + * Returns a list of \p node's dependencies. \p dependencies may be NULL, in which case this + * function will return the number of dependencies in \p numDependencies. Otherwise, + * \p numDependencies entries will be filled in. If \p numDependencies is higher than the actual + * number of dependencies, the remaining entries in \p dependencies will be set to NULL, and the + * number of nodes actually obtained will be returned in \p numDependencies. + * + * Note that if an edge has non-zero (non-default) edge data and \p edgeData is NULL, + * this API will return ::CUDA_ERROR_LOSSY_QUERY. If \p edgeData is non-NULL, then + * \p dependencies must be as well. + * + * \param hNode - Node to query + * \param dependencies - Pointer to return the dependencies + * \param edgeData - Optional array to return edge data for each dependency + * \param numDependencies - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_LOSSY_QUERY, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeGetDependentNodes, + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphGetEdges, + * ::cuGraphAddDependencies, + * ::cuGraphRemoveDependencies + */ +CUresult CUDAAPI cuGraphNodeGetDependencies_v2(CUgraphNode hNode, CUgraphNode *dependencies, CUgraphEdgeData *edgeData, size_t *numDependencies); + +/** + * \brief Returns a node's dependent nodes + * + * Returns a list of \p node's dependent nodes. \p dependentNodes may be NULL, in which + * case this function will return the number of dependent nodes in \p numDependentNodes. + * Otherwise, \p numDependentNodes entries will be filled in. If \p numDependentNodes is + * higher than the actual number of dependent nodes, the remaining entries in + * \p dependentNodes will be set to NULL, and the number of nodes actually obtained will + * be returned in \p numDependentNodes. + * + * \param hNode - Node to query + * \param dependentNodes - Pointer to return the dependent nodes + * \param numDependentNodes - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeGetDependencies, + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphGetEdges, + * ::cuGraphAddDependencies, + * ::cuGraphRemoveDependencies + */ +CUresult CUDAAPI cuGraphNodeGetDependentNodes(CUgraphNode hNode, CUgraphNode *dependentNodes, size_t *numDependentNodes); + +/** + * \brief Returns a node's dependent nodes (12.3+) + * + * Returns a list of \p node's dependent nodes. \p dependentNodes may be NULL, in which + * case this function will return the number of dependent nodes in \p numDependentNodes. + * Otherwise, \p numDependentNodes entries will be filled in. If \p numDependentNodes is + * higher than the actual number of dependent nodes, the remaining entries in + * \p dependentNodes will be set to NULL, and the number of nodes actually obtained will + * be returned in \p numDependentNodes. + * + * Note that if an edge has non-zero (non-default) edge data and \p edgeData is NULL, + * this API will return ::CUDA_ERROR_LOSSY_QUERY. If \p edgeData is non-NULL, then + * \p dependentNodes must be as well. + * + * \param hNode - Node to query + * \param dependentNodes - Pointer to return the dependent nodes + * \param edgeData - Optional pointer to return edge data for dependent nodes + * \param numDependentNodes - See description + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_LOSSY_QUERY, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeGetDependencies, + * ::cuGraphGetNodes, + * ::cuGraphGetRootNodes, + * ::cuGraphGetEdges, + * ::cuGraphAddDependencies, + * ::cuGraphRemoveDependencies + */ +CUresult CUDAAPI cuGraphNodeGetDependentNodes_v2(CUgraphNode hNode, CUgraphNode *dependentNodes, CUgraphEdgeData *edgeData, size_t *numDependentNodes); + +/** + * \brief Adds dependency edges to a graph + * + * The number of dependencies to be added is defined by \p numDependencies + * Elements in \p from and \p to at corresponding indices define a dependency. + * Each node in \p from and \p to must belong to \p hGraph. + * + * If \p numDependencies is 0, elements in \p from and \p to will be ignored. + * Specifying an existing dependency will return an error. + * + * \param hGraph - Graph to which dependencies are added + * \param from - Array of nodes that provide the dependencies + * \param to - Array of dependent nodes + * \param numDependencies - Number of dependencies to be added + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphRemoveDependencies, + * ::cuGraphGetEdges, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphAddDependencies(CUgraph hGraph, const CUgraphNode *from, const CUgraphNode *to, size_t numDependencies); + +/** + * \brief Adds dependency edges to a graph (12.3+) + * + * The number of dependencies to be added is defined by \p numDependencies + * Elements in \p from and \p to at corresponding indices define a dependency. + * Each node in \p from and \p to must belong to \p hGraph. + * + * If \p numDependencies is 0, elements in \p from and \p to will be ignored. + * Specifying an existing dependency will return an error. + * + * \param hGraph - Graph to which dependencies are added + * \param from - Array of nodes that provide the dependencies + * \param to - Array of dependent nodes + * \param edgeData - Optional array of edge data. If NULL, default (zeroed) edge data is assumed. + * \param numDependencies - Number of dependencies to be added + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphRemoveDependencies, + * ::cuGraphGetEdges, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphAddDependencies_v2(CUgraph hGraph, const CUgraphNode *from, const CUgraphNode *to, const CUgraphEdgeData *edgeData, size_t numDependencies); + +/** + * \brief Removes dependency edges from a graph + * + * The number of \p dependencies to be removed is defined by \p numDependencies. + * Elements in \p from and \p to at corresponding indices define a dependency. + * Each node in \p from and \p to must belong to \p hGraph. + * + * If \p numDependencies is 0, elements in \p from and \p to will be ignored. + * Specifying a non-existing dependency will return an error. + * + * Dependencies cannot be removed from graphs which contain allocation or free nodes. + * Any attempt to do so will return an error. + * + * \param hGraph - Graph from which to remove dependencies + * \param from - Array of nodes that provide the dependencies + * \param to - Array of dependent nodes + * \param numDependencies - Number of dependencies to be removed + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddDependencies, + * ::cuGraphGetEdges, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphRemoveDependencies(CUgraph hGraph, const CUgraphNode *from, const CUgraphNode *to, size_t numDependencies); + +/** + * \brief Removes dependency edges from a graph (12.3+) + * + * The number of \p dependencies to be removed is defined by \p numDependencies. + * Elements in \p from and \p to at corresponding indices define a dependency. + * Each node in \p from and \p to must belong to \p hGraph. + * + * If \p numDependencies is 0, elements in \p from and \p to will be ignored. + * Specifying an edge that does not exist in the graph, with data matching + * \p edgeData, results in an error. \p edgeData is nullable, which is equivalent + * to passing default (zeroed) data for each edge. + * + * Dependencies cannot be removed from graphs which contain allocation or free nodes. + * Any attempt to do so will return an error. + * + * \param hGraph - Graph from which to remove dependencies + * \param from - Array of nodes that provide the dependencies + * \param to - Array of dependent nodes + * \param edgeData - Optional array of edge data. If NULL, edge data is assumed to + * be default (zeroed). + * \param numDependencies - Number of dependencies to be removed + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddDependencies, + * ::cuGraphGetEdges, + * ::cuGraphNodeGetDependencies, + * ::cuGraphNodeGetDependentNodes + */ +CUresult CUDAAPI cuGraphRemoveDependencies_v2(CUgraph hGraph, const CUgraphNode *from, const CUgraphNode *to, const CUgraphEdgeData *edgeData, size_t numDependencies); + +/** + * \brief Remove a node from the graph + * + * Removes \p hNode from its graph. This operation also severs any dependencies of other nodes + * on \p hNode and vice versa. + * + * Nodes which belong to a graph which contains allocation or free nodes cannot be destroyed. + * Any attempt to do so will return an error. + * + * \param hNode - Node to remove + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddChildGraphNode, + * ::cuGraphAddEmptyNode, + * ::cuGraphAddKernelNode, + * ::cuGraphAddHostNode, + * ::cuGraphAddMemcpyNode, + * ::cuGraphAddMemsetNode + */ +CUresult CUDAAPI cuGraphDestroyNode(CUgraphNode hNode); + +/** + * \brief Creates an executable graph from a graph + * + * Instantiates \p hGraph as an executable graph. The graph is validated for any + * structural constraints or intra-node constraints which were not previously + * validated. If instantiation is successful, a handle to the instantiated graph + * is returned in \p phGraphExec. + * + * The \p flags parameter controls the behavior of instantiation and subsequent + * graph launches. Valid flags are: + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH, which configures a + * graph containing memory allocation nodes to automatically free any + * unfreed memory allocations before the graph is relaunched. + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_DEVICE_LAUNCH, which configures the graph for launch + * from the device. If this flag is passed, the executable graph handle returned can be + * used to launch the graph from both the host and device. This flag can only be used + * on platforms which support unified addressing. This flag cannot be used in + * conjunction with ::CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH. + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_USE_NODE_PRIORITY, which causes the graph + * to use the priorities from the per-node attributes rather than the priority + * of the launch stream during execution. Note that priorities are only available + * on kernel nodes, and are copied from stream priority during stream capture. + * + * If \p hGraph contains any allocation or free nodes, there can be at most one + * executable graph in existence for that graph at a time. An attempt to instantiate + * a second executable graph before destroying the first with ::cuGraphExecDestroy + * will result in an error. + * The same also applies if \p hGraph contains any device-updatable kernel nodes. + * + * If \p hGraph contains kernels which call device-side cudaGraphLaunch() from multiple + * contexts, this will result in an error. + * + * Graphs instantiated for launch on the device have additional restrictions which do not + * apply to host graphs: + * + * - The graph's nodes must reside on a single context. + * - The graph can only contain kernel nodes, memcpy nodes, memset nodes, and child graph nodes. + * - The graph cannot be empty and must contain at least one kernel, memcpy, or memset node. + * Operation-specific restrictions are outlined below. + * - Kernel nodes: + * - Use of CUDA Dynamic Parallelism is not permitted. + * - Cooperative launches are permitted as long as MPS is not in use. + * - Memcpy nodes: + * - Only copies involving device memory and/or pinned device-mapped host memory are permitted. + * - Copies involving CUDA arrays are not permitted. + * - Both operands must be accessible from the current context, and the current context must + * match the context of other nodes in the graph. + * + * \param phGraphExec - Returns instantiated graph + * \param hGraph - Graph to instantiate + * \param flags - Flags to control instantiation. See ::CUgraphInstantiate_flags. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphInstantiate, + * ::cuGraphCreate, + * ::cuGraphUpload, + * ::cuGraphLaunch, + * ::cuGraphExecDestroy + */ +CUresult CUDAAPI cuGraphInstantiate(CUgraphExec *phGraphExec, CUgraph hGraph, unsigned long long flags); + +/** + * \brief Creates an executable graph from a graph + * + * Instantiates \p hGraph as an executable graph according to the \p instantiateParams structure. + * The graph is validated for any structural constraints or intra-node constraints + * which were not previously validated. If instantiation is successful, a handle to + * the instantiated graph is returned in \p phGraphExec. + * + * \p instantiateParams controls the behavior of instantiation and subsequent + * graph launches, as well as returning more detailed information in the event of an error. + * ::CUDA_GRAPH_INSTANTIATE_PARAMS is defined as: + * + * \code + typedef struct { + cuuint64_t flags; + CUstream hUploadStream; + CUgraphNode hErrNode_out; + CUgraphInstantiateResult result_out; + } CUDA_GRAPH_INSTANTIATE_PARAMS; + * \endcode + * + * The \p flags field controls the behavior of instantiation and subsequent + * graph launches. Valid flags are: + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH, which configures a + * graph containing memory allocation nodes to automatically free any + * unfreed memory allocations before the graph is relaunched. + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_UPLOAD, which will perform an upload of the graph + * into \p hUploadStream once the graph has been instantiated. + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_DEVICE_LAUNCH, which configures the graph for launch + * from the device. If this flag is passed, the executable graph handle returned can be + * used to launch the graph from both the host and device. This flag can only be used + * on platforms which support unified addressing. This flag cannot be used in + * conjunction with ::CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH. + * + * - ::CUDA_GRAPH_INSTANTIATE_FLAG_USE_NODE_PRIORITY, which causes the graph + * to use the priorities from the per-node attributes rather than the priority + * of the launch stream during execution. Note that priorities are only available + * on kernel nodes, and are copied from stream priority during stream capture. + * + * If \p hGraph contains any allocation or free nodes, there can be at most one + * executable graph in existence for that graph at a time. An attempt to instantiate a + * second executable graph before destroying the first with ::cuGraphExecDestroy will + * result in an error. + * The same also applies if \p hGraph contains any device-updatable kernel nodes. + * + * If \p hGraph contains kernels which call device-side cudaGraphLaunch() from multiple + * contexts, this will result in an error. + * + * Graphs instantiated for launch on the device have additional restrictions which do not + * apply to host graphs: + * + * - The graph's nodes must reside on a single context. + * - The graph can only contain kernel nodes, memcpy nodes, memset nodes, and child graph nodes. + * - The graph cannot be empty and must contain at least one kernel, memcpy, or memset node. + * Operation-specific restrictions are outlined below. + * - Kernel nodes: + * - Use of CUDA Dynamic Parallelism is not permitted. + * - Cooperative launches are permitted as long as MPS is not in use. + * - Memcpy nodes: + * - Only copies involving device memory and/or pinned device-mapped host memory are permitted. + * - Copies involving CUDA arrays are not permitted. + * - Both operands must be accessible from the current context, and the current context must + * match the context of other nodes in the graph. + * + * In the event of an error, the \p result_out and \p hErrNode_out fields will contain more + * information about the nature of the error. Possible error reporting includes: + * + * - ::CUDA_GRAPH_INSTANTIATE_ERROR, if passed an invalid value or if an unexpected error occurred + * which is described by the return value of the function. \p hErrNode_out will be set to NULL. + * - ::CUDA_GRAPH_INSTANTIATE_INVALID_STRUCTURE, if the graph structure is invalid. \p hErrNode_out + * will be set to one of the offending nodes. + * - ::CUDA_GRAPH_INSTANTIATE_NODE_OPERATION_NOT_SUPPORTED, if the graph is instantiated for device + * launch but contains a node of an unsupported node type, or a node which performs unsupported + * operations, such as use of CUDA dynamic parallelism within a kernel node. \p hErrNode_out will + * be set to this node. + * - ::CUDA_GRAPH_INSTANTIATE_MULTIPLE_CTXS_NOT_SUPPORTED, if the graph is instantiated for device + * launch but a node’s context differs from that of another node. This error can also be returned + * if a graph is not instantiated for device launch and it contains kernels which call device-side + * cudaGraphLaunch() from multiple contexts. \p hErrNode_out will be set to this node. + * + * If instantiation is successful, \p result_out will be set to ::CUDA_GRAPH_INSTANTIATE_SUCCESS, + * and \p hErrNode_out will be set to NULL. + * + * \param phGraphExec - Returns instantiated graph + * \param hGraph - Graph to instantiate + * \param instantiateParams - Instantiation parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate, + * ::cuGraphInstantiate, + * ::cuGraphExecDestroy + */ +CUresult CUDAAPI cuGraphInstantiateWithParams(CUgraphExec *phGraphExec, CUgraph hGraph, CUDA_GRAPH_INSTANTIATE_PARAMS *instantiateParams); + +/** + * \brief Query the instantiation flags of an executable graph + * + * Returns the flags that were passed to instantiation for the given executable graph. + * ::CUDA_GRAPH_INSTANTIATE_FLAG_UPLOAD will not be returned by this API as it does + * not affect the resulting executable graph. + * + * \param hGraphExec - The executable graph to query + * \param flags - Returns the instantiation flags + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphInstantiate, + * ::cuGraphInstantiateWithParams + */ +CUresult CUDAAPI cuGraphExecGetFlags(CUgraphExec hGraphExec, cuuint64_t *flags); + +/** + * \brief Sets the parameters for a kernel node in the given graphExec + * + * Sets the parameters of a kernel node in an executable graph \p hGraphExec. + * The node is identified by the corresponding node \p hNode in the + * non-executable graph, from which the executable graph was instantiated. + * + * \p hNode must not have been removed from the original graph. All \p nodeParams + * fields may change, but the following restrictions apply to \p func updates: + * + * - The owning context of the function cannot change. + * - A node whose function originally did not use CUDA dynamic parallelism cannot be updated + * to a function which uses CDP + * - A node whose function originally did not make device-side update calls cannot be updated + * to a function which makes device-side update calls. + * - If \p hGraphExec was not instantiated for device launch, a node whose function originally + * did not use device-side cudaGraphLaunch() cannot be updated to a function which uses + * device-side cudaGraphLaunch() unless the node resides on the same context as nodes which + * contained such calls at instantiate-time. If no such calls were present at instantiation, + * these updates cannot be performed at all. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * If \p hNode is a device-updatable kernel node, the next upload/launch of \p hGraphExec + * will overwrite any previous device-side updates. Additionally, applying host updates to a + * device-updatable kernel node while it is being updated from the device will result in + * undefined behavior. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - kernel node from the graph from which graphExec was instantiated + * \param nodeParams - Updated Parameters to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddKernelNode, + * ::cuGraphKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecKernelNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_KERNEL_NODE_PARAMS *nodeParams); + +/** + * \brief Sets the parameters for a memcpy node in the given graphExec. + * + * Updates the work represented by \p hNode in \p hGraphExec as though \p hNode had + * contained \p copyParams at instantiation. hNode must remain in the graph which was + * used to instantiate \p hGraphExec. Changed edges to and from hNode are ignored. + * + * The source and destination memory in \p copyParams must be allocated from the same + * contexts as the original source and destination memory. Both the instantiation-time + * memory operands and the memory operands in \p copyParams must be 1-dimensional. + * Zero-length operations are not supported. + * + * The modifications only affect future launches of \p hGraphExec. Already enqueued + * or running launches of \p hGraphExec are not affected by this call. hNode is also + * not modified by this call. + * + * Returns CUDA_ERROR_INVALID_VALUE if the memory operands' mappings changed or + * either the original or new memory operands are multidimensional. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Memcpy node from the graph which was used to instantiate graphExec + * \param copyParams - The updated parameters to set + * \param ctx - Context on which to run the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddMemcpyNode, + * ::cuGraphMemcpyNodeSetParams, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecMemcpyNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_MEMCPY3D *copyParams, CUcontext ctx); + +/** + * \brief Sets the parameters for a memset node in the given graphExec. + * + * Updates the work represented by \p hNode in \p hGraphExec as though \p hNode had + * contained \p memsetParams at instantiation. hNode must remain in the graph which was + * used to instantiate \p hGraphExec. Changed edges to and from hNode are ignored. + * + * Zero sized operations are not supported. + * + * The new destination pointer in memsetParams must be to the same kind of allocation + * as the original destination pointer and have the same context association and device mapping + * as the original destination pointer. + * + * Both the value and pointer address may be updated. + * Changing other aspects of the memset (width, height, element size or pitch) may cause the update to be rejected. + * Specifically, for 2d memsets, all dimension changes are rejected. + * For 1d memsets, changes in height are explicitly rejected and other changes are oportunistically allowed + * if the resulting work maps onto the work resources already allocated for the node. + * + * The modifications only affect future launches of \p hGraphExec. Already enqueued + * or running launches of \p hGraphExec are not affected by this call. hNode is also + * not modified by this call. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Memset node from the graph which was used to instantiate graphExec + * \param memsetParams - The updated parameters to set + * \param ctx - Context on which to run the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddMemsetNode, + * ::cuGraphMemsetNodeSetParams, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecMemsetNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_MEMSET_NODE_PARAMS *memsetParams, CUcontext ctx); + +/** + * \brief Sets the parameters for a host node in the given graphExec. + * + * Updates the work represented by \p hNode in \p hGraphExec as though \p hNode had + * contained \p nodeParams at instantiation. hNode must remain in the graph which was + * used to instantiate \p hGraphExec. Changed edges to and from hNode are ignored. + * + * The modifications only affect future launches of \p hGraphExec. Already enqueued + * or running launches of \p hGraphExec are not affected by this call. hNode is also + * not modified by this call. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Host node from the graph which was used to instantiate graphExec + * \param nodeParams - The updated parameters to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddHostNode, + * ::cuGraphHostNodeSetParams, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecHostNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_HOST_NODE_PARAMS *nodeParams); + +/** + * \brief Updates node parameters in the child graph node in the given graphExec. + * + * Updates the work represented by \p hNode in \p hGraphExec as though the nodes contained + * in \p hNode's graph had the parameters contained in \p childGraph's nodes at instantiation. + * \p hNode must remain in the graph which was used to instantiate \p hGraphExec. + * Changed edges to and from \p hNode are ignored. + * + * The modifications only affect future launches of \p hGraphExec. Already enqueued + * or running launches of \p hGraphExec are not affected by this call. \p hNode is also + * not modified by this call. + * + * The topology of \p childGraph, as well as the node insertion order, must match that + * of the graph contained in \p hNode. See ::cuGraphExecUpdate() for a list of restrictions + * on what can be updated in an instantiated graph. The update is recursive, so child graph + * nodes contained within the top level child graph will also be updated. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Host node from the graph which was used to instantiate graphExec + * \param childGraph - The graph supplying the updated parameters + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddChildGraphNode, + * ::cuGraphChildGraphNodeGetGraph, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecChildGraphNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, CUgraph childGraph); + +/** + * \brief Sets the event for an event record node in the given graphExec + * + * Sets the event of an event record node in an executable graph \p hGraphExec. + * The node is identified by the corresponding node \p hNode in the + * non-executable graph, from which the executable graph was instantiated. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - event record node from the graph from which graphExec was instantiated + * \param event - Updated event to use + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddEventRecordNode, + * ::cuGraphEventRecordNodeGetEvent, + * ::cuGraphEventWaitNodeSetEvent, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecEventRecordNodeSetEvent(CUgraphExec hGraphExec, CUgraphNode hNode, CUevent event); + +/** + * \brief Sets the event for an event wait node in the given graphExec + * + * Sets the event of an event wait node in an executable graph \p hGraphExec. + * The node is identified by the corresponding node \p hNode in the + * non-executable graph, from which the executable graph was instantiated. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - event wait node from the graph from which graphExec was instantiated + * \param event - Updated event to use + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddEventWaitNode, + * ::cuGraphEventWaitNodeGetEvent, + * ::cuGraphEventRecordNodeSetEvent, + * ::cuEventRecordWithFlags, + * ::cuStreamWaitEvent, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecEventWaitNodeSetEvent(CUgraphExec hGraphExec, CUgraphNode hNode, CUevent event); + +/** + * \brief Sets the parameters for an external semaphore signal node in the given graphExec + * + * Sets the parameters of an external semaphore signal node in an executable graph \p hGraphExec. + * The node is identified by the corresponding node \p hNode in the + * non-executable graph, from which the executable graph was instantiated. + * + * \p hNode must not have been removed from the original graph. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * Changing \p nodeParams->numExtSems is not supported. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - semaphore signal node from the graph from which graphExec was instantiated + * \param nodeParams - Updated Parameters to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddExternalSemaphoresSignalNode, + * ::cuImportExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresWaitNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecExternalSemaphoresSignalNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_EXT_SEM_SIGNAL_NODE_PARAMS *nodeParams); + +/** + * \brief Sets the parameters for an external semaphore wait node in the given graphExec + * + * Sets the parameters of an external semaphore wait node in an executable graph \p hGraphExec. + * The node is identified by the corresponding node \p hNode in the + * non-executable graph, from which the executable graph was instantiated. + * + * \p hNode must not have been removed from the original graph. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * Changing \p nodeParams->numExtSems is not supported. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - semaphore wait node from the graph from which graphExec was instantiated + * \param nodeParams - Updated Parameters to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphExecNodeSetParams, + * ::cuGraphAddExternalSemaphoresWaitNode, + * ::cuImportExternalSemaphore, + * ::cuSignalExternalSemaphoresAsync, + * ::cuWaitExternalSemaphoresAsync, + * ::cuGraphExecKernelNodeSetParams, + * ::cuGraphExecMemcpyNodeSetParams, + * ::cuGraphExecMemsetNodeSetParams, + * ::cuGraphExecHostNodeSetParams, + * ::cuGraphExecChildGraphNodeSetParams, + * ::cuGraphExecEventRecordNodeSetEvent, + * ::cuGraphExecEventWaitNodeSetEvent, + * ::cuGraphExecExternalSemaphoresSignalNodeSetParams, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecExternalSemaphoresWaitNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_EXT_SEM_WAIT_NODE_PARAMS *nodeParams); + +/** + * \brief Enables or disables the specified node in the given graphExec + * + * Sets \p hNode to be either enabled or disabled. Disabled nodes are functionally equivalent + * to empty nodes until they are reenabled. Existing node parameters are not affected by + * disabling/enabling the node. + * + * The node is identified by the corresponding node \p hNode in the non-executable + * graph, from which the executable graph was instantiated. + * + * \p hNode must not have been removed from the original graph. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * If \p hNode is a device-updatable kernel node, the next upload/launch of \p hGraphExec + * will overwrite any previous device-side updates. Additionally, applying host updates to a + * device-updatable kernel node while it is being updated from the device will result in + * undefined behavior. + * + * \note Currently only kernel, memset and memcpy nodes are supported. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Node from the graph from which graphExec was instantiated + * \param isEnabled - Node is enabled if != 0, otherwise the node is disabled + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeGetEnabled, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + * ::cuGraphLaunch + */ +CUresult CUDAAPI cuGraphNodeSetEnabled(CUgraphExec hGraphExec, CUgraphNode hNode, unsigned int isEnabled); + +/** + * \brief Query whether a node in the given graphExec is enabled + * + * Sets isEnabled to 1 if \p hNode is enabled, or 0 if \p hNode is disabled. + * + * The node is identified by the corresponding node \p hNode in the non-executable + * graph, from which the executable graph was instantiated. + * + * \p hNode must not have been removed from the original graph. + * + * \note Currently only kernel, memset and memcpy nodes are supported. + * \note This function will not reflect device-side updates for device-updatable kernel nodes. + * + * \param hGraphExec - The executable graph in which to set the specified node + * \param hNode - Node from the graph from which graphExec was instantiated + * \param isEnabled - Location to return the enabled status of the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphNodeSetEnabled, + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + * ::cuGraphLaunch + */ +CUresult CUDAAPI cuGraphNodeGetEnabled(CUgraphExec hGraphExec, CUgraphNode hNode, unsigned int *isEnabled); + +/** + * \brief Uploads an executable graph in a stream + * + * Uploads \p hGraphExec to the device in \p hStream without executing it. Uploads of + * the same \p hGraphExec will be serialized. Each upload is ordered behind both any + * previous work in \p hStream and any previous launches of \p hGraphExec. + * Uses memory cached by \p stream to back the allocations owned by \p hGraphExec. + * + * \param hGraphExec - Executable graph to upload + * \param hStream - Stream in which to upload the graph + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphInstantiate, + * ::cuGraphLaunch, + * ::cuGraphExecDestroy + */ +CUresult CUDAAPI cuGraphUpload(CUgraphExec hGraphExec, CUstream hStream); + +/** + * \brief Launches an executable graph in a stream + * + * Executes \p hGraphExec in \p hStream. Only one instance of \p hGraphExec may be executing + * at a time. Each launch is ordered behind both any previous work in \p hStream + * and any previous launches of \p hGraphExec. To execute a graph concurrently, it must be + * instantiated multiple times into multiple executable graphs. + * + * If any allocations created by \p hGraphExec remain unfreed (from a previous launch) and + * \p hGraphExec was not instantiated with ::CUDA_GRAPH_INSTANTIATE_FLAG_AUTO_FREE_ON_LAUNCH, + * the launch will fail with ::CUDA_ERROR_INVALID_VALUE. + * + * \param hGraphExec - Executable graph to launch + * \param hStream - Stream in which to launch the graph + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphInstantiate, + * ::cuGraphUpload, + * ::cuGraphExecDestroy + */ +CUresult CUDAAPI cuGraphLaunch(CUgraphExec hGraphExec, CUstream hStream); + +/** + * \brief Destroys an executable graph + * + * Destroys the executable graph specified by \p hGraphExec, as well + * as all of its executable nodes. If the executable graph is + * in-flight, it will not be terminated, but rather freed + * asynchronously on completion. + * + * \param hGraphExec - Executable graph to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphInstantiate, + * ::cuGraphUpload, + * ::cuGraphLaunch + */ +CUresult CUDAAPI cuGraphExecDestroy(CUgraphExec hGraphExec); + +/** + * \brief Destroys a graph + * + * Destroys the graph specified by \p hGraph, as well as all of its nodes. + * + * \param hGraph - Graph to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate + */ +CUresult CUDAAPI cuGraphDestroy(CUgraph hGraph); + +/** + * \brief Check whether an executable graph can be updated with a graph and perform the update if possible + * + * Updates the node parameters in the instantiated graph specified by \p hGraphExec with the + * node parameters in a topologically identical graph specified by \p hGraph. + * + * Limitations: + * + * - Kernel nodes: + * - The owning context of the function cannot change. + * - A node whose function originally did not use CUDA dynamic parallelism cannot be updated + * to a function which uses CDP. + * - A node whose function originally did not make device-side update calls cannot be updated + * to a function which makes device-side update calls. + * - A cooperative node cannot be updated to a non-cooperative node, and vice-versa. + * - If the graph was instantiated with CUDA_GRAPH_INSTANTIATE_FLAG_USE_NODE_PRIORITY, the + * priority attribute cannot change. Equality is checked on the originally requested + * priority values, before they are clamped to the device's supported range. + * - If \p hGraphExec was not instantiated for device launch, a node whose function originally + * did not use device-side cudaGraphLaunch() cannot be updated to a function which uses + * device-side cudaGraphLaunch() unless the node resides on the same context as nodes which + * contained such calls at instantiate-time. If no such calls were present at instantiation, + * these updates cannot be performed at all. + * - Neither \p hGraph nor \p hGraphExec may contain device-updatable kernel nodes. + * - Memset and memcpy nodes: + * - The CUDA device(s) to which the operand(s) was allocated/mapped cannot change. + * - The source/destination memory must be allocated from the same contexts as the original + * source/destination memory. + * - For 2d memsets, only address and assinged value may be updated. + * - For 1d memsets, updating dimensions is also allowed, but may fail if the resulting operation doesn't + * map onto the work resources already allocated for the node. + * - Additional memcpy node restrictions: + * - Changing either the source or destination memory type(i.e. CU_MEMORYTYPE_DEVICE, + * CU_MEMORYTYPE_ARRAY, etc.) is not supported. + * - External semaphore wait nodes and record nodes: + * - Changing the number of semaphores is not supported. + * - Conditional nodes: + * - Changing node parameters is not supported. + * - Changeing parameters of nodes within the conditional body graph is subject to the rules above. + * - Conditional handle flags and default values are updated as part of the graph update. + * + * Note: The API may add further restrictions in future releases. The return code should always be checked. + * + * cuGraphExecUpdate sets the result member of \p resultInfo to CU_GRAPH_EXEC_UPDATE_ERROR_TOPOLOGY_CHANGED + * under the following conditions: + * - The count of nodes directly in \p hGraphExec and \p hGraph differ, in which case resultInfo->errorNode + * is set to NULL. + * - \p hGraph has more exit nodes than \p hGraph, in which case resultInfo->errorNode is set to one of + * the exit nodes in hGraph. + * - A node in \p hGraph has a different number of dependencies than the node from \p hGraphExec it is paired with, + * in which case resultInfo->errorNode is set to the node from \p hGraph. + * - A node in \p hGraph has a dependency that does not match with the corresponding dependency of the paired node + * from \p hGraphExec. resultInfo->errorNode will be set to the node from \p hGraph. resultInfo->errorFromNode + * will be set to the mismatched dependency. The dependencies are paired based on edge order and a dependency + * does not match when the nodes are already paired based on other edges examined in the graph. + * + * cuGraphExecUpdate sets the result member of \p resultInfo to: + * - CU_GRAPH_EXEC_UPDATE_ERROR if passed an invalid value. + * - CU_GRAPH_EXEC_UPDATE_ERROR_TOPOLOGY_CHANGED if the graph topology changed + * - CU_GRAPH_EXEC_UPDATE_ERROR_NODE_TYPE_CHANGED if the type of a node changed, in which case + * \p hErrorNode_out is set to the node from \p hGraph. + * - CU_GRAPH_EXEC_UPDATE_ERROR_UNSUPPORTED_FUNCTION_CHANGE if the function changed in an unsupported + * way(see note above), in which case \p hErrorNode_out is set to the node from \p hGraph + * - CU_GRAPH_EXEC_UPDATE_ERROR_PARAMETERS_CHANGED if any parameters to a node changed in a way + * that is not supported, in which case \p hErrorNode_out is set to the node from \p hGraph. + * - CU_GRAPH_EXEC_UPDATE_ERROR_ATTRIBUTES_CHANGED if any attributes of a node changed in a way + * that is not supported, in which case \p hErrorNode_out is set to the node from \p hGraph. + * - CU_GRAPH_EXEC_UPDATE_ERROR_NOT_SUPPORTED if something about a node is unsupported, like + * the node's type or configuration, in which case \p hErrorNode_out is set to the node from \p hGraph + * + * If the update fails for a reason not listed above, the result member of \p resultInfo will be set + * to CU_GRAPH_EXEC_UPDATE_ERROR. If the update succeeds, the result member will be set to CU_GRAPH_EXEC_UPDATE_SUCCESS. + * + * cuGraphExecUpdate returns CUDA_SUCCESS when the updated was performed successfully. It returns + * CUDA_ERROR_GRAPH_EXEC_UPDATE_FAILURE if the graph update was not performed because it included + * changes which violated constraints specific to instantiated graph update. + * + * \param hGraphExec The instantiated graph to be updated + * \param hGraph The graph containing the updated parameters + * \param resultInfo the error info structure + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_GRAPH_EXEC_UPDATE_FAILURE, + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecUpdate(CUgraphExec hGraphExec, CUgraph hGraph, CUgraphExecUpdateResultInfo *resultInfo); + +/** + * \brief Copies attributes from source node to destination node. + * + * Copies attributes from source node \p src to destination node \p dst. + * Both node must have the same context. + * + * \param[out] dst Destination node + * \param[in] src Source node + * For list of attributes see ::CUkernelNodeAttrID + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuGraphKernelNodeCopyAttributes(CUgraphNode dst, CUgraphNode src); + +/** + * \brief Queries node attribute. + * + * Queries attribute \p attr from node \p hNode and stores it in corresponding + * member of \p value_out. + * + * \param[in] hNode + * \param[in] attr + * \param[out] value_out + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuGraphKernelNodeGetAttribute(CUgraphNode hNode, CUkernelNodeAttrID attr, + CUkernelNodeAttrValue *value_out); + +/** + * \brief Sets node attribute. + * + * Sets attribute \p attr on node \p hNode from corresponding attribute of + * \p value. + * + * \param[out] hNode + * \param[in] attr + * \param[out] value + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE + * \notefnerr + * + * \sa + * ::CUaccessPolicyWindow + */ +CUresult CUDAAPI cuGraphKernelNodeSetAttribute(CUgraphNode hNode, CUkernelNodeAttrID attr, + const CUkernelNodeAttrValue *value); + +/** + * \brief Write a DOT file describing graph structure + * + * Using the provided \p hGraph, write to \p path a DOT formatted description of the graph. + * By default this includes the graph topology, node types, node id, kernel names and memcpy direction. + * \p flags can be specified to write more detailed information about each node type such as + * parameter values, kernel attributes, node and function handles. + * + * \param hGraph - The graph to create a DOT file from + * \param path - The path to write the DOT file to + * \param flags - Flags from CUgraphDebugDot_flags for specifying which additional node information to write + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OPERATING_SYSTEM + */ +CUresult CUDAAPI cuGraphDebugDotPrint(CUgraph hGraph, const char *path, unsigned int flags); + +/** + * \brief Create a user object + * + * Create a user object with the specified destructor callback and initial reference count. The + * initial references are owned by the caller. + * + * Destructor callbacks cannot make CUDA API calls and should avoid blocking behavior, as they + * are executed by a shared internal thread. Another thread may be signaled to perform such + * actions, if it does not block forward progress of tasks scheduled through CUDA. + * + * See CUDA User Objects in the CUDA C++ Programming Guide for more information on user objects. + * + * \param object_out - Location to return the user object handle + * \param ptr - The pointer to pass to the destroy function + * \param destroy - Callback to free the user object when it is no longer in use + * \param initialRefcount - The initial refcount to create the object with, typically 1. The + * initial references are owned by the calling thread. + * \param flags - Currently it is required to pass ::CU_USER_OBJECT_NO_DESTRUCTOR_SYNC, + * which is the only defined flag. This indicates that the destroy + * callback cannot be waited on by any CUDA API. Users requiring + * synchronization of the callback should signal its completion + * manually. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuUserObjectRetain, + * ::cuUserObjectRelease, + * ::cuGraphRetainUserObject, + * ::cuGraphReleaseUserObject, + * ::cuGraphCreate + */ +CUresult CUDAAPI cuUserObjectCreate(CUuserObject *object_out, void *ptr, CUhostFn destroy, + unsigned int initialRefcount, unsigned int flags); + +/** + * \brief Retain a reference to a user object + * + * Retains new references to a user object. The new references are owned by the caller. + * + * See CUDA User Objects in the CUDA C++ Programming Guide for more information on user objects. + * + * \param object - The object to retain + * \param count - The number of references to retain, typically 1. Must be nonzero + * and not larger than INT_MAX. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuUserObjectCreate, + * ::cuUserObjectRelease, + * ::cuGraphRetainUserObject, + * ::cuGraphReleaseUserObject, + * ::cuGraphCreate + */ +CUresult CUDAAPI cuUserObjectRetain(CUuserObject object, unsigned int count); + +/** + * \brief Release a reference to a user object + * + * Releases user object references owned by the caller. The object's destructor is invoked if + * the reference count reaches zero. + * + * It is undefined behavior to release references not owned by the caller, or to use a user + * object handle after all references are released. + * + * See CUDA User Objects in the CUDA C++ Programming Guide for more information on user objects. + * + * \param object - The object to release + * \param count - The number of references to release, typically 1. Must be nonzero + * and not larger than INT_MAX. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuUserObjectCreate, + * ::cuUserObjectRetain, + * ::cuGraphRetainUserObject, + * ::cuGraphReleaseUserObject, + * ::cuGraphCreate + */ +CUresult CUDAAPI cuUserObjectRelease(CUuserObject object, unsigned int count); + +/** + * \brief Retain a reference to a user object from a graph + * + * Creates or moves user object references that will be owned by a CUDA graph. + * + * See CUDA User Objects in the CUDA C++ Programming Guide for more information on user objects. + * + * \param graph - The graph to associate the reference with + * \param object - The user object to retain a reference for + * \param count - The number of references to add to the graph, typically 1. Must be + * nonzero and not larger than INT_MAX. + * \param flags - The optional flag ::CU_GRAPH_USER_OBJECT_MOVE transfers references + * from the calling thread, rather than create new references. Pass 0 + * to create new references. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuUserObjectCreate, + * ::cuUserObjectRetain, + * ::cuUserObjectRelease, + * ::cuGraphReleaseUserObject, + * ::cuGraphCreate + */ +CUresult CUDAAPI cuGraphRetainUserObject(CUgraph graph, CUuserObject object, unsigned int count, unsigned int flags); + +/** + * \brief Release a user object reference from a graph + * + * Releases user object references owned by a graph. + * + * See CUDA User Objects in the CUDA C++ Programming Guide for more information on user objects. + * + * \param graph - The graph that will release the reference + * \param object - The user object to release a reference for + * \param count - The number of references to release, typically 1. Must be nonzero + * and not larger than INT_MAX. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuUserObjectCreate, + * ::cuUserObjectRetain, + * ::cuUserObjectRelease, + * ::cuGraphRetainUserObject, + * ::cuGraphCreate + */ +CUresult CUDAAPI cuGraphReleaseUserObject(CUgraph graph, CUuserObject object, unsigned int count); + +/** + * \brief Adds a node of arbitrary type to a graph + * + * Creates a new node in \p hGraph described by \p nodeParams with \p numDependencies + * dependencies specified via \p dependencies. \p numDependencies may be 0. + * \p dependencies may be null if \p numDependencies is 0. \p dependencies may not have + * any duplicate entries. + * + * \p nodeParams is a tagged union. The node type should be specified in the \p type field, + * and type-specific parameters in the corresponding union member. All unused bytes - that + * is, \p reserved0 and all bytes past the utilized union member - must be set to zero. + * It is recommended to use brace initialization or memset to ensure all bytes are + * initialized. + * + * Note that for some node types, \p nodeParams may contain "out parameters" which are + * modified during the call, such as \p nodeParams->alloc.dptr. + * + * A handle to the new node will be returned in \p phGraphNode. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param numDependencies - Number of dependencies + * \param nodeParams - Specification of the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate, + * ::cuGraphNodeSetParams, + * ::cuGraphExecNodeSetParams + */ +CUresult CUDAAPI cuGraphAddNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, CUgraphNodeParams *nodeParams); + +/** + * \brief Adds a node of arbitrary type to a graph (12.3+) + * + * Creates a new node in \p hGraph described by \p nodeParams with \p numDependencies + * dependencies specified via \p dependencies. \p numDependencies may be 0. + * \p dependencies may be null if \p numDependencies is 0. \p dependencies may not have + * any duplicate entries. + * + * \p nodeParams is a tagged union. The node type should be specified in the \p type field, + * and type-specific parameters in the corresponding union member. All unused bytes - that + * is, \p reserved0 and all bytes past the utilized union member - must be set to zero. + * It is recommended to use brace initialization or memset to ensure all bytes are + * initialized. + * + * Note that for some node types, \p nodeParams may contain "out parameters" which are + * modified during the call, such as \p nodeParams->alloc.dptr. + * + * A handle to the new node will be returned in \p phGraphNode. + * + * \param phGraphNode - Returns newly created node + * \param hGraph - Graph to which to add the node + * \param dependencies - Dependencies of the node + * \param dependencyData - Optional edge data for the dependencies. If NULL, the data is + * assumed to be default (zeroed) for all dependencies. + * \param numDependencies - Number of dependencies + * \param nodeParams - Specification of the node + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphCreate, + * ::cuGraphNodeSetParams, + * ::cuGraphExecNodeSetParams + */ +CUresult CUDAAPI cuGraphAddNode_v2(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, const CUgraphEdgeData *dependencyData, size_t numDependencies, CUgraphNodeParams *nodeParams); + +/** + * \brief Update's a graph node's parameters + * + * Sets the parameters of graph node \p hNode to \p nodeParams. The node type specified by + * \p nodeParams->type must match the type of \p hNode. \p nodeParams must be fully + * initialized and all unused bytes (reserved, padding) zeroed. + * + * Modifying parameters is not supported for node types CU_GRAPH_NODE_TYPE_MEM_ALLOC and + * CU_GRAPH_NODE_TYPE_MEM_FREE. + * + * \param hNode - Node to set the parameters for + * \param nodeParams - Parameters to copy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphExecNodeSetParams + */ +CUresult CUDAAPI cuGraphNodeSetParams(CUgraphNode hNode, CUgraphNodeParams *nodeParams); + +/** + * \brief Update's a graph node's parameters in an instantiated graph + * + * Sets the parameters of a node in an executable graph \p hGraphExec. The node is identified + * by the corresponding node \p hNode in the non-executable graph from which the executable + * graph was instantiated. \p hNode must not have been removed from the original graph. + * + * The modifications only affect future launches of \p hGraphExec. Already + * enqueued or running launches of \p hGraphExec are not affected by this call. + * \p hNode is also not modified by this call. + * + * Allowed changes to parameters on executable graphs are as follows: + * + *
    Node typeAllowed changes + *
    kernelSee ::cuGraphExecKernelNodeSetParams + *
    memcpyAddresses for 1-dimensional copies if allocated in same context; see ::cuGraphExecMemcpyNodeSetParams + *
    memsetAddresses for 1-dimensional memsets if allocated in same context; see ::cuGraphExecMemsetNodeSetParams + *
    hostUnrestricted + *
    child graphTopology must match and restrictions apply recursively; see ::cuGraphExecUpdate + *
    event waitUnrestricted + *
    event recordUnrestricted + *
    external semaphore signalNumber of semaphore operations cannot change + *
    external semaphore waitNumber of semaphore operations cannot change + *
    memory allocationAPI unsupported + *
    memory freeAPI unsupported + *
    batch memopsAddresses, values, and operation type for wait operations; see ::cuGraphExecBatchMemOpNodeSetParams + *
    + * + * \param hGraphExec - The executable graph in which to update the specified node + * \param hNode - Corresponding node from the graph from which graphExec was instantiated + * \param nodeParams - Updated Parameters to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode, + * ::cuGraphNodeSetParams + * ::cuGraphExecUpdate, + * ::cuGraphInstantiate + */ +CUresult CUDAAPI cuGraphExecNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, CUgraphNodeParams *nodeParams); + +/** + * \brief Create a conditional handle + * + * Creates a conditional handle associated with \p hGraph. + * + * The conditional handle must be associated with a conditional node in this graph or one of its children. + * + * Handles not associated with a conditional node may cause graph instantiation to fail. + * + * Handles can only be set from the context with which they are associated. + * + * \param pHandle_out - Pointer used to return the handle to the caller. + * \param hGraph - Graph which will contain the conditional node using this handle. + * \param ctx - Context for the handle and associated conditional node. + * \param defaultLaunchValue - Optional initial value for the conditional variable. + * \param flags - Currently must be CU_GRAPH_COND_ASSIGN_DEFAULT or 0. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_graph_thread_safety + * \notefnerr + * + * \sa + * ::cuGraphAddNode + */ +CUresult CUDAAPI cuGraphConditionalHandleCreate(CUgraphConditionalHandle *pHandle_out, CUgraph hGraph, CUcontext ctx, unsigned int defaultLaunchValue, unsigned int flags); + +/** @} */ /* END CUDA_GRAPH */ + +/** + * \defgroup CUDA_OCCUPANCY Occupancy + * + * ___MANBRIEF___ occupancy calculation functions of the low-level CUDA driver + * API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the occupancy calculation functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns occupancy of a function + * + * Returns in \p *numBlocks the number of the maximum active blocks per + * streaming multiprocessor. + * + * Note that the API can also be used with context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will be the current context. + * + * \param numBlocks - Returned occupancy + * \param func - Kernel for which occupancy is calculated + * \param blockSize - Block size the kernel is intended to be launched with + * \param dynamicSMemSize - Per-block dynamic shared memory usage intended, in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cudaOccupancyMaxActiveBlocksPerMultiprocessor + */ +CUresult CUDAAPI cuOccupancyMaxActiveBlocksPerMultiprocessor(int *numBlocks, CUfunction func, int blockSize, size_t dynamicSMemSize); + +/** + * \brief Returns occupancy of a function + * + * Returns in \p *numBlocks the number of the maximum active blocks per + * streaming multiprocessor. + * + * The \p Flags parameter controls how special cases are handled. The + * valid flags are: + * + * - ::CU_OCCUPANCY_DEFAULT, which maintains the default behavior as + * ::cuOccupancyMaxActiveBlocksPerMultiprocessor; + * + * - ::CU_OCCUPANCY_DISABLE_CACHING_OVERRIDE, which suppresses the + * default behavior on platform where global caching affects + * occupancy. On such platforms, if caching is enabled, but + * per-block SM resource usage would result in zero occupancy, the + * occupancy calculator will calculate the occupancy as if caching + * is disabled. Setting ::CU_OCCUPANCY_DISABLE_CACHING_OVERRIDE makes + * the occupancy calculator to return 0 in such cases. More information + * can be found about this feature in the "Unified L1/Texture Cache" + * section of the Maxwell tuning guide. + * + * Note that the API can also be with launch context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will be the current context. + * + * \param numBlocks - Returned occupancy + * \param func - Kernel for which occupancy is calculated + * \param blockSize - Block size the kernel is intended to be launched with + * \param dynamicSMemSize - Per-block dynamic shared memory usage intended, in bytes + * \param flags - Requested behavior for the occupancy calculator + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cudaOccupancyMaxActiveBlocksPerMultiprocessorWithFlags + */ +CUresult CUDAAPI cuOccupancyMaxActiveBlocksPerMultiprocessorWithFlags(int *numBlocks, CUfunction func, int blockSize, size_t dynamicSMemSize, unsigned int flags); + +/** + * \brief Suggest a launch configuration with reasonable occupancy + * + * Returns in \p *blockSize a reasonable block size that can achieve + * the maximum occupancy (or, the maximum number of active warps with + * the fewest blocks per multiprocessor), and in \p *minGridSize the + * minimum grid size to achieve the maximum occupancy. + * + * If \p blockSizeLimit is 0, the configurator will use the maximum + * block size permitted by the device / function instead. + * + * If per-block dynamic shared memory allocation is not needed, the + * user should leave both \p blockSizeToDynamicSMemSize and \p + * dynamicSMemSize as 0. + * + * If per-block dynamic shared memory allocation is needed, then if + * the dynamic shared memory size is constant regardless of block + * size, the size should be passed through \p dynamicSMemSize, and \p + * blockSizeToDynamicSMemSize should be NULL. + * + * Otherwise, if the per-block dynamic shared memory size varies with + * different block sizes, the user needs to provide a unary function + * through \p blockSizeToDynamicSMemSize that computes the dynamic + * shared memory needed by \p func for any given block size. \p + * dynamicSMemSize is ignored. An example signature is: + * + * \code + * // Take block size, returns dynamic shared memory needed + * size_t blockToSmem(int blockSize); + * \endcode + * + * Note that the API can also be used with context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will be the current context. + * + * \param minGridSize - Returned minimum grid size needed to achieve the maximum occupancy + * \param blockSize - Returned maximum block size that can achieve the maximum occupancy + * \param func - Kernel for which launch configuration is calculated + * \param blockSizeToDynamicSMemSize - A function that calculates how much per-block dynamic shared memory \p func uses based on the block size + * \param dynamicSMemSize - Dynamic shared memory usage intended, in bytes + * \param blockSizeLimit - The maximum block size \p func is designed to handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cudaOccupancyMaxPotentialBlockSize + */ +CUresult CUDAAPI cuOccupancyMaxPotentialBlockSize(int *minGridSize, int *blockSize, CUfunction func, CUoccupancyB2DSize blockSizeToDynamicSMemSize, size_t dynamicSMemSize, int blockSizeLimit); + +/** + * \brief Suggest a launch configuration with reasonable occupancy + * + * An extended version of ::cuOccupancyMaxPotentialBlockSize. In + * addition to arguments passed to ::cuOccupancyMaxPotentialBlockSize, + * ::cuOccupancyMaxPotentialBlockSizeWithFlags also takes a \p Flags + * parameter. + * + * The \p Flags parameter controls how special cases are handled. The + * valid flags are: + * + * - ::CU_OCCUPANCY_DEFAULT, which maintains the default behavior as + * ::cuOccupancyMaxPotentialBlockSize; + * + * - ::CU_OCCUPANCY_DISABLE_CACHING_OVERRIDE, which suppresses the + * default behavior on platform where global caching affects + * occupancy. On such platforms, the launch configurations that + * produces maximal occupancy might not support global + * caching. Setting ::CU_OCCUPANCY_DISABLE_CACHING_OVERRIDE + * guarantees that the the produced launch configuration is global + * caching compatible at a potential cost of occupancy. More information + * can be found about this feature in the "Unified L1/Texture Cache" + * section of the Maxwell tuning guide. + * + * Note that the API can also be used with context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will be the current context. + * + * \param minGridSize - Returned minimum grid size needed to achieve the maximum occupancy + * \param blockSize - Returned maximum block size that can achieve the maximum occupancy + * \param func - Kernel for which launch configuration is calculated + * \param blockSizeToDynamicSMemSize - A function that calculates how much per-block dynamic shared memory \p func uses based on the block size + * \param dynamicSMemSize - Dynamic shared memory usage intended, in bytes + * \param blockSizeLimit - The maximum block size \p func is designed to handle + * \param flags - Options + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cudaOccupancyMaxPotentialBlockSizeWithFlags + */ +CUresult CUDAAPI cuOccupancyMaxPotentialBlockSizeWithFlags(int *minGridSize, int *blockSize, CUfunction func, CUoccupancyB2DSize blockSizeToDynamicSMemSize, size_t dynamicSMemSize, int blockSizeLimit, unsigned int flags); + +/** + * \brief Returns dynamic shared memory available per block when launching \p numBlocks blocks on SM + * + * Returns in \p *dynamicSmemSize the maximum size of dynamic shared memory to allow \p numBlocks blocks per SM. + * + * Note that the API can also be used with context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will be the current context. + * + * \param dynamicSmemSize - Returned maximum dynamic shared memory + * \param func - Kernel function for which occupancy is calculated + * \param numBlocks - Number of blocks to fit on SM + * \param blockSize - Size of the blocks + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + */ +CUresult CUDAAPI cuOccupancyAvailableDynamicSMemPerBlock(size_t *dynamicSmemSize, CUfunction func, int numBlocks, int blockSize); + +/** + * \brief Given the kernel function (\p func) and launch configuration + * (\p config), return the maximum cluster size in \p *clusterSize. + * + * The cluster dimensions in \p config are ignored. If func has a required + * cluster size set (see ::cudaFuncGetAttributes / ::cuFuncGetAttribute),\p + * *clusterSize will reflect the required cluster size. + * + * By default this function will always return a value that's portable on + * future hardware. A higher value may be returned if the kernel function + * allows non-portable cluster sizes. + * + * This function will respect the compile time launch bounds. + * + * Note that the API can also be used with context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will either be taken from the specified stream \p config->hStream + * or the current context in case of NULL stream. + * + * \param clusterSize - Returned maximum cluster size that can be launched + * for the given kernel function and launch configuration + * \param func - Kernel function for which maximum cluster + * size is calculated + * \param config - Launch configuration for the given kernel function + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cudaFuncGetAttributes, + * ::cuFuncGetAttribute + */ +CUresult CUDAAPI cuOccupancyMaxPotentialClusterSize(int *clusterSize, CUfunction func, const CUlaunchConfig *config); + +/** + * \brief Given the kernel function (\p func) and launch configuration + * (\p config), return the maximum number of clusters that could co-exist + * on the target device in \p *numClusters. + * + * If the function has required cluster size already set (see + * ::cudaFuncGetAttributes / ::cuFuncGetAttribute), the cluster size + * from config must either be unspecified or match the required size. + * Without required sizes, the cluster size must be specified in config, + * else the function will return an error. + * + * Note that various attributes of the kernel function may affect occupancy + * calculation. Runtime environment may affect how the hardware schedules + * the clusters, so the calculated occupancy is not guaranteed to be achievable. + * + * Note that the API can also be used with context-less kernel ::CUkernel + * by querying the handle using ::cuLibraryGetKernel() and then passing it + * to the API by casting to ::CUfunction. Here, the context to use for calculations + * will either be taken from the specified stream \p config->hStream + * or the current context in case of NULL stream. + * + * \param numClusters - Returned maximum number of clusters that + * could co-exist on the target device + * \param func - Kernel function for which maximum number + * of clusters are calculated + * \param config - Launch configuration for the given kernel function + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_CLUSTER_SIZE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cudaFuncGetAttributes, + * ::cuFuncGetAttribute + */ +CUresult CUDAAPI cuOccupancyMaxActiveClusters(int *numClusters, CUfunction func, const CUlaunchConfig *config); +/** @} */ /* END CUDA_OCCUPANCY */ + +/** + * \defgroup CUDA_TEXREF_DEPRECATED Texture Reference Management [DEPRECATED] + * + * ___MANBRIEF___ deprecated texture reference management functions of the + * low-level CUDA driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the deprecated texture reference management + * functions of the low-level CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Binds an array as a texture reference + * + * \deprecated + * + * Binds the CUDA array \p hArray to the texture reference \p hTexRef. Any + * previous address or CUDA array state associated with the texture reference + * is superseded by this function. \p Flags must be set to + * ::CU_TRSA_OVERRIDE_FORMAT. Any CUDA array previously bound to \p hTexRef is + * unbound. + * + * \param hTexRef - Texture reference to bind + * \param hArray - Array to bind + * \param Flags - Options (must be ::CU_TRSA_OVERRIDE_FORMAT) + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetArray(CUtexref hTexRef, CUarray hArray, unsigned int Flags); + +/** + * \brief Binds a mipmapped array to a texture reference + * + * \deprecated + * + * Binds the CUDA mipmapped array \p hMipmappedArray to the texture reference \p hTexRef. + * Any previous address or CUDA array state associated with the texture reference + * is superseded by this function. \p Flags must be set to ::CU_TRSA_OVERRIDE_FORMAT. + * Any CUDA array previously bound to \p hTexRef is unbound. + * + * \param hTexRef - Texture reference to bind + * \param hMipmappedArray - Mipmapped array to bind + * \param Flags - Options (must be ::CU_TRSA_OVERRIDE_FORMAT) + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetMipmappedArray(CUtexref hTexRef, CUmipmappedArray hMipmappedArray, unsigned int Flags); + +/** + * \brief Binds an address as a texture reference + * + * \deprecated + * + * Binds a linear address range to the texture reference \p hTexRef. Any + * previous address or CUDA array state associated with the texture reference + * is superseded by this function. Any memory previously bound to \p hTexRef + * is unbound. + * + * Since the hardware enforces an alignment requirement on texture base + * addresses, ::cuTexRefSetAddress() passes back a byte offset in + * \p *ByteOffset that must be applied to texture fetches in order to read from + * the desired memory. This offset must be divided by the texel size and + * passed to kernels that read from the texture so they can be applied to the + * ::tex1Dfetch() function. + * + * If the device memory pointer was returned from ::cuMemAlloc(), the offset + * is guaranteed to be 0 and NULL may be passed as the \p ByteOffset parameter. + * + * The total number of elements (or texels) in the linear address range + * cannot exceed ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LINEAR_WIDTH. + * The number of elements is computed as (\p bytes / bytesPerElement), + * where bytesPerElement is determined from the data format and number of + * components set using ::cuTexRefSetFormat(). + * + * \param ByteOffset - Returned byte offset + * \param hTexRef - Texture reference to bind + * \param dptr - Device pointer to bind + * \param bytes - Size of memory to bind in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetAddress(size_t *ByteOffset, CUtexref hTexRef, CUdeviceptr dptr, size_t bytes); + +/** + * \brief Binds an address as a 2D texture reference + * + * \deprecated + * + * Binds a linear address range to the texture reference \p hTexRef. Any + * previous address or CUDA array state associated with the texture reference + * is superseded by this function. Any memory previously bound to \p hTexRef + * is unbound. + * + * Using a ::tex2D() function inside a kernel requires a call to either + * ::cuTexRefSetArray() to bind the corresponding texture reference to an + * array, or ::cuTexRefSetAddress2D() to bind the texture reference to linear + * memory. + * + * Function calls to ::cuTexRefSetFormat() cannot follow calls to + * ::cuTexRefSetAddress2D() for the same texture reference. + * + * It is required that \p dptr be aligned to the appropriate hardware-specific + * texture alignment. You can query this value using the device attribute + * ::CU_DEVICE_ATTRIBUTE_TEXTURE_ALIGNMENT. If an unaligned \p dptr is + * supplied, ::CUDA_ERROR_INVALID_VALUE is returned. + * + * \p Pitch has to be aligned to the hardware-specific texture pitch alignment. + * This value can be queried using the device attribute + * ::CU_DEVICE_ATTRIBUTE_TEXTURE_PITCH_ALIGNMENT. If an unaligned \p Pitch is + * supplied, ::CUDA_ERROR_INVALID_VALUE is returned. + * + * Width and Height, which are specified in elements (or texels), cannot exceed + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_WIDTH and + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_HEIGHT respectively. + * \p Pitch, which is specified in bytes, cannot exceed + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_PITCH. + * + * \param hTexRef - Texture reference to bind + * \param desc - Descriptor of CUDA array + * \param dptr - Device pointer to bind + * \param Pitch - Line pitch in bytes + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetAddress2D(CUtexref hTexRef, const CUDA_ARRAY_DESCRIPTOR *desc, CUdeviceptr dptr, size_t Pitch); + +/** + * \brief Sets the format for a texture reference + * + * \deprecated + * + * Specifies the format of the data to be read by the texture reference + * \p hTexRef. \p fmt and \p NumPackedComponents are exactly analogous to the + * ::Format and ::NumChannels members of the ::CUDA_ARRAY_DESCRIPTOR structure: + * They specify the format of each component and the number of components per + * array element. + * + * \param hTexRef - Texture reference + * \param fmt - Format to set + * \param NumPackedComponents - Number of components per array element + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat, + * ::cudaCreateChannelDesc + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetFormat(CUtexref hTexRef, CUarray_format fmt, int NumPackedComponents); + +/** + * \brief Sets the addressing mode for a texture reference + * + * \deprecated + * + * Specifies the addressing mode \p am for the given dimension \p dim of the + * texture reference \p hTexRef. If \p dim is zero, the addressing mode is + * applied to the first parameter of the functions used to fetch from the + * texture; if \p dim is 1, the second, and so on. ::CUaddress_mode is defined + * as: + * \code + typedef enum CUaddress_mode_enum { + CU_TR_ADDRESS_MODE_WRAP = 0, + CU_TR_ADDRESS_MODE_CLAMP = 1, + CU_TR_ADDRESS_MODE_MIRROR = 2, + CU_TR_ADDRESS_MODE_BORDER = 3 + } CUaddress_mode; + * \endcode + * + * Note that this call has no effect if \p hTexRef is bound to linear memory. + * Also, if the flag, ::CU_TRSF_NORMALIZED_COORDINATES, is not set, the only + * supported address mode is ::CU_TR_ADDRESS_MODE_CLAMP. + * + * \param hTexRef - Texture reference + * \param dim - Dimension + * \param am - Addressing mode to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetAddressMode(CUtexref hTexRef, int dim, CUaddress_mode am); + +/** + * \brief Sets the filtering mode for a texture reference + * + * \deprecated + * + * Specifies the filtering mode \p fm to be used when reading memory through + * the texture reference \p hTexRef. ::CUfilter_mode_enum is defined as: + * + * \code + typedef enum CUfilter_mode_enum { + CU_TR_FILTER_MODE_POINT = 0, + CU_TR_FILTER_MODE_LINEAR = 1 + } CUfilter_mode; + * \endcode + * + * Note that this call has no effect if \p hTexRef is bound to linear memory. + * + * \param hTexRef - Texture reference + * \param fm - Filtering mode to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetFilterMode(CUtexref hTexRef, CUfilter_mode fm); + +/** + * \brief Sets the mipmap filtering mode for a texture reference + * + * \deprecated + * + * Specifies the mipmap filtering mode \p fm to be used when reading memory through + * the texture reference \p hTexRef. ::CUfilter_mode_enum is defined as: + * + * \code + typedef enum CUfilter_mode_enum { + CU_TR_FILTER_MODE_POINT = 0, + CU_TR_FILTER_MODE_LINEAR = 1 + } CUfilter_mode; + * \endcode + * + * Note that this call has no effect if \p hTexRef is not bound to a mipmapped array. + * + * \param hTexRef - Texture reference + * \param fm - Filtering mode to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetMipmapFilterMode(CUtexref hTexRef, CUfilter_mode fm); + +/** + * \brief Sets the mipmap level bias for a texture reference + * + * \deprecated + * + * Specifies the mipmap level bias \p bias to be added to the specified mipmap level when + * reading memory through the texture reference \p hTexRef. + * + * Note that this call has no effect if \p hTexRef is not bound to a mipmapped array. + * + * \param hTexRef - Texture reference + * \param bias - Mipmap level bias + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetMipmapLevelBias(CUtexref hTexRef, float bias); + +/** + * \brief Sets the mipmap min/max mipmap level clamps for a texture reference + * + * \deprecated + * + * Specifies the min/max mipmap level clamps, \p minMipmapLevelClamp and \p maxMipmapLevelClamp + * respectively, to be used when reading memory through the texture reference + * \p hTexRef. + * + * Note that this call has no effect if \p hTexRef is not bound to a mipmapped array. + * + * \param hTexRef - Texture reference + * \param minMipmapLevelClamp - Mipmap min level clamp + * \param maxMipmapLevelClamp - Mipmap max level clamp + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetMipmapLevelClamp(CUtexref hTexRef, float minMipmapLevelClamp, float maxMipmapLevelClamp); + +/** + * \brief Sets the maximum anisotropy for a texture reference + * + * \deprecated + * + * Specifies the maximum anisotropy \p maxAniso to be used when reading memory through + * the texture reference \p hTexRef. + * + * Note that this call has no effect if \p hTexRef is bound to linear memory. + * + * \param hTexRef - Texture reference + * \param maxAniso - Maximum anisotropy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetMaxAnisotropy(CUtexref hTexRef, unsigned int maxAniso); + +/** + * \brief Sets the border color for a texture reference + * + * \deprecated + * + * Specifies the value of the RGBA color via the \p pBorderColor to the texture reference + * \p hTexRef. The color value supports only float type and holds color components in + * the following sequence: + * pBorderColor[0] holds 'R' component + * pBorderColor[1] holds 'G' component + * pBorderColor[2] holds 'B' component + * pBorderColor[3] holds 'A' component + * + * Note that the color values can be set only when the Address mode is set to + * CU_TR_ADDRESS_MODE_BORDER using ::cuTexRefSetAddressMode. + * Applications using integer border color values have to "reinterpret_cast" their values to float. + * + * \param hTexRef - Texture reference + * \param pBorderColor - RGBA color + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddressMode, + * ::cuTexRefGetAddressMode, ::cuTexRefGetBorderColor + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetBorderColor(CUtexref hTexRef, float *pBorderColor); + +/** + * \brief Sets the flags for a texture reference + * + * \deprecated + * + * Specifies optional flags via \p Flags to specify the behavior of data + * returned through the texture reference \p hTexRef. The valid flags are: + * + * - ::CU_TRSF_READ_AS_INTEGER, which suppresses the default behavior of + * having the texture promote integer data to floating point data in the + * range [0, 1]. Note that texture with 32-bit integer format + * would not be promoted, regardless of whether or not this + * flag is specified; + * - ::CU_TRSF_NORMALIZED_COORDINATES, which suppresses the + * default behavior of having the texture coordinates range + * from [0, Dim) where Dim is the width or height of the CUDA + * array. Instead, the texture coordinates [0, 1.0) reference + * the entire breadth of the array dimension; + * - ::CU_TRSF_DISABLE_TRILINEAR_OPTIMIZATION, which disables any trilinear + * filtering optimizations. Trilinear optimizations improve texture filtering + * performance by allowing bilinear filtering on textures in scenarios where + * it can closely approximate the expected results. + * + * \param hTexRef - Texture reference + * \param Flags - Optional flags to set + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefSetFlags(CUtexref hTexRef, unsigned int Flags); + +/** + * \brief Gets the address associated with a texture reference + * + * \deprecated + * + * Returns in \p *pdptr the base address bound to the texture reference + * \p hTexRef, or returns ::CUDA_ERROR_INVALID_VALUE if the texture reference + * is not bound to any device memory range. + * + * \param pdptr - Returned device address + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetAddress(CUdeviceptr *pdptr, CUtexref hTexRef); + +/** + * \brief Gets the array bound to a texture reference + * + * \deprecated + * + * Returns in \p *phArray the CUDA array bound to the texture reference + * \p hTexRef, or returns ::CUDA_ERROR_INVALID_VALUE if the texture reference + * is not bound to any CUDA array. + * + * \param phArray - Returned array + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetArray(CUarray *phArray, CUtexref hTexRef); + +/** + * \brief Gets the mipmapped array bound to a texture reference + * + * \deprecated + * + * Returns in \p *phMipmappedArray the CUDA mipmapped array bound to the texture + * reference \p hTexRef, or returns ::CUDA_ERROR_INVALID_VALUE if the texture reference + * is not bound to any CUDA mipmapped array. + * + * \param phMipmappedArray - Returned mipmapped array + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetMipmappedArray(CUmipmappedArray *phMipmappedArray, CUtexref hTexRef); + +/** + * \brief Gets the addressing mode used by a texture reference + * + * \deprecated + * + * Returns in \p *pam the addressing mode corresponding to the + * dimension \p dim of the texture reference \p hTexRef. Currently, the only + * valid value for \p dim are 0 and 1. + * + * \param pam - Returned addressing mode + * \param hTexRef - Texture reference + * \param dim - Dimension + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetAddressMode(CUaddress_mode *pam, CUtexref hTexRef, int dim); + +/** + * \brief Gets the filter-mode used by a texture reference + * + * \deprecated + * + * Returns in \p *pfm the filtering mode of the texture reference + * \p hTexRef. + * + * \param pfm - Returned filtering mode + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetFilterMode(CUfilter_mode *pfm, CUtexref hTexRef); + +/** + * \brief Gets the format used by a texture reference + * + * \deprecated + * + * Returns in \p *pFormat and \p *pNumChannels the format and number + * of components of the CUDA array bound to the texture reference \p hTexRef. + * If \p pFormat or \p pNumChannels is NULL, it will be ignored. + * + * \param pFormat - Returned format + * \param pNumChannels - Returned number of components + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetFormat(CUarray_format *pFormat, int *pNumChannels, CUtexref hTexRef); + +/** + * \brief Gets the mipmap filtering mode for a texture reference + * + * \deprecated + * + * Returns the mipmap filtering mode in \p pfm that's used when reading memory through + * the texture reference \p hTexRef. + * + * \param pfm - Returned mipmap filtering mode + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetMipmapFilterMode(CUfilter_mode *pfm, CUtexref hTexRef); + +/** + * \brief Gets the mipmap level bias for a texture reference + * + * \deprecated + * + * Returns the mipmap level bias in \p pBias that's added to the specified mipmap + * level when reading memory through the texture reference \p hTexRef. + * + * \param pbias - Returned mipmap level bias + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetMipmapLevelBias(float *pbias, CUtexref hTexRef); + +/** + * \brief Gets the min/max mipmap level clamps for a texture reference + * + * \deprecated + * + * Returns the min/max mipmap level clamps in \p pminMipmapLevelClamp and \p pmaxMipmapLevelClamp + * that's used when reading memory through the texture reference \p hTexRef. + * + * \param pminMipmapLevelClamp - Returned mipmap min level clamp + * \param pmaxMipmapLevelClamp - Returned mipmap max level clamp + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetMipmapLevelClamp(float *pminMipmapLevelClamp, float *pmaxMipmapLevelClamp, CUtexref hTexRef); + +/** + * \brief Gets the maximum anisotropy for a texture reference + * + * \deprecated + * + * Returns the maximum anisotropy in \p pmaxAniso that's used when reading memory through + * the texture reference \p hTexRef. + * + * \param pmaxAniso - Returned maximum anisotropy + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFlags, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetMaxAnisotropy(int *pmaxAniso, CUtexref hTexRef); + +/** + * \brief Gets the border color used by a texture reference + * + * \deprecated + * + * Returns in \p pBorderColor, values of the RGBA color used by + * the texture reference \p hTexRef. + * The color value is of type float and holds color components in + * the following sequence: + * pBorderColor[0] holds 'R' component + * pBorderColor[1] holds 'G' component + * pBorderColor[2] holds 'B' component + * pBorderColor[3] holds 'A' component + * + * \param hTexRef - Texture reference + * \param pBorderColor - Returned Type and Value of RGBA color + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddressMode, + * ::cuTexRefSetAddressMode, ::cuTexRefSetBorderColor + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetBorderColor(float *pBorderColor, CUtexref hTexRef); + +/** + * \brief Gets the flags used by a texture reference + * + * \deprecated + * + * Returns in \p *pFlags the flags of the texture reference \p hTexRef. + * + * \param pFlags - Returned flags + * \param hTexRef - Texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefSetAddress, + * ::cuTexRefSetAddress2D, ::cuTexRefSetAddressMode, ::cuTexRefSetArray, + * ::cuTexRefSetFilterMode, ::cuTexRefSetFlags, ::cuTexRefSetFormat, + * ::cuTexRefGetAddress, ::cuTexRefGetAddressMode, ::cuTexRefGetArray, + * ::cuTexRefGetFilterMode, ::cuTexRefGetFormat + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefGetFlags(unsigned int *pFlags, CUtexref hTexRef); + +/** + * \brief Creates a texture reference + * + * \deprecated + * + * Creates a texture reference and returns its handle in \p *pTexRef. Once + * created, the application must call ::cuTexRefSetArray() or + * ::cuTexRefSetAddress() to associate the reference with allocated memory. + * Other texture reference functions are used to specify the format and + * interpretation (addressing, filtering, etc.) to be used when the memory is + * read through this texture reference. + * + * \param pTexRef - Returned texture reference + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefDestroy + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefCreate(CUtexref *pTexRef); + +/** + * \brief Destroys a texture reference + * + * \deprecated + * + * Destroys the texture reference specified by \p hTexRef. + * + * \param hTexRef - Texture reference to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuTexRefCreate + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuTexRefDestroy(CUtexref hTexRef); + +/** @} */ /* END CUDA_TEXREF_DEPRECATED */ + + +/** + * \defgroup CUDA_SURFREF_DEPRECATED Surface Reference Management [DEPRECATED] + * + * ___MANBRIEF___ surface reference management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the surface reference management functions of the + * low-level CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Sets the CUDA array for a surface reference. + * + * \deprecated + * + * Sets the CUDA array \p hArray to be read and written by the surface reference + * \p hSurfRef. Any previous CUDA array state associated with the surface + * reference is superseded by this function. \p Flags must be set to 0. + * The ::CUDA_ARRAY3D_SURFACE_LDST flag must have been set for the CUDA array. + * Any CUDA array previously bound to \p hSurfRef is unbound. + + * \param hSurfRef - Surface reference handle + * \param hArray - CUDA array handle + * \param Flags - set to 0 + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuModuleGetSurfRef, + * ::cuSurfRefGetArray + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuSurfRefSetArray(CUsurfref hSurfRef, CUarray hArray, unsigned int Flags); + +/** + * \brief Passes back the CUDA array bound to a surface reference. + * + * \deprecated + * + * Returns in \p *phArray the CUDA array bound to the surface reference + * \p hSurfRef, or returns ::CUDA_ERROR_INVALID_VALUE if the surface reference + * is not bound to any CUDA array. + + * \param phArray - Surface reference handle + * \param hSurfRef - Surface reference handle + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa ::cuModuleGetSurfRef, ::cuSurfRefSetArray + */ +__CUDA_DEPRECATED CUresult CUDAAPI cuSurfRefGetArray(CUarray *phArray, CUsurfref hSurfRef); + +/** @} */ /* END CUDA_SURFREF_DEPRECATED */ + +/** + * \defgroup CUDA_TEXOBJECT Texture Object Management + * + * ___MANBRIEF___ texture object management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the texture object management functions of the + * low-level CUDA driver application programming interface. The texture + * object API is only supported on devices of compute capability 3.0 or higher. + * + * @{ + */ + +/** + * \brief Creates a texture object + * + * Creates a texture object and returns it in \p pTexObject. \p pResDesc describes + * the data to texture from. \p pTexDesc describes how the data should be sampled. + * \p pResViewDesc is an optional argument that specifies an alternate format for + * the data described by \p pResDesc, and also describes the subresource region + * to restrict access to when texturing. \p pResViewDesc can only be specified if + * the type of resource is a CUDA array or a CUDA mipmapped array not in a block + * compressed format. + * + * Texture objects are only supported on devices of compute capability 3.0 or higher. + * Additionally, a texture object is an opaque value, and, as such, should only be + * accessed through CUDA API calls. + * + * The ::CUDA_RESOURCE_DESC structure is defined as: + * \code + typedef struct CUDA_RESOURCE_DESC_st + { + CUresourcetype resType; + + union { + struct { + CUarray hArray; + } array; + struct { + CUmipmappedArray hMipmappedArray; + } mipmap; + struct { + CUdeviceptr devPtr; + CUarray_format format; + unsigned int numChannels; + size_t sizeInBytes; + } linear; + struct { + CUdeviceptr devPtr; + CUarray_format format; + unsigned int numChannels; + size_t width; + size_t height; + size_t pitchInBytes; + } pitch2D; + } res; + + unsigned int flags; + } CUDA_RESOURCE_DESC; + + * \endcode + * where: + * - ::CUDA_RESOURCE_DESC::resType specifies the type of resource to texture from. + * CUresourceType is defined as: + * \code + typedef enum CUresourcetype_enum { + CU_RESOURCE_TYPE_ARRAY = 0x00, + CU_RESOURCE_TYPE_MIPMAPPED_ARRAY = 0x01, + CU_RESOURCE_TYPE_LINEAR = 0x02, + CU_RESOURCE_TYPE_PITCH2D = 0x03 + } CUresourcetype; + * \endcode + * + * \par + * If ::CUDA_RESOURCE_DESC::resType is set to ::CU_RESOURCE_TYPE_ARRAY, ::CUDA_RESOURCE_DESC::res::array::hArray + * must be set to a valid CUDA array handle. + * + * \par + * If ::CUDA_RESOURCE_DESC::resType is set to ::CU_RESOURCE_TYPE_MIPMAPPED_ARRAY, ::CUDA_RESOURCE_DESC::res::mipmap::hMipmappedArray + * must be set to a valid CUDA mipmapped array handle. + * + * \par + * If ::CUDA_RESOURCE_DESC::resType is set to ::CU_RESOURCE_TYPE_LINEAR, ::CUDA_RESOURCE_DESC::res::linear::devPtr + * must be set to a valid device pointer, that is aligned to ::CU_DEVICE_ATTRIBUTE_TEXTURE_ALIGNMENT. + * ::CUDA_RESOURCE_DESC::res::linear::format and ::CUDA_RESOURCE_DESC::res::linear::numChannels + * describe the format of each component and the number of components per array element. ::CUDA_RESOURCE_DESC::res::linear::sizeInBytes + * specifies the size of the array in bytes. The total number of elements in the linear address range cannot exceed + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE1D_LINEAR_WIDTH. The number of elements is computed as (sizeInBytes / (sizeof(format) * numChannels)). + * + * \par + * If ::CUDA_RESOURCE_DESC::resType is set to ::CU_RESOURCE_TYPE_PITCH2D, ::CUDA_RESOURCE_DESC::res::pitch2D::devPtr + * must be set to a valid device pointer, that is aligned to ::CU_DEVICE_ATTRIBUTE_TEXTURE_ALIGNMENT. + * ::CUDA_RESOURCE_DESC::res::pitch2D::format and ::CUDA_RESOURCE_DESC::res::pitch2D::numChannels + * describe the format of each component and the number of components per array element. ::CUDA_RESOURCE_DESC::res::pitch2D::width + * and ::CUDA_RESOURCE_DESC::res::pitch2D::height specify the width and height of the array in elements, and cannot exceed + * ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_WIDTH and ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_HEIGHT respectively. + * ::CUDA_RESOURCE_DESC::res::pitch2D::pitchInBytes specifies the pitch between two rows in bytes and has to be aligned to + * ::CU_DEVICE_ATTRIBUTE_TEXTURE_PITCH_ALIGNMENT. Pitch cannot exceed ::CU_DEVICE_ATTRIBUTE_MAXIMUM_TEXTURE2D_LINEAR_PITCH. + * + * - ::flags must be set to zero. + * + * + * The ::CUDA_TEXTURE_DESC struct is defined as + * \code + typedef struct CUDA_TEXTURE_DESC_st { + CUaddress_mode addressMode[3]; + CUfilter_mode filterMode; + unsigned int flags; + unsigned int maxAnisotropy; + CUfilter_mode mipmapFilterMode; + float mipmapLevelBias; + float minMipmapLevelClamp; + float maxMipmapLevelClamp; + } CUDA_TEXTURE_DESC; + * \endcode + * where + * - ::CUDA_TEXTURE_DESC::addressMode specifies the addressing mode for each dimension of the texture data. ::CUaddress_mode is defined as: + * \code + typedef enum CUaddress_mode_enum { + CU_TR_ADDRESS_MODE_WRAP = 0, + CU_TR_ADDRESS_MODE_CLAMP = 1, + CU_TR_ADDRESS_MODE_MIRROR = 2, + CU_TR_ADDRESS_MODE_BORDER = 3 + } CUaddress_mode; + * \endcode + * This is ignored if ::CUDA_RESOURCE_DESC::resType is ::CU_RESOURCE_TYPE_LINEAR. Also, if the flag, ::CU_TRSF_NORMALIZED_COORDINATES + * is not set, the only supported address mode is ::CU_TR_ADDRESS_MODE_CLAMP. + * + * - ::CUDA_TEXTURE_DESC::filterMode specifies the filtering mode to be used when fetching from the texture. CUfilter_mode is defined as: + * \code + typedef enum CUfilter_mode_enum { + CU_TR_FILTER_MODE_POINT = 0, + CU_TR_FILTER_MODE_LINEAR = 1 + } CUfilter_mode; + * \endcode + * This is ignored if ::CUDA_RESOURCE_DESC::resType is ::CU_RESOURCE_TYPE_LINEAR. + * + * - ::CUDA_TEXTURE_DESC::flags can be any combination of the following: + * - ::CU_TRSF_READ_AS_INTEGER, which suppresses the default behavior of + * having the texture promote integer data to floating point data in the + * range [0, 1]. Note that texture with 32-bit integer format would not be + * promoted, regardless of whether or not this flag is specified. + * - ::CU_TRSF_NORMALIZED_COORDINATES, which suppresses the default behavior + * of having the texture coordinates range from [0, Dim) where Dim is the + * width or height of the CUDA array. Instead, the texture coordinates + * [0, 1.0) reference the entire breadth of the array dimension; Note that + * for CUDA mipmapped arrays, this flag has to be set. + * - ::CU_TRSF_DISABLE_TRILINEAR_OPTIMIZATION, which disables any trilinear + * filtering optimizations. Trilinear optimizations improve texture filtering + * performance by allowing bilinear filtering on textures in scenarios where + * it can closely approximate the expected results. + * - ::CU_TRSF_SEAMLESS_CUBEMAP, which enables seamless cube map filtering. + * This flag can only be specified if the underlying resource is a CUDA array + * or a CUDA mipmapped array that was created with the flag ::CUDA_ARRAY3D_CUBEMAP. + * When seamless cube map filtering is enabled, texture address modes specified + * by ::CUDA_TEXTURE_DESC::addressMode are ignored. Instead, if the ::CUDA_TEXTURE_DESC::filterMode + * is set to ::CU_TR_FILTER_MODE_POINT the address mode ::CU_TR_ADDRESS_MODE_CLAMP + * will be applied for all dimensions. If the ::CUDA_TEXTURE_DESC::filterMode is + * set to ::CU_TR_FILTER_MODE_LINEAR seamless cube map filtering will be performed + * when sampling along the cube face borders. + * + * - ::CUDA_TEXTURE_DESC::maxAnisotropy specifies the maximum anisotropy ratio to be used when doing anisotropic filtering. This value will be + * clamped to the range [1,16]. + * + * - ::CUDA_TEXTURE_DESC::mipmapFilterMode specifies the filter mode when the calculated mipmap level lies between two defined mipmap levels. + * + * - ::CUDA_TEXTURE_DESC::mipmapLevelBias specifies the offset to be applied to the calculated mipmap level. + * + * - ::CUDA_TEXTURE_DESC::minMipmapLevelClamp specifies the lower end of the mipmap level range to clamp access to. + * + * - ::CUDA_TEXTURE_DESC::maxMipmapLevelClamp specifies the upper end of the mipmap level range to clamp access to. + * + * + * The ::CUDA_RESOURCE_VIEW_DESC struct is defined as + * \code + typedef struct CUDA_RESOURCE_VIEW_DESC_st + { + CUresourceViewFormat format; + size_t width; + size_t height; + size_t depth; + unsigned int firstMipmapLevel; + unsigned int lastMipmapLevel; + unsigned int firstLayer; + unsigned int lastLayer; + } CUDA_RESOURCE_VIEW_DESC; + * \endcode + * where: + * - ::CUDA_RESOURCE_VIEW_DESC::format specifies how the data contained in the CUDA array or CUDA mipmapped array should + * be interpreted. Note that this can incur a change in size of the texture data. If the resource view format is a block + * compressed format, then the underlying CUDA array or CUDA mipmapped array has to have a base of format ::CU_AD_FORMAT_UNSIGNED_INT32. + * with 2 or 4 channels, depending on the block compressed format. For ex., BC1 and BC4 require the underlying CUDA array to have + * a format of ::CU_AD_FORMAT_UNSIGNED_INT32 with 2 channels. The other BC formats require the underlying resource to have the same base + * format but with 4 channels. + * + * - ::CUDA_RESOURCE_VIEW_DESC::width specifies the new width of the texture data. If the resource view format is a block + * compressed format, this value has to be 4 times the original width of the resource. For non block compressed formats, + * this value has to be equal to that of the original resource. + * + * - ::CUDA_RESOURCE_VIEW_DESC::height specifies the new height of the texture data. If the resource view format is a block + * compressed format, this value has to be 4 times the original height of the resource. For non block compressed formats, + * this value has to be equal to that of the original resource. + * + * - ::CUDA_RESOURCE_VIEW_DESC::depth specifies the new depth of the texture data. This value has to be equal to that of the + * original resource. + * + * - ::CUDA_RESOURCE_VIEW_DESC::firstMipmapLevel specifies the most detailed mipmap level. This will be the new mipmap level zero. + * For non-mipmapped resources, this value has to be zero.::CUDA_TEXTURE_DESC::minMipmapLevelClamp and ::CUDA_TEXTURE_DESC::maxMipmapLevelClamp + * will be relative to this value. For ex., if the firstMipmapLevel is set to 2, and a minMipmapLevelClamp of 1.2 is specified, + * then the actual minimum mipmap level clamp will be 3.2. + * + * - ::CUDA_RESOURCE_VIEW_DESC::lastMipmapLevel specifies the least detailed mipmap level. For non-mipmapped resources, this value + * has to be zero. + * + * - ::CUDA_RESOURCE_VIEW_DESC::firstLayer specifies the first layer index for layered textures. This will be the new layer zero. + * For non-layered resources, this value has to be zero. + * + * - ::CUDA_RESOURCE_VIEW_DESC::lastLayer specifies the last layer index for layered textures. For non-layered resources, + * this value has to be zero. + * + * + * \param pTexObject - Texture object to create + * \param pResDesc - Resource descriptor + * \param pTexDesc - Texture descriptor + * \param pResViewDesc - Resource view descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexObjectDestroy, + * ::cudaCreateTextureObject + */ +CUresult CUDAAPI cuTexObjectCreate(CUtexObject *pTexObject, const CUDA_RESOURCE_DESC *pResDesc, const CUDA_TEXTURE_DESC *pTexDesc, const CUDA_RESOURCE_VIEW_DESC *pResViewDesc); + +/** + * \brief Destroys a texture object + * + * Destroys the texture object specified by \p texObject. + * + * \param texObject - Texture object to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexObjectCreate, + * ::cudaDestroyTextureObject + */ +CUresult CUDAAPI cuTexObjectDestroy(CUtexObject texObject); + +/** + * \brief Returns a texture object's resource descriptor + * + * Returns the resource descriptor for the texture object specified by \p texObject. + * + * \param pResDesc - Resource descriptor + * \param texObject - Texture object + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexObjectCreate, + * ::cudaGetTextureObjectResourceDesc, + */ +CUresult CUDAAPI cuTexObjectGetResourceDesc(CUDA_RESOURCE_DESC *pResDesc, CUtexObject texObject); + +/** + * \brief Returns a texture object's texture descriptor + * + * Returns the texture descriptor for the texture object specified by \p texObject. + * + * \param pTexDesc - Texture descriptor + * \param texObject - Texture object + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexObjectCreate, + * ::cudaGetTextureObjectTextureDesc + */ +CUresult CUDAAPI cuTexObjectGetTextureDesc(CUDA_TEXTURE_DESC *pTexDesc, CUtexObject texObject); + +/** + * \brief Returns a texture object's resource view descriptor + * + * Returns the resource view descriptor for the texture object specified by \p texObject. + * If no resource view was set for \p texObject, the ::CUDA_ERROR_INVALID_VALUE is returned. + * + * \param pResViewDesc - Resource view descriptor + * \param texObject - Texture object + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTexObjectCreate, + * ::cudaGetTextureObjectResourceViewDesc + */ +CUresult CUDAAPI cuTexObjectGetResourceViewDesc(CUDA_RESOURCE_VIEW_DESC *pResViewDesc, CUtexObject texObject); + +/** @} */ /* END CUDA_TEXOBJECT */ + +/** + * \defgroup CUDA_SURFOBJECT Surface Object Management + * + * ___MANBRIEF___ surface object management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the surface object management functions of the + * low-level CUDA driver application programming interface. The surface + * object API is only supported on devices of compute capability 3.0 or higher. + * + * @{ + */ + +/** + * \brief Creates a surface object + * + * Creates a surface object and returns it in \p pSurfObject. \p pResDesc describes + * the data to perform surface load/stores on. ::CUDA_RESOURCE_DESC::resType must be + * ::CU_RESOURCE_TYPE_ARRAY and ::CUDA_RESOURCE_DESC::res::array::hArray + * must be set to a valid CUDA array handle. ::CUDA_RESOURCE_DESC::flags must be set to zero. + * + * Surface objects are only supported on devices of compute capability 3.0 or higher. + * Additionally, a surface object is an opaque value, and, as such, should only be + * accessed through CUDA API calls. + * + * \param pSurfObject - Surface object to create + * \param pResDesc - Resource descriptor + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuSurfObjectDestroy, + * ::cudaCreateSurfaceObject + */ +CUresult CUDAAPI cuSurfObjectCreate(CUsurfObject *pSurfObject, const CUDA_RESOURCE_DESC *pResDesc); + +/** + * \brief Destroys a surface object + * + * Destroys the surface object specified by \p surfObject. + * + * \param surfObject - Surface object to destroy + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuSurfObjectCreate, + * ::cudaDestroySurfaceObject + */ +CUresult CUDAAPI cuSurfObjectDestroy(CUsurfObject surfObject); + +/** + * \brief Returns a surface object's resource descriptor + * + * Returns the resource descriptor for the surface object specified by \p surfObject. + * + * \param pResDesc - Resource descriptor + * \param surfObject - Surface object + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuSurfObjectCreate, + * ::cudaGetSurfaceObjectResourceDesc + */ +CUresult CUDAAPI cuSurfObjectGetResourceDesc(CUDA_RESOURCE_DESC *pResDesc, CUsurfObject surfObject); + +/** @} */ /* END CUDA_SURFOBJECT */ + +/** + * \defgroup CUDA_TENSOR_MEMORY Tensor Map Object Managment + * + * ___MANBRIEF___ tensor map object management functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the tensor map object management functions of the + * low-level CUDA driver application programming interface. The tensor + * core API is only supported on devices of compute capability 9.0 or higher. + * + * @{ + */ + +/** + * \brief Create a tensor map descriptor object representing tiled memory region + * + * Creates a descriptor for Tensor Memory Access (TMA) object specified + * by the parameters describing a tiled region and returns it in \p tensorMap. + * + * Tensor map objects are only supported on devices of compute capability 9.0 or higher. + * Additionally, a tensor map object is an opaque value, and, as such, should only be + * accessed through CUDA API calls. + * + * The parameters passed are bound to the following requirements: + * + * - \p tensorMap address must be aligned to 64 bytes. + * + * - \p tensorDataType has to be an enum from ::CUtensorMapDataType which is defined as: + * \code + typedef enum CUtensorMapDataType_enum { + CU_TENSOR_MAP_DATA_TYPE_UINT8 = 0, // 1 byte + CU_TENSOR_MAP_DATA_TYPE_UINT16, // 2 bytes + CU_TENSOR_MAP_DATA_TYPE_UINT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_INT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_UINT64, // 8 bytes + CU_TENSOR_MAP_DATA_TYPE_INT64, // 8 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT16, // 2 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT64, // 8 bytes + CU_TENSOR_MAP_DATA_TYPE_BFLOAT16, // 2 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT32_FTZ, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_TFLOAT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_TFLOAT32_FTZ // 4 bytes + } CUtensorMapDataType; + * \endcode + * + * - \p tensorRank must be non-zero and less than or equal to the maximum supported dimensionality of 5. If \p interleave is not + * ::CU_TENSOR_MAP_INTERLEAVE_NONE, then \p tensorRank must additionally be greater than or equal to 3. + * + * - \p globalAddress, which specifies the starting address of the memory region described, must be 32 byte aligned when \p interleave is + * ::CU_TENSOR_MAP_INTERLEAVE_32B and 16 byte aligned otherwise. + * + * - \p globalDim array, which specifies tensor size of each of the \p tensorRank dimensions, must be non-zero and less than or + * equal to 2^32. + * + * - \p globalStrides array, which specifies tensor stride of each of the lower \p tensorRank - 1 dimensions in bytes, must be a + * multiple of 16 and less than 2^40. Additionally, the stride must be a multiple of 32 when \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_32B. + * Each following dimension specified includes previous dimension stride: + * \code + globalStrides[0] = globalDim[0] * elementSizeInBytes(tensorDataType) + padding[0]; + for (i = 1; i < tensorRank - 1; i++) + globalStrides[i] = globalStrides[i – 1] * (globalDim[i] + padding[i]); + assert(globalStrides[i] >= globalDim[i]); + * \endcode + * + * - \p boxDim array, which specifies number of elements to be traversed along each of the \p tensorRank dimensions, must be non-zero + * and less than or equal to 256. + * When \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_NONE, { \p boxDim[0] * elementSizeInBytes( \p tensorDataType ) } must be a multiple + * of 16 bytes. + * + * - \p elementStrides array, which specifies the iteration step along each of the \p tensorRank dimensions, must be non-zero and less + * than or equal to 8. Note that when \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_NONE, the first element of this array is ignored since + * TMA doesn’t support the stride for dimension zero. + * When all elements of \p elementStrides array is one, \p boxDim specifies the number of elements to load. However, if the \p elementStrides[i] + * is not equal to one, then TMA loads ceil( \p boxDim[i] / \p elementStrides[i]) number of elements along i-th dimension. To load N elements along + * i-th dimension, \p boxDim[i] must be set to N * \p elementStrides[i]. + * + * - \p interleave specifies the interleaved layout of type ::CUtensorMapInterleave, which is defined as: + * \code + typedef enum CUtensorMapInterleave_enum { + CU_TENSOR_MAP_INTERLEAVE_NONE = 0, + CU_TENSOR_MAP_INTERLEAVE_16B, + CU_TENSOR_MAP_INTERLEAVE_32B + } CUtensorMapInterleave; + * \endcode + * TMA supports interleaved layouts like NC/8HWC8 where C8 utilizes 16 bytes in memory assuming 2 byte per channel or NC/16HWC16 where C16 + * uses 32 bytes. + * When \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_NONE and \p swizzle is not ::CU_TENSOR_MAP_SWIZZLE_NONE, the bounding box inner dimension + * (computed as \p boxDim[0] multiplied by element size derived from \p tensorDataType) must be less than or equal to the swizzle size. + * - CU_TENSOR_MAP_SWIZZLE_32B implies the bounding box inner dimension will be <= 32. + * - CU_TENSOR_MAP_SWIZZLE_64B implies the bounding box inner dimension will be <= 64. + * - CU_TENSOR_MAP_SWIZZLE_128B implies the bounding box inner dimension will be <= 128. + * + * - \p swizzle, which specifies the shared memory bank swizzling pattern, has to be of type ::CUtensorMapSwizzle which is defined as: + * \code + typedef enum CUtensorMapSwizzle_enum { + CU_TENSOR_MAP_SWIZZLE_NONE = 0, + CU_TENSOR_MAP_SWIZZLE_32B, + CU_TENSOR_MAP_SWIZZLE_64B, + CU_TENSOR_MAP_SWIZZLE_128B + } CUtensorMapSwizzle; + * \endcode + * Data are organized in a specific order in global memory; however, this may not match the order in which the application accesses data + * in shared memory. This difference in data organization may cause bank conflicts when shared memory is accessed. In order to avoid this + * problem, data can be loaded to shared memory with shuffling across shared memory banks. + * When \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_32B, \p swizzle must be ::CU_TENSOR_MAP_SWIZZLE_32B. + * Other interleave modes can have any swizzling pattern. + * + * - \p l2Promotion specifies L2 fetch size which indicates the byte granurality at which L2 requests is filled from DRAM. It must be of + * type ::CUtensorMapL2promotion, which is defined as: + * \code + typedef enum CUtensorMapL2promotion_enum { + CU_TENSOR_MAP_L2_PROMOTION_NONE = 0, + CU_TENSOR_MAP_L2_PROMOTION_L2_64B, + CU_TENSOR_MAP_L2_PROMOTION_L2_128B, + CU_TENSOR_MAP_L2_PROMOTION_L2_256B + } CUtensorMapL2promotion; + * \endcode + * + * - \p oobFill, which indicates whether zero or a special NaN constant should be used to fill out-of-bound elements, must be of type + * ::CUtensorMapFloatOOBfill which is defined as: + * \code + typedef enum CUtensorMapFloatOOBfill_enum { + CU_TENSOR_MAP_FLOAT_OOB_FILL_NONE = 0, + CU_TENSOR_MAP_FLOAT_OOB_FILL_NAN_REQUEST_ZERO_FMA + } CUtensorMapFloatOOBfill; + * \endcode + * Note that ::CU_TENSOR_MAP_FLOAT_OOB_FILL_NAN_REQUEST_ZERO_FMA can only be used when \p tensorDataType represents a floating-point data type. + * + * \param tensorMap - Tensor map object to create + * \param tensorDataType - Tensor data type + * \param tensorRank - Dimensionality of tensor + * \param globalAddress - Starting address of memory region described by tensor + * \param globalDim - Array containing tensor size (number of elements) along each of the \p tensorRank dimensions + * \param globalStrides - Array containing stride size (in bytes) along each of the \p tensorRank - 1 dimensions + * \param boxDim - Array containing traversal box size (number of elments) along each of the \p tensorRank dimensions. Specifies how many elements to be traversed along each tensor dimension. + * \param elementStrides - Array containing traversal stride in each of the \p tensorRank dimensions + * \param interleave - Type of interleaved layout the tensor addresses + * \param swizzle - Bank swizzling pattern inside shared memory + * \param l2Promotion - L2 promotion size + * \param oobFill - Indicate whether zero or special NaN constant must be used to fill out-of-bound elements + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTensorMapEncodeIm2col, + * ::cuTensorMapReplaceAddress + */ +CUresult CUDAAPI cuTensorMapEncodeTiled(CUtensorMap *tensorMap, CUtensorMapDataType tensorDataType, cuuint32_t tensorRank, void *globalAddress, const cuuint64_t *globalDim, const cuuint64_t *globalStrides, const cuuint32_t *boxDim, const cuuint32_t *elementStrides, CUtensorMapInterleave interleave, CUtensorMapSwizzle swizzle, CUtensorMapL2promotion l2Promotion, CUtensorMapFloatOOBfill oobFill); + + +/** + * \brief Create a tensor map descriptor object representing im2col memory region + * + * Creates a descriptor for Tensor Memory Access (TMA) object specified + * by the parameters describing a im2col memory layout and returns it in \p tensorMap. + * + * Tensor map objects are only supported on devices of compute capability 9.0 or higher. + * Additionally, a tensor map object is an opaque value, and, as such, should only be + * accessed through CUDA API calls. + * + * The parameters passed are bound to the following requirements: + * + * - \p tensorMap address must be aligned to 64 bytes. + * + * - \p tensorDataType has to be an enum from ::CUtensorMapDataType which is defined as: + * \code + typedef enum CUtensorMapDataType_enum { + CU_TENSOR_MAP_DATA_TYPE_UINT8 = 0, // 1 byte + CU_TENSOR_MAP_DATA_TYPE_UINT16, // 2 bytes + CU_TENSOR_MAP_DATA_TYPE_UINT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_INT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_UINT64, // 8 bytes + CU_TENSOR_MAP_DATA_TYPE_INT64, // 8 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT16, // 2 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT64, // 8 bytes + CU_TENSOR_MAP_DATA_TYPE_BFLOAT16, // 2 bytes + CU_TENSOR_MAP_DATA_TYPE_FLOAT32_FTZ, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_TFLOAT32, // 4 bytes + CU_TENSOR_MAP_DATA_TYPE_TFLOAT32_FTZ // 4 bytes + } CUtensorMapDataType; + * \endcode + * + * - \p tensorRank, which specifies the number of tensor dimensions, must be 3, 4, or 5. + * + * - \p globalAddress, which specifies the starting address of the memory region described, must be 32 byte aligned when \p interleave is + * ::CU_TENSOR_MAP_INTERLEAVE_32B and 16 byte aligned otherwise. + * + * - \p globalDim array, which specifies tensor size of each of the \p tensorRank dimensions, must be non-zero and less than or + * equal to 2^32. + * + * - \p globalStrides array, which specifies tensor stride of each of the lower \p tensorRank - 1 dimensions in bytes, must be a + * multiple of 16 and less than 2^40. Additionally, the stride must be a multiple of 32 when \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_32B. + * Each following dimension specified includes previous dimension stride: + * \code + globalStrides[0] = globalDim[0] * elementSizeInBytes(tensorDataType) + padding[0]; + for (i = 1; i < tensorRank - 1; i++) + globalStrides[i] = globalStrides[i – 1] * (globalDim[i] + padding[i]); + assert(globalStrides[i] >= globalDim[i]); + * \endcode + * + * - \p pixelBoxLowerCorner array specifies the coordinate offsets {D, H, W} of the bounding box from top/left/front corner. The number of + * offsets and their precision depend on the tensor dimensionality: + * - When \p tensorRank is 3, one signed offset within range [-32768, 32767] is supported. + * - When \p tensorRank is 4, two signed offsets each within range [-128, 127] are supported. + * - When \p tensorRank is 5, three offsets each within range [-16, 15] are supported. + * + * - \p pixelBoxUpperCorner array specifies the coordinate offsets {D, H, W} of the bounding box from bottom/right/back corner. The number of + * offsets and their precision depend on the tensor dimensionality: + * - When \p tensorRank is 3, one signed offset within range [-32768, 32767] is supported. + * - When \p tensorRank is 4, two signed offsets each within range [-128, 127] are supported. + * - When \p tensorRank is 5, three offsets each within range [-16, 15] are supported. + * The bounding box specified by \p pixelBoxLowerCorner and \p pixelBoxUpperCorner must have non-zero area. + * + * - \p channelsPerPixel, which specifies the number of elements which must be accessed along C dimension, must be less than or equal to 256. + * + * - \p pixelsPerColumn, which specifies the number of elements that must be accessed along the {N, D, H, W} dimensions, must be less than or + * equal to 1024. + * + * - \p elementStrides array, which specifies the iteration step along each of the \p tensorRank dimensions, must be non-zero and less + * than or equal to 8. Note that when \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_NONE, the first element of this array is ignored since + * TMA doesn’t support the stride for dimension zero. + * When all elements of the \p elementStrides array are one, \p boxDim specifies the number of elements to load. However, if \p elementStrides[i] + * is not equal to one for some \p i, then TMA loads ceil( \p boxDim[i] / \p elementStrides[i]) number of elements along i-th dimension. + * To load N elements along i-th dimension, \p boxDim[i] must be set to N * \p elementStrides[i]. + * + * - \p interleave specifies the interleaved layout of type ::CUtensorMapInterleave, which is defined as: + * \code + typedef enum CUtensorMapInterleave_enum { + CU_TENSOR_MAP_INTERLEAVE_NONE = 0, + CU_TENSOR_MAP_INTERLEAVE_16B, + CU_TENSOR_MAP_INTERLEAVE_32B + } CUtensorMapInterleave; + * \endcode + * TMA supports interleaved layouts like NC/8HWC8 where C8 utilizes 16 bytes in memory assuming 2 byte per channel or NC/16HWC16 where C16 + * uses 32 bytes. + * When \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_NONE and \p swizzle is not ::CU_TENSOR_MAP_SWIZZLE_NONE, the bounding box inner dimension + * (computed as \p boxDim[0] multiplied by element size derived from \p tensorDataType) must be less than or equal to the swizzle size. + * - CU_TENSOR_MAP_SWIZZLE_32B implies the bounding box inner dimension will be <= 32. + * - CU_TENSOR_MAP_SWIZZLE_64B implies the bounding box inner dimension will be <= 64. + * - CU_TENSOR_MAP_SWIZZLE_128B implies the bounding box inner dimension will be <= 128. + * + * - \p swizzle, which specifies the shared memory bank swizzling pattern, has to be of type ::CUtensorMapSwizzle which is defined as: + * \code + typedef enum CUtensorMapSwizzle_enum { + CU_TENSOR_MAP_SWIZZLE_NONE = 0, + CU_TENSOR_MAP_SWIZZLE_32B, + CU_TENSOR_MAP_SWIZZLE_64B, + CU_TENSOR_MAP_SWIZZLE_128B + } CUtensorMapSwizzle; + * \endcode + * Data are organized in a specific order in global memory; however, this may not match the order in which the application accesses data + * in shared memory. This difference in data organization may cause bank conflicts when shared memory is accessed. In order to avoid this + * problem, data can be loaded to shared memory with shuffling across shared memory banks. + * When \p interleave is ::CU_TENSOR_MAP_INTERLEAVE_32B, \p swizzle must be ::CU_TENSOR_MAP_SWIZZLE_32B. + * Other interleave modes can have any swizzling pattern. + * + * - \p l2Promotion specifies L2 fetch size which indicates the byte granularity at which L2 requests are filled from DRAM. It must be of + * type ::CUtensorMapL2promotion, which is defined as: + * \code + typedef enum CUtensorMapL2promotion_enum { + CU_TENSOR_MAP_L2_PROMOTION_NONE = 0, + CU_TENSOR_MAP_L2_PROMOTION_L2_64B, + CU_TENSOR_MAP_L2_PROMOTION_L2_128B, + CU_TENSOR_MAP_L2_PROMOTION_L2_256B + } CUtensorMapL2promotion; + * \endcode + * + * - \p oobFill, which indicates whether zero or a special NaN constant should be used to fill out-of-bound elements, must be of type + * ::CUtensorMapFloatOOBfill which is defined as: + * \code + typedef enum CUtensorMapFloatOOBfill_enum { + CU_TENSOR_MAP_FLOAT_OOB_FILL_NONE = 0, + CU_TENSOR_MAP_FLOAT_OOB_FILL_NAN_REQUEST_ZERO_FMA + } CUtensorMapFloatOOBfill; + * \endcode + * Note that ::CU_TENSOR_MAP_FLOAT_OOB_FILL_NAN_REQUEST_ZERO_FMA can only be used when \p tensorDataType represents a floating-point data type. + * + * \param tensorMap - Tensor map object to create + * \param tensorDataType - Tensor data type + * \param tensorRank - Dimensionality of tensor; must be at least 3 + * \param globalAddress - Starting address of memory region described by tensor + * \param globalDim - Array containing tensor size (number of elements) along each of the \p tensorRank dimensions + * \param globalStrides - Array containing stride size (in bytes) along each of the \p tensorRank - 1 dimensions + * \param pixelBoxLowerCorner - Array containing DHW dimensions of lower box corner + * \param pixelBoxUpperCorner - Array containing DHW dimensions of upper box corner + * \param channelsPerPixel - Number of channels per pixel + * \param pixelsPerColumn - Number of pixels per column + * \param elementStrides - Array containing traversal stride in each of the \p tensorRank dimensions + * \param interleave - Type of interleaved layout the tensor addresses + * \param swizzle - Bank swizzling pattern inside shared memory + * \param l2Promotion - L2 promotion size + * \param oobFill - Indicate whether zero or special NaN constant will be used to fill out-of-bound elements + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTensorMapEncodeTiled, + * ::cuTensorMapReplaceAddress + */ +CUresult CUDAAPI cuTensorMapEncodeIm2col(CUtensorMap *tensorMap, CUtensorMapDataType tensorDataType, cuuint32_t tensorRank, void *globalAddress, const cuuint64_t *globalDim, const cuuint64_t *globalStrides, const int *pixelBoxLowerCorner, const int *pixelBoxUpperCorner, cuuint32_t channelsPerPixel, cuuint32_t pixelsPerColumn, const cuuint32_t *elementStrides, CUtensorMapInterleave interleave, CUtensorMapSwizzle swizzle, CUtensorMapL2promotion l2Promotion, CUtensorMapFloatOOBfill oobFill); + +/** + * \brief Modify an existing tensor map descriptor with an updated global address + * + * Modifies the descriptor for Tensor Memory Access (TMA) object passed in \p tensorMap with + * an updated \p globalAddress. + * + * Tensor map objects are only supported on devices of compute capability 9.0 or higher. + * Additionally, a tensor map object is an opaque value, and, as such, should only be + * accessed through CUDA API calls. + * + * \param tensorMap - Tensor map object to modify + * \param globalAddress - Starting address of memory region described by tensor, must follow previous alignment requirements + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuTensorMapEncodeTiled, + * ::cuTensorMapEncodeIm2col + */ +CUresult CUDAAPI cuTensorMapReplaceAddress(CUtensorMap *tensorMap, void *globalAddress); + +/** @} */ +/* END CUDA_TENSOR_MEMORY */ + +/** + * \defgroup CUDA_PEER_ACCESS Peer Context Memory Access + * + * ___MANBRIEF___ direct peer context memory access functions of the low-level + * CUDA driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the direct peer context memory access functions + * of the low-level CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Queries if a device may directly access a peer device's memory. + * + * Returns in \p *canAccessPeer a value of 1 if contexts on \p dev are capable of + * directly accessing memory from contexts on \p peerDev and 0 otherwise. + * If direct access of \p peerDev from \p dev is possible, then access may be + * enabled on two specific contexts by calling ::cuCtxEnablePeerAccess(). + * + * \param canAccessPeer - Returned access capability + * \param dev - Device from which allocations on \p peerDev are to + * be directly accessed. + * \param peerDev - Device on which the allocations to be directly accessed + * by \p dev reside. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE + * \notefnerr + * + * \sa + * ::cuCtxEnablePeerAccess, + * ::cuCtxDisablePeerAccess, + * ::cudaDeviceCanAccessPeer + */ +CUresult CUDAAPI cuDeviceCanAccessPeer(int *canAccessPeer, CUdevice dev, CUdevice peerDev); + +/** + * \brief Enables direct access to memory allocations in a peer context. + * + * If both the current context and \p peerContext are on devices which support unified + * addressing (as may be queried using ::CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING) and same + * major compute capability, then on success all allocations from \p peerContext will + * immediately be accessible by the current context. See \ref CUDA_UNIFIED for additional + * details. + * + * Note that access granted by this call is unidirectional and that in order to access + * memory from the current context in \p peerContext, a separate symmetric call + * to ::cuCtxEnablePeerAccess() is required. + * + * Note that there are both device-wide and system-wide limitations per system + * configuration, as noted in the CUDA Programming Guide under the section + * "Peer-to-Peer Memory Access". + * + * Returns ::CUDA_ERROR_PEER_ACCESS_UNSUPPORTED if ::cuDeviceCanAccessPeer() indicates + * that the ::CUdevice of the current context cannot directly access memory + * from the ::CUdevice of \p peerContext. + * + * Returns ::CUDA_ERROR_PEER_ACCESS_ALREADY_ENABLED if direct access of + * \p peerContext from the current context has already been enabled. + * + * Returns ::CUDA_ERROR_TOO_MANY_PEERS if direct peer access is not possible + * because hardware resources required for peer access have been exhausted. + * + * Returns ::CUDA_ERROR_INVALID_CONTEXT if there is no current context, \p peerContext + * is not a valid context, or if the current context is \p peerContext. + * + * Returns ::CUDA_ERROR_INVALID_VALUE if \p Flags is not 0. + * + * \param peerContext - Peer context to enable direct access to from the current context + * \param Flags - Reserved for future use and must be set to 0 + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_PEER_ACCESS_ALREADY_ENABLED, + * ::CUDA_ERROR_TOO_MANY_PEERS, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_PEER_ACCESS_UNSUPPORTED, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuDeviceCanAccessPeer, + * ::cuCtxDisablePeerAccess, + * ::cudaDeviceEnablePeerAccess + */ +CUresult CUDAAPI cuCtxEnablePeerAccess(CUcontext peerContext, unsigned int Flags); + +/** + * \brief Disables direct access to memory allocations in a peer context and + * unregisters any registered allocations. + * + Returns ::CUDA_ERROR_PEER_ACCESS_NOT_ENABLED if direct peer access has + * not yet been enabled from \p peerContext to the current context. + * + * Returns ::CUDA_ERROR_INVALID_CONTEXT if there is no current context, or if + * \p peerContext is not a valid context. + * + * \param peerContext - Peer context to disable direct access to + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_PEER_ACCESS_NOT_ENABLED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * \notefnerr + * + * \sa + * ::cuDeviceCanAccessPeer, + * ::cuCtxEnablePeerAccess, + * ::cudaDeviceDisablePeerAccess + */ +CUresult CUDAAPI cuCtxDisablePeerAccess(CUcontext peerContext); + +/** + * \brief Queries attributes of the link between two devices. + * + * Returns in \p *value the value of the requested attribute \p attrib of the + * link between \p srcDevice and \p dstDevice. The supported attributes are: + * - ::CU_DEVICE_P2P_ATTRIBUTE_PERFORMANCE_RANK: A relative value indicating the + * performance of the link between two devices. + * - ::CU_DEVICE_P2P_ATTRIBUTE_ACCESS_SUPPORTED P2P: 1 if P2P Access is enable. + * - ::CU_DEVICE_P2P_ATTRIBUTE_NATIVE_ATOMIC_SUPPORTED: 1 if Atomic operations over + * the link are supported. + * - ::CU_DEVICE_P2P_ATTRIBUTE_CUDA_ARRAY_ACCESS_SUPPORTED: 1 if cudaArray can + * be accessed over the link. + * + * Returns ::CUDA_ERROR_INVALID_DEVICE if \p srcDevice or \p dstDevice are not valid + * or if they represent the same device. + * + * Returns ::CUDA_ERROR_INVALID_VALUE if \p attrib is not valid or if \p value is + * a null pointer. + * + * \param value - Returned value of the requested attribute + * \param attrib - The requested attribute of the link between \p srcDevice and \p dstDevice. + * \param srcDevice - The source device of the target link. + * \param dstDevice - The destination device of the target link. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE + * \notefnerr + * + * \sa + * ::cuCtxEnablePeerAccess, + * ::cuCtxDisablePeerAccess, + * ::cuDeviceCanAccessPeer, + * ::cudaDeviceGetP2PAttribute + */ +CUresult CUDAAPI cuDeviceGetP2PAttribute(int* value, CUdevice_P2PAttribute attrib, CUdevice srcDevice, CUdevice dstDevice); + +/** @} */ /* END CUDA_PEER_ACCESS */ + +/** + * \defgroup CUDA_GRAPHICS Graphics Interoperability + * + * ___MANBRIEF___ graphics interoperability functions of the low-level CUDA + * driver API (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the graphics interoperability functions of the + * low-level CUDA driver application programming interface. + * + * @{ + */ + +/** + * \brief Unregisters a graphics resource for access by CUDA + * + * Unregisters the graphics resource \p resource so it is not accessible by + * CUDA unless registered again. + * + * If \p resource is invalid then ::CUDA_ERROR_INVALID_HANDLE is + * returned. + * + * \param resource - Resource to unregister + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_UNKNOWN + * \notefnerr + * + * \sa + * ::cuGraphicsD3D9RegisterResource, + * ::cuGraphicsD3D10RegisterResource, + * ::cuGraphicsD3D11RegisterResource, + * ::cuGraphicsGLRegisterBuffer, + * ::cuGraphicsGLRegisterImage, + * ::cudaGraphicsUnregisterResource + */ +CUresult CUDAAPI cuGraphicsUnregisterResource(CUgraphicsResource resource); + +/** + * \brief Get an array through which to access a subresource of a mapped graphics resource. + * + * Returns in \p *pArray an array through which the subresource of the mapped + * graphics resource \p resource which corresponds to array index \p arrayIndex + * and mipmap level \p mipLevel may be accessed. The value set in \p *pArray may + * change every time that \p resource is mapped. + * + * If \p resource is not a texture then it cannot be accessed via an array and + * ::CUDA_ERROR_NOT_MAPPED_AS_ARRAY is returned. + * If \p arrayIndex is not a valid array index for \p resource then + * ::CUDA_ERROR_INVALID_VALUE is returned. + * If \p mipLevel is not a valid mipmap level for \p resource then + * ::CUDA_ERROR_INVALID_VALUE is returned. + * If \p resource is not mapped then ::CUDA_ERROR_NOT_MAPPED is returned. + * + * \param pArray - Returned array through which a subresource of \p resource may be accessed + * \param resource - Mapped resource to access + * \param arrayIndex - Array index for array textures or cubemap face + * index as defined by ::CUarray_cubemap_face for + * cubemap textures for the subresource to access + * \param mipLevel - Mipmap level for the subresource to access + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_MAPPED, + * ::CUDA_ERROR_NOT_MAPPED_AS_ARRAY + * \notefnerr + * + * \sa + * ::cuGraphicsResourceGetMappedPointer, + * ::cudaGraphicsSubResourceGetMappedArray + */ +CUresult CUDAAPI cuGraphicsSubResourceGetMappedArray(CUarray *pArray, CUgraphicsResource resource, unsigned int arrayIndex, unsigned int mipLevel); + +/** + * \brief Get a mipmapped array through which to access a mapped graphics resource. + * + * Returns in \p *pMipmappedArray a mipmapped array through which the mapped graphics + * resource \p resource. The value set in \p *pMipmappedArray may change every time + * that \p resource is mapped. + * + * If \p resource is not a texture then it cannot be accessed via a mipmapped array and + * ::CUDA_ERROR_NOT_MAPPED_AS_ARRAY is returned. + * If \p resource is not mapped then ::CUDA_ERROR_NOT_MAPPED is returned. + * + * \param pMipmappedArray - Returned mipmapped array through which \p resource may be accessed + * \param resource - Mapped resource to access + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_MAPPED, + * ::CUDA_ERROR_NOT_MAPPED_AS_ARRAY + * \notefnerr + * + * \sa + * ::cuGraphicsResourceGetMappedPointer, + * ::cudaGraphicsResourceGetMappedMipmappedArray + */ +CUresult CUDAAPI cuGraphicsResourceGetMappedMipmappedArray(CUmipmappedArray *pMipmappedArray, CUgraphicsResource resource); + +/** + * \brief Get a device pointer through which to access a mapped graphics resource. + * + * Returns in \p *pDevPtr a pointer through which the mapped graphics resource + * \p resource may be accessed. + * Returns in \p pSize the size of the memory in bytes which may be accessed from that pointer. + * The value set in \p pPointer may change every time that \p resource is mapped. + * + * If \p resource is not a buffer then it cannot be accessed via a pointer and + * ::CUDA_ERROR_NOT_MAPPED_AS_POINTER is returned. + * If \p resource is not mapped then ::CUDA_ERROR_NOT_MAPPED is returned. + * * + * \param pDevPtr - Returned pointer through which \p resource may be accessed + * \param pSize - Returned size of the buffer accessible starting at \p *pPointer + * \param resource - Mapped resource to access + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_MAPPED, + * ::CUDA_ERROR_NOT_MAPPED_AS_POINTER + * \notefnerr + * + * \sa + * ::cuGraphicsMapResources, + * ::cuGraphicsSubResourceGetMappedArray, + * ::cudaGraphicsResourceGetMappedPointer + */ +CUresult CUDAAPI cuGraphicsResourceGetMappedPointer(CUdeviceptr *pDevPtr, size_t *pSize, CUgraphicsResource resource); + +/** + * \brief Set usage flags for mapping a graphics resource + * + * Set \p flags for mapping the graphics resource \p resource. + * + * Changes to \p flags will take effect the next time \p resource is mapped. + * The \p flags argument may be any of the following: + + * - ::CU_GRAPHICS_MAP_RESOURCE_FLAGS_NONE: Specifies no hints about how this + * resource will be used. It is therefore assumed that this resource will be + * read from and written to by CUDA kernels. This is the default value. + * - ::CU_GRAPHICS_MAP_RESOURCE_FLAGS_READONLY: Specifies that CUDA kernels which + * access this resource will not write to this resource. + * - ::CU_GRAPHICS_MAP_RESOURCE_FLAGS_WRITEDISCARD: Specifies that CUDA kernels + * which access this resource will not read from this resource and will + * write over the entire contents of the resource, so none of the data + * previously stored in the resource will be preserved. + * + * If \p resource is presently mapped for access by CUDA then + * ::CUDA_ERROR_ALREADY_MAPPED is returned. + * If \p flags is not one of the above values then ::CUDA_ERROR_INVALID_VALUE is returned. + * + * \param resource - Registered resource to set flags for + * \param flags - Parameters for resource mapping + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_ALREADY_MAPPED + * \notefnerr + * + * \sa + * ::cuGraphicsMapResources, + * ::cudaGraphicsResourceSetMapFlags + */ +CUresult CUDAAPI cuGraphicsResourceSetMapFlags(CUgraphicsResource resource, unsigned int flags); + +/** + * \brief Map graphics resources for access by CUDA + * + * Maps the \p count graphics resources in \p resources for access by CUDA. + * + * The resources in \p resources may be accessed by CUDA until they + * are unmapped. The graphics API from which \p resources were registered + * should not access any resources while they are mapped by CUDA. If an + * application does so, the results are undefined. + * + * This function provides the synchronization guarantee that any graphics calls + * issued before ::cuGraphicsMapResources() will complete before any subsequent CUDA + * work issued in \p stream begins. + * + * If \p resources includes any duplicate entries then ::CUDA_ERROR_INVALID_HANDLE is returned. + * If any of \p resources are presently mapped for access by CUDA then ::CUDA_ERROR_ALREADY_MAPPED is returned. + * + * \param count - Number of resources to map + * \param resources - Resources to map for CUDA usage + * \param hStream - Stream with which to synchronize + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_ALREADY_MAPPED, + * ::CUDA_ERROR_UNKNOWN + * \note_null_stream + * \notefnerr + * + * \sa + * ::cuGraphicsResourceGetMappedPointer, + * ::cuGraphicsSubResourceGetMappedArray, + * ::cuGraphicsUnmapResources, + * ::cudaGraphicsMapResources + */ +CUresult CUDAAPI cuGraphicsMapResources(unsigned int count, CUgraphicsResource *resources, CUstream hStream); + +/** + * \brief Unmap graphics resources. + * + * Unmaps the \p count graphics resources in \p resources. + * + * Once unmapped, the resources in \p resources may not be accessed by CUDA + * until they are mapped again. + * + * This function provides the synchronization guarantee that any CUDA work issued + * in \p stream before ::cuGraphicsUnmapResources() will complete before any + * subsequently issued graphics work begins. + * + * + * If \p resources includes any duplicate entries then ::CUDA_ERROR_INVALID_HANDLE is returned. + * If any of \p resources are not presently mapped for access by CUDA then ::CUDA_ERROR_NOT_MAPPED is returned. + * + * \param count - Number of resources to unmap + * \param resources - Resources to unmap + * \param hStream - Stream with which to synchronize + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_NOT_MAPPED, + * ::CUDA_ERROR_UNKNOWN + * \note_null_stream + * \notefnerr + * + * \sa + * ::cuGraphicsMapResources, + * ::cudaGraphicsUnmapResources + */ +CUresult CUDAAPI cuGraphicsUnmapResources(unsigned int count, CUgraphicsResource *resources, CUstream hStream); + +/** @} */ /* END CUDA_GRAPHICS */ + +/** + * \defgroup CUDA_DRIVER_ENTRY_POINT Driver Entry Point Access + * + * ___MANBRIEF___ driver entry point access functions of the low-level CUDA driver API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the driver entry point access functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * \brief Returns the requested driver API function pointer + * + * Returns in \p **pfn the address of the CUDA driver function for the requested + * CUDA version and flags. + * + * The CUDA version is specified as (1000 * major + 10 * minor), so CUDA 11.2 + * should be specified as 11020. For a requested driver symbol, if the specified + * CUDA version is greater than or equal to the CUDA version in which the driver symbol + * was introduced, this API will return the function pointer to the corresponding + * versioned function. + * + * The pointer returned by the API should be cast to a function pointer matching the + * requested driver function's definition in the API header file. The function pointer + * typedef can be picked up from the corresponding typedefs header file. For example, + * cudaTypedefs.h consists of function pointer typedefs for driver APIs defined in cuda.h. + * + * The API will return ::CUDA_SUCCESS and set the returned \p pfn to NULL if the + * requested driver function is not supported on the platform, no ABI + * compatible driver function exists for the specified \p cudaVersion or if the + * driver symbol is invalid. + * + * It will also set the optional \p symbolStatus to one of the values in + * ::CUdriverProcAddressQueryResult with the following meanings: + * - ::CU_GET_PROC_ADDRESS_SUCCESS - The requested symbol was succesfully found based + * on input arguments and \p pfn is valid + * - ::CU_GET_PROC_ADDRESS_SYMBOL_NOT_FOUND - The requested symbol was not found + * - ::CU_GET_PROC_ADDRESS_VERSION_NOT_SUFFICIENT - The requested symbol was found but is + * not supported by cudaVersion specified + * + * The requested flags can be: + * - ::CU_GET_PROC_ADDRESS_DEFAULT: This is the default mode. This is equivalent to + * ::CU_GET_PROC_ADDRESS_PER_THREAD_DEFAULT_STREAM if the code is compiled with + * --default-stream per-thread compilation flag or the macro CUDA_API_PER_THREAD_DEFAULT_STREAM + * is defined; ::CU_GET_PROC_ADDRESS_LEGACY_STREAM otherwise. + * - ::CU_GET_PROC_ADDRESS_LEGACY_STREAM: This will enable the search for all driver symbols + * that match the requested driver symbol name except the corresponding per-thread versions. + * - ::CU_GET_PROC_ADDRESS_PER_THREAD_DEFAULT_STREAM: This will enable the search for all + * driver symbols that match the requested driver symbol name including the per-thread + * versions. If a per-thread version is not found, the API will return the legacy version + * of the driver function. + * + * \param symbol - The base name of the driver API function to look for. As an example, + * for the driver API ::cuMemAlloc_v2, \p symbol would be cuMemAlloc and + * \p cudaVersion would be the ABI compatible CUDA version for the _v2 variant. + * \param pfn - Location to return the function pointer to the requested driver function + * \param cudaVersion - The CUDA version to look for the requested driver symbol + * \param flags - Flags to specify search options. + * \param symbolStatus - Optional location to store the status of the search for + * \p symbol based on \p cudaVersion. See ::CUdriverProcAddressQueryResult + * for possible values. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED + * \note_version_mixing + * + * \sa + * ::cudaGetDriverEntryPoint + */ +CUresult CUDAAPI cuGetProcAddress(const char *symbol, void **pfn, int cudaVersion, cuuint64_t flags, CUdriverProcAddressQueryResult *symbolStatus); + +/** @} */ /* END CUDA_DRIVER_ENTRY_POINT */ + +/** + * \defgroup CUDA_COREDUMP Coredump Attributes Control API + * + * ___MANBRIEF___ coredump attribute control functions for the low-level CUDA API + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the coredump attribute control functions of the low-level CUDA + * driver application programming interface. + * + * @{ + */ + +/** + * Flags for choosing a coredump attribute to get/set + */ +typedef enum CUcoredumpSettings_enum { + CU_COREDUMP_ENABLE_ON_EXCEPTION = 1, + CU_COREDUMP_TRIGGER_HOST, + CU_COREDUMP_LIGHTWEIGHT, + CU_COREDUMP_ENABLE_USER_TRIGGER, + CU_COREDUMP_FILE, + CU_COREDUMP_PIPE, + CU_COREDUMP_GENERATION_FLAGS, + CU_COREDUMP_MAX +} CUcoredumpSettings; + +/** + * Flags for controlling coredump contents + */ +typedef enum CUCoredumpGenerationFlags { + CU_COREDUMP_DEFAULT_FLAGS = 0, + CU_COREDUMP_SKIP_NONRELOCATED_ELF_IMAGES = (1 << 0), + CU_COREDUMP_SKIP_GLOBAL_MEMORY = (1 << 1), + CU_COREDUMP_SKIP_SHARED_MEMORY = (1 << 2), + CU_COREDUMP_SKIP_LOCAL_MEMORY = (1 << 3), + CU_COREDUMP_SKIP_ABORT = (1 << 4), + CU_COREDUMP_SKIP_CONSTBANK_MEMORY = (1 << 5), + + CU_COREDUMP_LIGHTWEIGHT_FLAGS = CU_COREDUMP_SKIP_NONRELOCATED_ELF_IMAGES + | CU_COREDUMP_SKIP_GLOBAL_MEMORY + | CU_COREDUMP_SKIP_SHARED_MEMORY + | CU_COREDUMP_SKIP_LOCAL_MEMORY + | CU_COREDUMP_SKIP_CONSTBANK_MEMORY +} CUCoredumpGenerationFlags; + +/** + * \brief Allows caller to fetch a coredump attribute value for the current context + * + * Returns in \p *value the requested value specified by \p attrib. It is up to the caller + * to ensure that the data type and size of \p *value matches the request. + * + * If the caller calls this function with \p *value equal to NULL, the size of the memory + * region (in bytes) expected for \p attrib will be placed in \p size. + * + * The supported attributes are: + * - ::CU_COREDUMP_ENABLE_ON_EXCEPTION: Bool where ::true means that GPU exceptions from + * this context will create a coredump at the location specified by ::CU_COREDUMP_FILE. + * The default value is ::false unless set to ::true globally or locally, or the + * CU_CTX_USER_COREDUMP_ENABLE flag was set during context creation. + * - ::CU_COREDUMP_TRIGGER_HOST: Bool where ::true means that the host CPU will + * also create a coredump. The default value is ::true unless set to ::false globally or + * or locally. This value is deprecated as of CUDA 12.5 - raise the ::CU_COREDUMP_SKIP_ABORT + * flag to disable host device abort() if needed. + * - ::CU_COREDUMP_LIGHTWEIGHT: Bool where ::true means that any resulting coredumps + * will not have a dump of GPU memory or non-reloc ELF images. The default value is + * ::false unless set to ::true globally or locally. This attribute is deprecated as + * of CUDA 12.5, please use ::CU_COREDUMP_GENERATION_FLAGS instead. + * - ::CU_COREDUMP_ENABLE_USER_TRIGGER: Bool where ::true means that a coredump can be + * created by writing to the system pipe specified by ::CU_COREDUMP_PIPE. The default + * value is ::false unless set to ::true globally or locally. + * - ::CU_COREDUMP_FILE: String of up to 1023 characters that defines the location where + * any coredumps generated by this context will be written. The default value is + * ::core.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine running + * the CUDA applications and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_PIPE: String of up to 1023 characters that defines the name of the pipe + * that will be monitored if user-triggered coredumps are enabled. The default value is + * ::corepipe.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine running + * the CUDA application and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_GENERATION_FLAGS: An integer with values to allow granular control the data + * contained in a coredump specified as a bitwise OR combination of the following values: + * + ::CU_COREDUMP_DEFAULT_FLAGS - if set by itself, coredump generation returns to its + * default settings of including all memory regions that it is able to access + * + ::CU_COREDUMP_SKIP_NONRELOCATED_ELF_IMAGES - Coredump will not include the data from + * CUDA source modules that are not relocated at runtime. + * + ::CU_COREDUMP_SKIP_GLOBAL_MEMORY - Coredump will not include device-side global data + * that does not belong to any context. + * + ::CU_COREDUMP_SKIP_SHARED_MEMORY - Coredump will not include grid-scale shared memory + * for the warp that the dumped kernel belonged to. + * + ::CU_COREDUMP_SKIP_LOCAL_MEMORY - Coredump will not include local memory from the kernel. + * + ::CU_COREDUMP_LIGHTWEIGHT_FLAGS - Enables all of the above options. Equiavlent to setting + * the ::CU_COREDUMP_LIGHTWEIGHT attribute to ::true. + * + ::CU_COREDUMP_SKIP_ABORT - If set, GPU exceptions will not raise an abort() in the host CPU + * process. Same functional goal as ::CU_COREDUMP_TRIGGER_HOST but better reflects the default + * behavior. + * + * \param attrib - The enum defining which value to fetch. + * \param value - void* containing the requested data. + * \param size - The size of the memory region \p value points to. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * + * \sa + * ::cuCoredumpGetAttributeGlobal, + * ::cuCoredumpSetAttribute, + * ::cuCoredumpSetAttributeGlobal + */ +CUresult CUDAAPI cuCoredumpGetAttribute(CUcoredumpSettings attrib, void* value, size_t *size); + +/** + * \brief Allows caller to fetch a coredump attribute value for the entire application + * + * Returns in \p *value the requested value specified by \p attrib. It is up to the caller + * to ensure that the data type and size of \p *value matches the request. + * + * If the caller calls this function with \p *value equal to NULL, the size of the memory + * region (in bytes) expected for \p attrib will be placed in \p size. + * + * The supported attributes are: + * - ::CU_COREDUMP_ENABLE_ON_EXCEPTION: Bool where ::true means that GPU exceptions from + * this context will create a coredump at the location specified by ::CU_COREDUMP_FILE. + * The default value is ::false. + * - ::CU_COREDUMP_TRIGGER_HOST: Bool where ::true means that the host CPU will + * also create a coredump. The default value is ::true unless set to ::false globally or + * or locally. This value is deprecated as of CUDA 12.5 - raise the ::CU_COREDUMP_SKIP_ABORT + * flag to disable host device abort() if needed. + * - ::CU_COREDUMP_LIGHTWEIGHT: Bool where ::true means that any resulting coredumps + * will not have a dump of GPU memory or non-reloc ELF images. The default value is + * ::false. This attribute is deprecated as of CUDA 12.5, please use ::CU_COREDUMP_GENERATION_FLAGS + * instead. + * - ::CU_COREDUMP_ENABLE_USER_TRIGGER: Bool where ::true means that a coredump can be + * created by writing to the system pipe specified by ::CU_COREDUMP_PIPE. The default + * value is ::false. + * - ::CU_COREDUMP_FILE: String of up to 1023 characters that defines the location where + * any coredumps generated by this context will be written. The default value is + * ::core.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine running + * the CUDA applications and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_PIPE: String of up to 1023 characters that defines the name of the pipe + * that will be monitored if user-triggered coredumps are enabled. The default value is + * ::corepipe.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine running + * the CUDA application and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_GENERATION_FLAGS: An integer with values to allow granular control the data + * contained in a coredump specified as a bitwise OR combination of the following values: + * + ::CU_COREDUMP_DEFAULT_FLAGS - if set by itself, coredump generation returns to its + * default settings of including all memory regions that it is able to access + * + ::CU_COREDUMP_SKIP_NONRELOCATED_ELF_IMAGES - Coredump will not include the data from + * CUDA source modules that are not relocated at runtime. + * + ::CU_COREDUMP_SKIP_GLOBAL_MEMORY - Coredump will not include device-side global data + * that does not belong to any context. + * + ::CU_COREDUMP_SKIP_SHARED_MEMORY - Coredump will not include grid-scale shared memory + * for the warp that the dumped kernel belonged to. + * + ::CU_COREDUMP_SKIP_LOCAL_MEMORY - Coredump will not include local memory from the kernel. + * + ::CU_COREDUMP_LIGHTWEIGHT_FLAGS - Enables all of the above options. Equiavlent to setting + * the ::CU_COREDUMP_LIGHTWEIGHT attribute to ::true. + * + ::CU_COREDUMP_SKIP_ABORT - If set, GPU exceptions will not raise an abort() in the host CPU + * process. Same functional goal as ::CU_COREDUMP_TRIGGER_HOST but better reflects the default + * behavior. + * + * \param attrib - The enum defining which value to fetch. + * \param value - void* containing the requested data. + * \param size - The size of the memory region \p value points to. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuCoredumpGetAttribute, + * ::cuCoredumpSetAttribute, + * ::cuCoredumpSetAttributeGlobal + */ +CUresult CUDAAPI cuCoredumpGetAttributeGlobal(CUcoredumpSettings attrib, void *value, size_t *size); + +/** + * \brief Allows caller to set a coredump attribute value for the current context + * + * This function should be considered an alternate interface to the CUDA-GDB environment + * variables defined in this document: https://docs.nvidia.com/cuda/cuda-gdb/index.html#gpu-coredump + * + * An important design decision to note is that any coredump environment variable values + * set before CUDA initializes will take permanent precedence over any values set with this + * function. This decision was made to ensure no change in behavior for any users that + * may be currently using these variables to get coredumps. + * + * \p *value shall contain the requested value specified by \p set. It is up to the caller + * to ensure that the data type and size of \p *value matches the request. + * + * If the caller calls this function with \p *value equal to NULL, the size of the memory + * region (in bytes) expected for \p set will be placed in \p size. + * + * /note This function will return ::CUDA_ERROR_NOT_SUPPORTED if the caller attempts to set + * ::CU_COREDUMP_ENABLE_ON_EXCEPTION on a GPU of with Compute Capability < 6.0. ::cuCoredumpSetAttributeGlobal + * works on those platforms as an alternative. + * + * /note ::CU_COREDUMP_ENABLE_USER_TRIGGER and ::CU_COREDUMP_PIPE cannot be set on a per-context basis. + * + * The supported attributes are: + * - ::CU_COREDUMP_ENABLE_ON_EXCEPTION: Bool where ::true means that GPU exceptions from + * this context will create a coredump at the location specified by ::CU_COREDUMP_FILE. + * The default value is ::false. + * - ::CU_COREDUMP_TRIGGER_HOST: Bool where ::true means that the host CPU will + * also create a coredump. The default value is ::true unless set to ::false globally or + * or locally. This value is deprecated as of CUDA 12.5 - raise the ::CU_COREDUMP_SKIP_ABORT + * flag to disable host device abort() if needed. + * - ::CU_COREDUMP_LIGHTWEIGHT: Bool where ::true means that any resulting coredumps + * will not have a dump of GPU memory or non-reloc ELF images. The default value is + * ::false. This attribute is deprecated as of CUDA 12.5, please use ::CU_COREDUMP_GENERATION_FLAGS + * instead. + * - ::CU_COREDUMP_FILE: String of up to 1023 characters that defines the location where + * any coredumps generated by this context will be written. The default value is + * ::core.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine running + * the CUDA applications and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_GENERATION_FLAGS: An integer with values to allow granular control the data + * contained in a coredump specified as a bitwise OR combination of the following values: + * + ::CU_COREDUMP_DEFAULT_FLAGS - if set by itself, coredump generation returns to its + * default settings of including all memory regions that it is able to access + * + ::CU_COREDUMP_SKIP_NONRELOCATED_ELF_IMAGES - Coredump will not include the data from + * CUDA source modules that are not relocated at runtime. + * + ::CU_COREDUMP_SKIP_GLOBAL_MEMORY - Coredump will not include device-side global data + * that does not belong to any context. + * + ::CU_COREDUMP_SKIP_SHARED_MEMORY - Coredump will not include grid-scale shared memory + * for the warp that the dumped kernel belonged to. + * + ::CU_COREDUMP_SKIP_LOCAL_MEMORY - Coredump will not include local memory from the kernel. + * + ::CU_COREDUMP_LIGHTWEIGHT_FLAGS - Enables all of the above options. Equiavlent to setting + * the ::CU_COREDUMP_LIGHTWEIGHT attribute to ::true. + * + ::CU_COREDUMP_SKIP_ABORT - If set, GPU exceptions will not raise an abort() in the host CPU + * process. Same functional goal as ::CU_COREDUMP_TRIGGER_HOST but better reflects the default + * behavior. + * + * \param attrib - The enum defining which value to set. + * \param value - void* containing the requested data. + * \param size - The size of the memory region \p value points to. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_PERMITTED, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED, + * ::CUDA_ERROR_NOT_SUPPORTED + * + * \sa + * ::cuCoredumpGetAttributeGlobal, + * ::cuCoredumpGetAttribute, + * ::cuCoredumpSetAttributeGlobal + */ +CUresult CUDAAPI cuCoredumpSetAttribute(CUcoredumpSettings attrib, void* value, size_t *size); + +/** + * \brief Allows caller to set a coredump attribute value globally + * + * This function should be considered an alternate interface to the CUDA-GDB environment + * variables defined in this document: https://docs.nvidia.com/cuda/cuda-gdb/index.html#gpu-coredump + * + * An important design decision to note is that any coredump environment variable values + * set before CUDA initializes will take permanent precedence over any values set with this + * function. This decision was made to ensure no change in behavior for any users that + * may be currently using these variables to get coredumps. + * + * \p *value shall contain the requested value specified by \p set. It is up to the caller + * to ensure that the data type and size of \p *value matches the request. + * + * If the caller calls this function with \p *value equal to NULL, the size of the memory + * region (in bytes) expected for \p set will be placed in \p size. + * + * The supported attributes are: + * - ::CU_COREDUMP_ENABLE_ON_EXCEPTION: Bool where ::true means that GPU exceptions from + * this context will create a coredump at the location specified by ::CU_COREDUMP_FILE. + * The default value is ::false. + * - ::CU_COREDUMP_TRIGGER_HOST: Bool where ::true means that the host CPU will + * also create a coredump. The default value is ::true unless set to ::false globally or + * or locally. This value is deprecated as of CUDA 12.5 - raise the ::CU_COREDUMP_SKIP_ABORT + * flag to disable host device abort() if needed. + * - ::CU_COREDUMP_LIGHTWEIGHT: Bool where ::true means that any resulting coredumps + * will not have a dump of GPU memory or non-reloc ELF images. The default value is + * ::false. This attribute is deprecated as of CUDA 12.5, please use ::CU_COREDUMP_GENERATION_FLAGS + * instead. + * - ::CU_COREDUMP_ENABLE_USER_TRIGGER: Bool where ::true means that a coredump can be + * created by writing to the system pipe specified by ::CU_COREDUMP_PIPE. The default + * value is ::false. + * - ::CU_COREDUMP_FILE: String of up to 1023 characters that defines the location where + * any coredumps generated by this context will be written. The default value is + * ::core.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine running + * the CUDA applications and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_PIPE: String of up to 1023 characters that defines the name of the pipe + * that will be monitored if user-triggered coredumps are enabled. This value may not be + * changed after ::CU_COREDUMP_ENABLE_USER_TRIGGER is set to ::true. The default + * value is ::corepipe.cuda.HOSTNAME.PID where ::HOSTNAME is the host name of the machine + * running the CUDA application and ::PID is the process ID of the CUDA application. + * - ::CU_COREDUMP_GENERATION_FLAGS: An integer with values to allow granular control the data + * contained in a coredump specified as a bitwise OR combination of the following values: + * + ::CU_COREDUMP_DEFAULT_FLAGS - if set by itself, coredump generation returns to its + * default settings of including all memory regions that it is able to access + * + ::CU_COREDUMP_SKIP_NONRELOCATED_ELF_IMAGES - Coredump will not include the data from + * CUDA source modules that are not relocated at runtime. + * + ::CU_COREDUMP_SKIP_GLOBAL_MEMORY - Coredump will not include device-side global data + * that does not belong to any context. + * + ::CU_COREDUMP_SKIP_SHARED_MEMORY - Coredump will not include grid-scale shared memory + * for the warp that the dumped kernel belonged to. + * + ::CU_COREDUMP_SKIP_LOCAL_MEMORY - Coredump will not include local memory from the kernel. + * + ::CU_COREDUMP_LIGHTWEIGHT_FLAGS - Enables all of the above options. Equiavlent to setting + * the ::CU_COREDUMP_LIGHTWEIGHT attribute to ::true. + * + ::CU_COREDUMP_SKIP_ABORT - If set, GPU exceptions will not raise an abort() in the host CPU + * process. Same functional goal as ::CU_COREDUMP_TRIGGER_HOST but better reflects the default + * behavior. + * + * \param attrib - The enum defining which value to set. + * \param value - void* containing the requested data. + * \param size - The size of the memory region \p value points to. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_PERMITTED + * + * \sa + * ::cuCoredumpGetAttribute, + * ::cuCoredumpGetAttributeGlobal, + * ::cuCoredumpSetAttribute + */ +CUresult CUDAAPI cuCoredumpSetAttributeGlobal(CUcoredumpSettings attrib, void *value, size_t *size); + +/** @} */ /* END CUDA_COREDUMP */ + +CUresult CUDAAPI cuGetExportTable(const void **ppExportTable, const CUuuid *pExportTableId); + +/* +** ******************* GREEN CONTEXTS ********************** +*/ + +/** + * \defgroup CUDA_GREEN_CONTEXTS Green Contexts + * + * ___MANBRIEF___ Driver level API for creation and manipulation of green contexts + * (___CURRENT_FILE___) ___ENDMANBRIEF___ + * + * This section describes the APIs for creation and manipulation of green contexts in the CUDA + * driver. Green contexts are a lightweight alternative to traditional contexts, with the ability + * to pass in a set of resources that they should be initialized with. This allows the developer to + * represent distinct spatial partitions of the GPU, provision resources for them, and target them + * via the same programming model that CUDA exposes (streams, kernel launches, etc.). + * + * There are 4 main steps to using these new set of APIs. + * - (1) Start with an initial set of resources, for example via ::cuDeviceGetDevResource. Only SM type is supported today. + * - (2) Partition this set of resources by providing them as input to a partition API, for example: ::cuDevSmResourceSplitByCount. + * - (3) Finalize the specification of resources by creating a descriptor via ::cuDevResourceGenerateDesc. + * - (4) Provision the resources and create a green context via ::cuGreenCtxCreate. + * + * For \p CU_DEV_RESOURCE_TYPE_SM, the partitions created have minimum SM count requirements, often rounding up and aligning the + * minCount provided to ::cuDevSmResourceSplitByCount. The following is a guideline for each architecture + * and may be subject to change: + * - On Compute Architecture 6.X: The minimum count is 1 SM. + * - On Compute Architecture 7.X: The minimum count is 2 SMs and must be a multiple of 2. + * - On Compute Architecture 8.X: The minimum count is 4 SMs and must be a multiple of 2. + * - On Compute Architecture 9.0+: The minimum count is 8 SMs and must be a multiple of 8. + * + * In the future, flags can be provided to tradeoff functional and performance characteristics versus finer grained SM partitions. + * + * Even if the green contexts have disjoint SM partitions, it is not guaranteed that the kernels launched + * in them will run concurrently or have forward progress guarantees. This is due to other resources (like HW connections, + * see ::CUDA_DEVICE_MAX_CONNECTIONS) that could cause a dependency. Additionally, in certain scenarios, + * it is possible for the workload to run on more SMs than was provisioned (but never less). + * The following are two scenarios which can exhibit this behavior: + * - On Volta+ MPS: When \p CUDA_MPS_ACTIVE_THREAD_PERCENTAGE is used, + * the set of SMs that are used for running kernels can be scaled up to the value of SMs used for the MPS client. + * - On Compute Architecture 9.x: When a module with dynamic parallelism (CDP) is loaded, all future + * kernels running under green contexts may use and share an additional set of 2 SMs. + * + * @{ + */ + +/*! + * \typedef struct CUdevResourceDesc_st* CUdevResourceDesc; + * An opaque descriptor handle. The descriptor encapsulates multiple created and configured resources. + * Created via ::cuDevResourceGenerateDesc + */ +typedef struct CUdevResourceDesc_st *CUdevResourceDesc; + +typedef enum { + CU_GREEN_CTX_DEFAULT_STREAM = 0x1, /**< Required. Creates a default stream to use inside the green context */ +} CUgreenCtxCreate_flags; + +typedef enum { + CU_DEV_SM_RESOURCE_SPLIT_IGNORE_SM_COSCHEDULING = 0x1, + CU_DEV_SM_RESOURCE_SPLIT_MAX_POTENTIAL_CLUSTER_SIZE = 0x2, +} CUdevSmResourceSplit_flags; + +#define RESOURCE_ABI_VERSION 1 +#define RESOURCE_ABI_EXTERNAL_BYTES 48 + +#define _CONCAT_INNER(x, y) x ## y +#define _CONCAT_OUTER(x, y) _CONCAT_INNER(x, y) + +/*! + * \typedef enum CUdevResourceType + * Type of resource + */ +typedef enum { + CU_DEV_RESOURCE_TYPE_INVALID = 0, + CU_DEV_RESOURCE_TYPE_SM = 1, /**< Streaming multiprocessors related information */ +#if defined(__CUDA_API_VERSION_INTERNAL) && !defined(__CUDA_API_VERSION_INTERNAL_ODR) + CU_DEV_RESOURCE_TYPE_MAX, +#endif +} CUdevResourceType; + +/*! + * \struct CUdevSmResource + * Data for SM-related resources + */ +typedef struct CUdevSmResource_st { + unsigned int smCount; /**< The amount of streaming multiprocessors available in this resource. This is an output parameter only, do not write to this field. */ +} CUdevSmResource; + +/*! + * \struct CUdevResource + * A tagged union describing different resources identified by the type field. This structure should not be directly modified outside of the API that created it. + * \code + * struct { + * CUdevResourceType type; + * union { + * CUdevSmResource sm; + * }; + * }; + * \endcode + * - If \p type is \p CU_DEV_RESOURCE_TYPE_INVALID, this resoure is not valid and cannot be further accessed. + * - If \p type is \p CU_DEV_RESOURCE_TYPE_SM, the ::CUdevSmResource structure \p sm is filled in. For example, + * \p sm.smCount will reflect the amount of streaming multiprocessors available in this resource. + */ +typedef struct CUdevResource_st { + CUdevResourceType type; /**< Type of resource, dictates which union field was last set */ + unsigned char _internal_padding[92]; + union { + CUdevSmResource sm; /**< Resource corresponding to CU_DEV_RESOURCE_TYPE_SM \p. type. */ + unsigned char _oversize[RESOURCE_ABI_EXTERNAL_BYTES]; + }; +} _CONCAT_OUTER(CUdevResource_v, RESOURCE_ABI_VERSION); +typedef _CONCAT_OUTER(CUdevResource_v, RESOURCE_ABI_VERSION) CUdevResource; + +#undef _CONCAT_INNER +#undef _CONCAT_OUTER + +#undef ABI_PER_RESOURCE_EXTERNAL_BYTES +#undef ABI_RESOURCE_VERSION + +/** + * \brief Creates a green context with a specified set of resources. + * + * This API creates a green context with the resources specified in the descriptor \p desc and + * returns it in the handle represented by \p phCtx. This API will retain the primary context on device \p dev, + * which will is released when the green context is destroyed. It is advised to have the primary context active + * before calling this API to avoid the heavy cost of triggering primary context initialization and + * deinitialization multiple times. + * + * The API does not set the green context current. In order to set it current, you need to explicitly set it current + * by first converting the green context to a CUcontext using ::cuCtxFromGreenCtx and subsequently calling + * ::cuCtxSetCurrent / ::cuCtxPushCurrent. It should be noted that a green context can be current to only one + * thread at a time. There is no internal synchronization to make API calls accessing the same green context + * from multiple threads work. + * + * Note: The API is not supported on 32-bit platforms. + * + * \param phCtx - Pointer for the output handle to the green context + * \param desc - Descriptor generated via ::cuDevResourceGenerateDesc which contains the set of resources to be used + * \param dev - Device on which to create the green context. + * \param flags - One of the supported green context creation flags. \p CU_GREEN_CTX_DEFAULT_STREAM is required. + * + * The supported flags are: + * - \p CU_GREEN_CTX_DEFAULT_STREAM : Creates a default stream to use inside the green context. Required. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_NOT_SUPPORTED, + * ::CUDA_ERROR_OUT_OF_MEMORY + * + * \sa + * ::cuGreenCtxDestroy, + * ::cuCtxFromGreenCtx, + * ::cuCtxSetCurrent, + * ::cuCtxPushCurrent, + * ::cuDevResourceGenerateDesc, + * ::cuDevicePrimaryCtxRetain, + * ::cuCtxCreate, + * ::cuCtxCreate_v3 + */ +CUresult CUDAAPI cuGreenCtxCreate(CUgreenCtx* phCtx, CUdevResourceDesc desc, CUdevice dev, unsigned int flags); + +/** + * \brief Destroys a green context + * + * Destroys the green context, releasing the primary context of the device that this green context was created for. + * Any resources provisioned for this green context (that were initially available via the resource descriptor) + * are released as well. + * \param hCtx - Green context to be destroyed + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_CONTEXT_IS_DESTROYED + * + * \sa + * ::cuGreenCtxCreate, + * ::cuCtxDestroy + */ +CUresult CUDAAPI cuGreenCtxDestroy(CUgreenCtx hCtx); + +/** + * \brief Converts a green context into the primary context + * + * The API converts a green context into the primary context returned in \p pContext. It is important + * to note that the converted context \p pContext is a normal primary context but with + * the resources of the specified green context \p hCtx. Once converted, it can then + * be used to set the context current with ::cuCtxSetCurrent or with any of the CUDA APIs + * that accept a CUcontext parameter. + * + * Users are expected to call this API before calling any CUDA APIs that accept a + * CUcontext. Failing to do so will result in the APIs returning ::CUDA_ERROR_INVALID_CONTEXT. + * + * \param pContext Returned primary context with green context resources + * \param hCtx Green context to convert + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuGreenCtxCreate + */ +CUresult CUDAAPI cuCtxFromGreenCtx(CUcontext *pContext, CUgreenCtx hCtx); + +/** + * \brief Get device resources + * + * Get the \p type resources available to the \p device. + * This may often be the starting point for further partitioning or configuring of resources. + * + * Note: The API is not supported on 32-bit platforms. + * + * \param device - Device to get resource for + * \param resource - Output pointer to a CUdevResource structure + * \param type - Type of resource to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_RESOURCE_TYPE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_DEVICE + * + * \sa + * ::cuDevResourceGenerateDesc + */ +CUresult CUDAAPI cuDeviceGetDevResource(CUdevice device, CUdevResource* resource, CUdevResourceType type); + +/** + * \brief Get context resources + * + * Get the \p type resources available to the context represented by \p hCtx + * \param hCtx - Context to get resource for + * + * Note: The API is not supported on 32-bit platforms. + * + * \param resource - Output pointer to a CUdevResource structure + * \param type - Type of resource to retrieve + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_RESOURCE_TYPE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_CONTEXT + * + * \sa + * ::cuDevResourceGenerateDesc + */ +CUresult CUDAAPI cuCtxGetDevResource(CUcontext hCtx, CUdevResource* resource, CUdevResourceType type); + +/** + * \brief Get green context resources + * + * Get the \p type resources available to the green context represented by \p hCtx + * \param hCtx - Green context to get resource for + * \param resource - Output pointer to a CUdevResource structure + * \param type - Type of resource to retrieve + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_RESOURCE_TYPE, + * ::CUDA_ERROR_INVALID_VALUE + * + * \sa + * ::cuDevResourceGenerateDesc + */ +CUresult CUDAAPI cuGreenCtxGetDevResource(CUgreenCtx hCtx, CUdevResource* resource, CUdevResourceType type); + +/** + * \brief Splits \p CU_DEV_RESOURCE_TYPE_SM resources. + * + * Splits \p CU_DEV_RESOURCE_TYPE_SM resources into \p nbGroups, adhering to the minimum SM count specified in \p minCount + * and the usage flags in \p useFlags. If \p result is NULL, the API simulates a split and provides the amount of groups that + * would be created in \p nbGroups. Otherwise, \p nbGroups must point to the amount of elements in \p result and on return, + * the API will overwrite \p nbGroups with the amount actually created. The groups are written to the array in \p result. + * \p nbGroups can be less than the total amount if a smaller number of groups is needed. + * + * This API is used to spatially partition the input resource. The input resource needs to come from one of + * ::cuDeviceGetDevResource, ::cuCtxGetDevResource, or ::cuGreenCtxGetDevResource. + * A limitation of the API is that the output results cannot be split again without + * first creating a descriptor and a green context with that descriptor. + * + * When creating the groups, the API will take into account the performance and functional characteristics of the + * input resource, and guarantee a split that will create a disjoint set of symmetrical partitions. This may lead to fewer groups created + * than purely dividing the total SM count by the \p minCount due to cluster requirements or + * alignment and granularity requirements for the minCount. + * + * The \p remainder set does not have the same functional or performance guarantees as the groups in \p result. + * Its use should be carefully planned and future partitions of the \p remainder set are discouraged. + * + * The following flags are supported: + * - \p CU_DEV_SM_RESOURCE_SPLIT_IGNORE_SM_COSCHEDULING : Lower the minimum SM count and alignment, and treat each SM independent of its hierarchy. + * This allows more fine grained partitions but at the cost of advanced features (such as large clusters on compute capability 9.0+). + * - \p CU_DEV_SM_RESOURCE_SPLIT_MAX_POTENTIAL_CLUSTER_SIZE : Compute Capability 9.0+ only. Attempt to create groups that may allow + * for maximally sized thread clusters. This can be queried post green context creation using ::cuOccupancyMaxPotentialClusterSize. + * + * A successful API call must either have: + * - A valid array of \p result pointers of size passed in \p nbGroups, with \p input of type \p CU_DEV_RESOURCE_TYPE_SM. + * Value of \p minCount must be between 0 and the SM count specified in \p input. \p remaining may be NULL. + * - NULL passed in for \p result, with a valid integer pointer in \p nbGroups and \p input of type \p CU_DEV_RESOURCE_TYPE_SM. + * Value of \p minCount must be between 0 and the SM count specified in \p input. \p remaining may be NULL. + * This queries the number of groups that would be created by the API. + * + * Note: The API is not supported on 32-bit platforms. + * + * \param result - Output array of \p CUdevResource resources. Can be NULL to query the number of groups. + * \param nbGroups - This is a pointer, specifying the number of groups that would be or should be created as described below. + * \param input - Input SM resource to be split. Must be a valid \p CU_DEV_RESOURCE_TYPE_SM resource. + * \param remaining - If the input resource cannot be cleanly split among \p nbGroups, the remaining is placed in here. + * Can be ommitted (NULL) if the user does not need the remaining set. + * \param useFlags - Flags specifying how these partitions are used or which constraints to abide by when splitting the input. Zero is valid for default behavior. + * \param minCount - Minimum number of SMs required + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_DEVICE, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_RESOURCE_TYPE, + * ::CUDA_ERROR_INVALID_RESOURCE_CONFIGURATION + * + * \sa + * ::cuGreenCtxGetDevResource, + * ::cuCtxGetDevResource, + * ::cuDeviceGetDevResource + */ +CUresult CUDAAPI cuDevSmResourceSplitByCount( + CUdevResource* result, unsigned int* nbGroups, const CUdevResource* input, CUdevResource* remaining, unsigned int useFlags, unsigned int minCount); + +/** + * \brief Generate a resource descriptor + * + * Generates a single resource descriptor with the set of resources specified in \p resources. + * The generated resource descriptor is necessary for the creation of green contexts via the ::cuGreenCtxCreate API. + * Resources of the same type can be passed in, provided they meet the requirements as noted below. + * + * A successful API call must have: + * - A valid output pointer for the \p phDesc descriptor as well as a valid array of \p resources pointers, + * with the array size passed in \p nbResources. + * If multiple resources are provided in \p resources, the device they came from must be the same, + * otherwise CUDA_ERROR_INVALID_RESOURCE_CONFIGURATION is returned. + * If multiple resources are provided in \p resources and they are of type ::CU_DEV_RESOURCE_TYPE_SM, + * they must be outputs (whether \p result or \p remaining) from the same split API instance, + * otherwise CUDA_ERROR_INVALID_RESOURCE_CONFIGURATION is returned. + * + * Note: The API is not supported on 32-bit platforms. + * + * \param phDesc - Output descriptor + * \param resources - Array of resources to be included in the descriptor + * \param nbResources - Number of resources passed in \p resources + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_INVALID_RESOURCE_TYPE, + * ::CUDA_ERROR_INVALID_RESOURCE_CONFIGURATION + * + * \sa + * ::cuDevSmResourceSplitByCount + */ +CUresult CUDAAPI cuDevResourceGenerateDesc(CUdevResourceDesc *phDesc, CUdevResource *resources, unsigned int nbResources); + +/** + * \brief Records an event. + * + * Captures in \p hEvent all the activities of the green context of \p hCtx + * at the time of this call. \p hEvent and \p hCtx must be from the same + * primary context otherwise ::CUDA_ERROR_INVALID_HANDLE is returned. + * Calls such as ::cuEventQuery() or ::cuGreenCtxWaitEvent() will + * then examine or wait for completion of the work that was captured. Uses of + * \p hCtx after this call do not modify \p hEvent. + * + * \note The API will return ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED if the + * specified green context \p hCtx has a stream in the capture mode. In such + * a case, the call will invalidate all the conflicting captures. + * + * \param hCtx - Green context to record event for + * \param hEvent - Event to record + * + * \return + * ::CUDA_SUCCESS + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED + * + * \sa + * ::cuGreenCtxWaitEvent, + * ::cuEventRecord, + * ::cuCtxRecordEvent, + * ::cuCtxWaitEvent + */ +CUresult CUDAAPI cuGreenCtxRecordEvent(CUgreenCtx hCtx, CUevent hEvent); + +/** + * \brief Make a green context wait on an event + * + * Makes all future work submitted to green context \p hCtx wait for all work + * captured in \p hEvent. The synchronization will be performed on the device + * and will not block the calling CPU thread. See ::cuGreenCtxRecordEvent() + * or ::cuEventRecord(), for details on what is captured by an event. + * + * \note \p hEvent may be from a different context or device than \p hCtx. + * + * \note The API will return ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED and + * invalidate the capture if the specified event \p hEvent is part of an + * ongoing capture sequence or if the specified green context \p hCtx has + * a stream in the capture mode. + * + * \param hCtx - Green context to wait + * \param hEvent - Event to wait on + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * ::CUDA_ERROR_STREAM_CAPTURE_UNSUPPORTED + * + * \sa + * ::cuGreenCtxRecordEvent, + * ::cuStreamWaitEvent + * ::cuCtxRecordEvent, + * ::cuCtxWaitEvent +*/ +CUresult CUDAAPI cuGreenCtxWaitEvent(CUgreenCtx hCtx, CUevent hEvent); + +/** + * \brief Query the green context associated with a stream + * + * Returns the CUDA green context that the stream is associated with, or NULL if the stream + * is not associated with any green context. + * + * The stream handle \p hStream can refer to any of the following: + *
      + *
    • + * a stream created via any of the CUDA driver APIs such as ::cuStreamCreate, ::cuStreamCreateWithPriority + * and ::cuGreenCtxStreamCreate, or their runtime API equivalents such as + * ::cudaStreamCreate, ::cudaStreamCreateWithFlags and ::cudaStreamCreateWithPriority. + * If during stream creation the context that was active in the calling thread was obtained + * with cuCtxFromGreenCtx, that green context is returned in \p phCtx. + * Otherwise, \p *phCtx is set to NULL instead. + *
    • + *
    • + * special stream such as the NULL stream or ::CU_STREAM_LEGACY. + * In that case if context that is active in the calling thread was obtained + * with cuCtxFromGreenCtx, that green context is returned. + * Otherwise, \p *phCtx is set to NULL instead. + *
    • + *
    + * Passing an invalid handle will result in undefined behavior. + * + * \param hStream - Handle to the stream to be queried + * \param phCtx - Returned green context associated with the stream + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_HANDLE, + * \notefnerr + * + * \sa ::cuStreamDestroy, + * ::cuStreamCreate, + * ::cuStreamCreateWithPriority, + * ::cuStreamGetCtx_v2, + * ::cuGreenCtxStreamCreate, + * ::cuStreamGetPriority, + * ::cuStreamGetFlags, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamCreate, + * ::cudaStreamCreateWithFlags + */ +CUresult CUDAAPI cuStreamGetGreenCtx(CUstream hStream, CUgreenCtx *phCtx); + +/** + * \brief Create a stream for use in the green context + * + * Creates a stream for use in the specified green context \p greenCtx and returns a handle in \p phStream. + * The stream can be destroyed by calling ::cuStreamDestroy(). Note that the API ignores the context that + * is current to the calling thread and creates a stream in the specified green context \p greenCtx. + * + * The supported values for \p flags are: + * - ::CU_STREAM_NON_BLOCKING: This must be specified. It indicates that work running in the created + * stream may run concurrently with work in the default stream, and that + * the created stream should perform no implicit synchronization with the default stream. + * + * Specifying \p priority affects the scheduling priority of work in the stream. Priorities provide a + * hint to preferentially run work with higher priority when possible, but do not preempt + * already-running work or provide any other functional guarantee on execution order. + * \p priority follows a convention where lower numbers represent higher priorities. + * '0' represents default priority. The range of meaningful numerical priorities can + * be queried using ::cuCtxGetStreamPriorityRange. If the specified priority is + * outside the numerical range returned by ::cuCtxGetStreamPriorityRange, + * it will automatically be clamped to the lowest or the highest number in the range. + * + * \param phStream - Returned newly created stream + * \param greenCtx - Green context for which to create the stream for + * \param flags - Flags for stream creation. \p CU_STREAM_NON_BLOCKING must be specified. + * \param priority - Stream priority. Lower numbers represent higher priorities. + * See ::cuCtxGetStreamPriorityRange for more information about + * meaningful stream priorities that can be passed. + * + * \return + * ::CUDA_SUCCESS, + * ::CUDA_ERROR_DEINITIALIZED, + * ::CUDA_ERROR_NOT_INITIALIZED, + * ::CUDA_ERROR_INVALID_CONTEXT, + * ::CUDA_ERROR_INVALID_VALUE, + * ::CUDA_ERROR_OUT_OF_MEMORY + * \notefnerr + * + * \note In the current implementation, only compute kernels launched in + * priority streams are affected by the stream's priority. Stream priorities have + * no effect on host-to-device and device-to-host memory operations. + * + * \sa ::cuStreamDestroy, + * ::cuGreenCtxCreate + * ::cuStreamCreate, + * ::cuStreamGetPriority, + * ::cuCtxGetStreamPriorityRange, + * ::cuStreamGetFlags, + * ::cuStreamWaitEvent, + * ::cuStreamQuery, + * ::cuStreamSynchronize, + * ::cuStreamAddCallback, + * ::cudaStreamCreateWithPriority + */ +CUresult CUDAAPI cuGreenCtxStreamCreate(CUstream* phStream, CUgreenCtx greenCtx, unsigned int flags, int priority); + +/** @} */ + +/* +** *************** END CUDA_GREEN_CONTEXTS ***************** +*/ + +/** + * CUDA API versioning support + */ +#if defined(__CUDA_API_VERSION_INTERNAL) + #undef cuMemHostRegister + #undef cuGraphicsResourceSetMapFlags + #undef cuLinkCreate + #undef cuLinkAddData + #undef cuLinkAddFile + #undef cuDeviceTotalMem + #undef cuCtxCreate + #undef cuModuleGetGlobal + #undef cuMemGetInfo + #undef cuMemAlloc + #undef cuMemAllocPitch + #undef cuMemFree + #undef cuMemGetAddressRange + #undef cuMemAllocHost + #undef cuMemHostGetDevicePointer + #undef cuMemcpyHtoD + #undef cuMemcpyDtoH + #undef cuMemcpyDtoD + #undef cuMemcpyDtoA + #undef cuMemcpyAtoD + #undef cuMemcpyHtoA + #undef cuMemcpyAtoH + #undef cuMemcpyAtoA + #undef cuMemcpyHtoAAsync + #undef cuMemcpyAtoHAsync + #undef cuMemcpy2D + #undef cuMemcpy2DUnaligned + #undef cuMemcpy3D + #undef cuMemcpyHtoDAsync + #undef cuMemcpyDtoHAsync + #undef cuMemcpyDtoDAsync + #undef cuMemcpy2DAsync + #undef cuMemcpy3DAsync + #undef cuMemsetD8 + #undef cuMemsetD16 + #undef cuMemsetD32 + #undef cuMemsetD2D8 + #undef cuMemsetD2D16 + #undef cuMemsetD2D32 + #undef cuArrayCreate + #undef cuArrayGetDescriptor + #undef cuArray3DCreate + #undef cuArray3DGetDescriptor + #undef cuTexRefSetAddress + #undef cuTexRefSetAddress2D + #undef cuTexRefGetAddress + #undef cuGraphicsResourceGetMappedPointer + #undef cuCtxDestroy + #undef cuCtxPopCurrent + #undef cuCtxPushCurrent + #undef cuStreamDestroy + #undef cuEventDestroy + #undef cuMemcpy + #undef cuMemcpyAsync + #undef cuMemcpyPeer + #undef cuMemcpyPeerAsync + #undef cuMemcpy3DPeer + #undef cuMemcpy3DPeerAsync + #undef cuMemsetD8Async + #undef cuMemsetD16Async + #undef cuMemsetD32Async + #undef cuMemsetD2D8Async + #undef cuMemsetD2D16Async + #undef cuMemsetD2D32Async + #undef cuStreamGetPriority + #undef cuStreamGetId + #undef cuStreamGetFlags + #undef cuStreamGetCtx + #undef cuStreamWaitEvent + #undef cuStreamAddCallback + #undef cuStreamAttachMemAsync + #undef cuStreamQuery + #undef cuStreamSynchronize + #undef cuEventRecord + #undef cuEventRecordWithFlags + #undef cuLaunchKernel + #undef cuLaunchKernelEx + #undef cuLaunchHostFunc + #undef cuGraphicsMapResources + #undef cuGraphicsUnmapResources + #undef cuStreamWriteValue32 + #undef cuStreamWaitValue32 + #undef cuStreamWriteValue64 + #undef cuStreamWaitValue64 + #undef cuStreamBatchMemOp + #undef cuStreamWriteValue32_v2 + #undef cuStreamWaitValue32_v2 + #undef cuStreamWriteValue64_v2 + #undef cuStreamWaitValue64_v2 + #undef cuStreamBatchMemOp_v2 + #undef cuMemPrefetchAsync + #undef cuMemPrefetchAsync_v2 + #undef cuLaunchCooperativeKernel + #undef cuSignalExternalSemaphoresAsync + #undef cuWaitExternalSemaphoresAsync + #undef cuStreamBeginCapture + #undef cuStreamBeginCaptureToGraph + #undef cuStreamEndCapture + #undef cuStreamIsCapturing + #undef cuStreamGetCaptureInfo + #undef cuStreamGetCaptureInfo_v2 + #undef cuStreamGetCaptureInfo_v3 + #undef cuGraphInstantiateWithParams + #undef cuGraphExecUpdate + #undef cuGraphUpload + #undef cuGraphLaunch + #undef cuDevicePrimaryCtxRelease + #undef cuDevicePrimaryCtxReset + #undef cuDevicePrimaryCtxSetFlags + #undef cuIpcOpenMemHandle + #undef cuStreamCopyAttributes + #undef cuStreamSetAttribute + #undef cuStreamGetAttribute + #undef cuGraphInstantiate + #undef cuGraphAddKernelNode + #undef cuGraphKernelNodeGetParams + #undef cuGraphKernelNodeSetParams + #undef cuGraphExecKernelNodeSetParams + #undef cuMemMapArrayAsync + #undef cuMemFreeAsync + #undef cuMemAllocAsync + #undef cuMemAllocFromPoolAsync + #undef cuStreamUpdateCaptureDependencies + #undef cuStreamUpdateCaptureDependencies_v2 + #undef cuGetProcAddress + #undef cuStreamGetCtx_v2 + + CUresult CUDAAPI cuMemHostRegister(void *p, size_t bytesize, unsigned int Flags); + CUresult CUDAAPI cuGraphicsResourceSetMapFlags(CUgraphicsResource resource, unsigned int flags); + CUresult CUDAAPI cuLinkCreate(unsigned int numOptions, CUjit_option *options, void **optionValues, CUlinkState *stateOut); + CUresult CUDAAPI cuLinkAddData(CUlinkState state, CUjitInputType type, void *data, size_t size, const char *name, + unsigned int numOptions, CUjit_option *options, void **optionValues); + CUresult CUDAAPI cuLinkAddFile(CUlinkState state, CUjitInputType type, const char *path, + unsigned int numOptions, CUjit_option *options, void **optionValues); + CUresult CUDAAPI cuTexRefSetAddress2D_v2(CUtexref hTexRef, const CUDA_ARRAY_DESCRIPTOR *desc, CUdeviceptr dptr, size_t Pitch); + + typedef unsigned int CUdeviceptr_v1; + + typedef struct CUDA_MEMCPY2D_v1_st + { + unsigned int srcXInBytes; /**< Source X in bytes */ + unsigned int srcY; /**< Source Y */ + CUmemorytype srcMemoryType; /**< Source memory type (host, device, array) */ + const void *srcHost; /**< Source host pointer */ + CUdeviceptr_v1 srcDevice; /**< Source device pointer */ + CUarray srcArray; /**< Source array reference */ + unsigned int srcPitch; /**< Source pitch (ignored when src is array) */ + + unsigned int dstXInBytes; /**< Destination X in bytes */ + unsigned int dstY; /**< Destination Y */ + CUmemorytype dstMemoryType; /**< Destination memory type (host, device, array) */ + void *dstHost; /**< Destination host pointer */ + CUdeviceptr_v1 dstDevice; /**< Destination device pointer */ + CUarray dstArray; /**< Destination array reference */ + unsigned int dstPitch; /**< Destination pitch (ignored when dst is array) */ + + unsigned int WidthInBytes; /**< Width of 2D memory copy in bytes */ + unsigned int Height; /**< Height of 2D memory copy */ + } CUDA_MEMCPY2D_v1; + + typedef struct CUDA_MEMCPY3D_v1_st + { + unsigned int srcXInBytes; /**< Source X in bytes */ + unsigned int srcY; /**< Source Y */ + unsigned int srcZ; /**< Source Z */ + unsigned int srcLOD; /**< Source LOD */ + CUmemorytype srcMemoryType; /**< Source memory type (host, device, array) */ + const void *srcHost; /**< Source host pointer */ + CUdeviceptr_v1 srcDevice; /**< Source device pointer */ + CUarray srcArray; /**< Source array reference */ + void *reserved0; /**< Must be NULL */ + unsigned int srcPitch; /**< Source pitch (ignored when src is array) */ + unsigned int srcHeight; /**< Source height (ignored when src is array; may be 0 if Depth==1) */ + + unsigned int dstXInBytes; /**< Destination X in bytes */ + unsigned int dstY; /**< Destination Y */ + unsigned int dstZ; /**< Destination Z */ + unsigned int dstLOD; /**< Destination LOD */ + CUmemorytype dstMemoryType; /**< Destination memory type (host, device, array) */ + void *dstHost; /**< Destination host pointer */ + CUdeviceptr_v1 dstDevice; /**< Destination device pointer */ + CUarray dstArray; /**< Destination array reference */ + void *reserved1; /**< Must be NULL */ + unsigned int dstPitch; /**< Destination pitch (ignored when dst is array) */ + unsigned int dstHeight; /**< Destination height (ignored when dst is array; may be 0 if Depth==1) */ + + unsigned int WidthInBytes; /**< Width of 3D memory copy in bytes */ + unsigned int Height; /**< Height of 3D memory copy */ + unsigned int Depth; /**< Depth of 3D memory copy */ + } CUDA_MEMCPY3D_v1; + + typedef struct CUDA_ARRAY_DESCRIPTOR_v1_st + { + unsigned int Width; /**< Width of array */ + unsigned int Height; /**< Height of array */ + + CUarray_format Format; /**< Array format */ + unsigned int NumChannels; /**< Channels per array element */ + } CUDA_ARRAY_DESCRIPTOR_v1; + + typedef struct CUDA_ARRAY3D_DESCRIPTOR_v1_st + { + unsigned int Width; /**< Width of 3D array */ + unsigned int Height; /**< Height of 3D array */ + unsigned int Depth; /**< Depth of 3D array */ + + CUarray_format Format; /**< Array format */ + unsigned int NumChannels; /**< Channels per array element */ + unsigned int Flags; /**< Flags */ + } CUDA_ARRAY3D_DESCRIPTOR_v1; + + CUresult CUDAAPI cuDeviceTotalMem(unsigned int *bytes, CUdevice dev); + CUresult CUDAAPI cuCtxCreate(CUcontext *pctx, unsigned int flags, CUdevice dev); + CUresult CUDAAPI cuModuleGetGlobal(CUdeviceptr_v1 *dptr, unsigned int *bytes, CUmodule hmod, const char *name); + CUresult CUDAAPI cuMemGetInfo(unsigned int *free, unsigned int *total); + CUresult CUDAAPI cuMemAlloc(CUdeviceptr_v1 *dptr, unsigned int bytesize); + CUresult CUDAAPI cuMemAllocPitch(CUdeviceptr_v1 *dptr, unsigned int *pPitch, unsigned int WidthInBytes, unsigned int Height, unsigned int ElementSizeBytes); + CUresult CUDAAPI cuMemFree(CUdeviceptr_v1 dptr); + CUresult CUDAAPI cuMemGetAddressRange(CUdeviceptr_v1 *pbase, unsigned int *psize, CUdeviceptr_v1 dptr); + CUresult CUDAAPI cuMemAllocHost(void **pp, unsigned int bytesize); + CUresult CUDAAPI cuMemHostGetDevicePointer(CUdeviceptr_v1 *pdptr, void *p, unsigned int Flags); + CUresult CUDAAPI cuMemcpyHtoD(CUdeviceptr_v1 dstDevice, const void *srcHost, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyDtoH(void *dstHost, CUdeviceptr_v1 srcDevice, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyDtoD(CUdeviceptr_v1 dstDevice, CUdeviceptr_v1 srcDevice, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyDtoA(CUarray dstArray, unsigned int dstOffset, CUdeviceptr_v1 srcDevice, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyAtoD(CUdeviceptr_v1 dstDevice, CUarray srcArray, unsigned int srcOffset, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyHtoA(CUarray dstArray, unsigned int dstOffset, const void *srcHost, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyAtoH(void *dstHost, CUarray srcArray, unsigned int srcOffset, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyAtoA(CUarray dstArray, unsigned int dstOffset, CUarray srcArray, unsigned int srcOffset, unsigned int ByteCount); + CUresult CUDAAPI cuMemcpyHtoAAsync(CUarray dstArray, unsigned int dstOffset, const void *srcHost, unsigned int ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyAtoHAsync(void *dstHost, CUarray srcArray, unsigned int srcOffset, unsigned int ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpy2D(const CUDA_MEMCPY2D_v1 *pCopy); + CUresult CUDAAPI cuMemcpy2DUnaligned(const CUDA_MEMCPY2D_v1 *pCopy); + CUresult CUDAAPI cuMemcpy3D(const CUDA_MEMCPY3D_v1 *pCopy); + CUresult CUDAAPI cuMemcpyHtoDAsync(CUdeviceptr_v1 dstDevice, const void *srcHost, unsigned int ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyDtoHAsync(void *dstHost, CUdeviceptr_v1 srcDevice, unsigned int ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyDtoDAsync(CUdeviceptr_v1 dstDevice, CUdeviceptr_v1 srcDevice, unsigned int ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpy2DAsync(const CUDA_MEMCPY2D_v1 *pCopy, CUstream hStream); + CUresult CUDAAPI cuMemcpy3DAsync(const CUDA_MEMCPY3D_v1 *pCopy, CUstream hStream); + CUresult CUDAAPI cuMemsetD8(CUdeviceptr_v1 dstDevice, unsigned char uc, unsigned int N); + CUresult CUDAAPI cuMemsetD16(CUdeviceptr_v1 dstDevice, unsigned short us, unsigned int N); + CUresult CUDAAPI cuMemsetD32(CUdeviceptr_v1 dstDevice, unsigned int ui, unsigned int N); + CUresult CUDAAPI cuMemsetD2D8(CUdeviceptr_v1 dstDevice, unsigned int dstPitch, unsigned char uc, unsigned int Width, unsigned int Height); + CUresult CUDAAPI cuMemsetD2D16(CUdeviceptr_v1 dstDevice, unsigned int dstPitch, unsigned short us, unsigned int Width, unsigned int Height); + CUresult CUDAAPI cuMemsetD2D32(CUdeviceptr_v1 dstDevice, unsigned int dstPitch, unsigned int ui, unsigned int Width, unsigned int Height); + CUresult CUDAAPI cuArrayCreate(CUarray *pHandle, const CUDA_ARRAY_DESCRIPTOR_v1 *pAllocateArray); + CUresult CUDAAPI cuArrayGetDescriptor(CUDA_ARRAY_DESCRIPTOR_v1 *pArrayDescriptor, CUarray hArray); + CUresult CUDAAPI cuArray3DCreate(CUarray *pHandle, const CUDA_ARRAY3D_DESCRIPTOR_v1 *pAllocateArray); + CUresult CUDAAPI cuArray3DGetDescriptor(CUDA_ARRAY3D_DESCRIPTOR_v1 *pArrayDescriptor, CUarray hArray); + CUresult CUDAAPI cuTexRefSetAddress(unsigned int *ByteOffset, CUtexref hTexRef, CUdeviceptr_v1 dptr, unsigned int bytes); + CUresult CUDAAPI cuTexRefSetAddress2D(CUtexref hTexRef, const CUDA_ARRAY_DESCRIPTOR_v1 *desc, CUdeviceptr_v1 dptr, unsigned int Pitch); + CUresult CUDAAPI cuTexRefGetAddress(CUdeviceptr_v1 *pdptr, CUtexref hTexRef); + CUresult CUDAAPI cuGraphicsResourceGetMappedPointer(CUdeviceptr_v1 *pDevPtr, unsigned int *pSize, CUgraphicsResource resource); + + CUresult CUDAAPI cuCtxDestroy(CUcontext ctx); + CUresult CUDAAPI cuCtxPopCurrent(CUcontext *pctx); + CUresult CUDAAPI cuCtxPushCurrent(CUcontext ctx); + CUresult CUDAAPI cuStreamDestroy(CUstream hStream); + CUresult CUDAAPI cuEventDestroy(CUevent hEvent); + CUresult CUDAAPI cuDevicePrimaryCtxRelease(CUdevice dev); + CUresult CUDAAPI cuDevicePrimaryCtxReset(CUdevice dev); + CUresult CUDAAPI cuDevicePrimaryCtxSetFlags(CUdevice dev, unsigned int flags); + + CUresult CUDAAPI cuMemcpyHtoD_v2(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount); + CUresult CUDAAPI cuMemcpyDtoH_v2(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount); + CUresult CUDAAPI cuMemcpyDtoD_v2(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount); + CUresult CUDAAPI cuMemcpyDtoA_v2(CUarray dstArray, size_t dstOffset, CUdeviceptr srcDevice, size_t ByteCount); + CUresult CUDAAPI cuMemcpyAtoD_v2(CUdeviceptr dstDevice, CUarray srcArray, size_t srcOffset, size_t ByteCount); + CUresult CUDAAPI cuMemcpyHtoA_v2(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount); + CUresult CUDAAPI cuMemcpyAtoH_v2(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount); + CUresult CUDAAPI cuMemcpyAtoA_v2(CUarray dstArray, size_t dstOffset, CUarray srcArray, size_t srcOffset, size_t ByteCount); + CUresult CUDAAPI cuMemcpyHtoAAsync_v2(CUarray dstArray, size_t dstOffset, const void *srcHost, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyAtoHAsync_v2(void *dstHost, CUarray srcArray, size_t srcOffset, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpy2D_v2(const CUDA_MEMCPY2D *pCopy); + CUresult CUDAAPI cuMemcpy2DUnaligned_v2(const CUDA_MEMCPY2D *pCopy); + CUresult CUDAAPI cuMemcpy3D_v2(const CUDA_MEMCPY3D *pCopy); + CUresult CUDAAPI cuMemcpyHtoDAsync_v2(CUdeviceptr dstDevice, const void *srcHost, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyDtoHAsync_v2(void *dstHost, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyDtoDAsync_v2(CUdeviceptr dstDevice, CUdeviceptr srcDevice, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpy2DAsync_v2(const CUDA_MEMCPY2D *pCopy, CUstream hStream); + CUresult CUDAAPI cuMemcpy3DAsync_v2(const CUDA_MEMCPY3D *pCopy, CUstream hStream); + CUresult CUDAAPI cuMemsetD8_v2(CUdeviceptr dstDevice, unsigned char uc, size_t N); + CUresult CUDAAPI cuMemsetD16_v2(CUdeviceptr dstDevice, unsigned short us, size_t N); + CUresult CUDAAPI cuMemsetD32_v2(CUdeviceptr dstDevice, unsigned int ui, size_t N); + CUresult CUDAAPI cuMemsetD2D8_v2(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height); + CUresult CUDAAPI cuMemsetD2D16_v2(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height); + CUresult CUDAAPI cuMemsetD2D32_v2(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height); + CUresult CUDAAPI cuMemcpy(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount); + CUresult CUDAAPI cuMemcpyAsync(CUdeviceptr dst, CUdeviceptr src, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpyPeer(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount); + CUresult CUDAAPI cuMemcpyPeerAsync(CUdeviceptr dstDevice, CUcontext dstContext, CUdeviceptr srcDevice, CUcontext srcContext, size_t ByteCount, CUstream hStream); + CUresult CUDAAPI cuMemcpy3DPeer(const CUDA_MEMCPY3D_PEER *pCopy); + CUresult CUDAAPI cuMemcpy3DPeerAsync(const CUDA_MEMCPY3D_PEER *pCopy, CUstream hStream); + + CUresult CUDAAPI cuMemsetD8Async(CUdeviceptr dstDevice, unsigned char uc, size_t N, CUstream hStream); + CUresult CUDAAPI cuMemsetD16Async(CUdeviceptr dstDevice, unsigned short us, size_t N, CUstream hStream); + CUresult CUDAAPI cuMemsetD32Async(CUdeviceptr dstDevice, unsigned int ui, size_t N, CUstream hStream); + CUresult CUDAAPI cuMemsetD2D8Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned char uc, size_t Width, size_t Height, CUstream hStream); + CUresult CUDAAPI cuMemsetD2D16Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned short us, size_t Width, size_t Height, CUstream hStream); + CUresult CUDAAPI cuMemsetD2D32Async(CUdeviceptr dstDevice, size_t dstPitch, unsigned int ui, size_t Width, size_t Height, CUstream hStream); + + CUresult CUDAAPI cuStreamGetPriority(CUstream hStream, int *priority); + CUresult CUDAAPI cuStreamGetId(CUstream hStream, unsigned long long *streamId); + CUresult CUDAAPI cuStreamGetFlags(CUstream hStream, unsigned int *flags); + CUresult CUDAAPI cuStreamGetCtx(CUstream hStream, CUcontext *pctx); + CUresult CUDAAPI cuStreamGetCtx_v2(CUstream hStream, CUcontext *pCtx, CUgreenCtx *pGreenCtx); + CUresult CUDAAPI cuStreamWaitEvent(CUstream hStream, CUevent hEvent, unsigned int Flags); + CUresult CUDAAPI cuStreamAddCallback(CUstream hStream, CUstreamCallback callback, void *userData, unsigned int flags); + CUresult CUDAAPI cuStreamAttachMemAsync(CUstream hStream, CUdeviceptr dptr, size_t length, unsigned int flags); + CUresult CUDAAPI cuStreamQuery(CUstream hStream); + CUresult CUDAAPI cuStreamSynchronize(CUstream hStream); + CUresult CUDAAPI cuEventRecord(CUevent hEvent, CUstream hStream); + CUresult CUDAAPI cuEventRecordWithFlags(CUevent hEvent, CUstream hStream, unsigned int flags); + CUresult CUDAAPI cuLaunchKernel(CUfunction f, unsigned int gridDimX, unsigned int gridDimY, unsigned int gridDimZ, unsigned int blockDimX, unsigned int blockDimY, unsigned int blockDimZ, unsigned int sharedMemBytes, CUstream hStream, void **kernelParams, void **extra); + CUresult CUDAAPI cuLaunchKernelEx(const CUlaunchConfig *config, CUfunction f, void **kernelParams, void **extra); + CUresult CUDAAPI cuLaunchHostFunc(CUstream hStream, CUhostFn fn, void *userData); + CUresult CUDAAPI cuGraphicsMapResources(unsigned int count, CUgraphicsResource *resources, CUstream hStream); + CUresult CUDAAPI cuGraphicsUnmapResources(unsigned int count, CUgraphicsResource *resources, CUstream hStream); + CUresult CUDAAPI cuStreamWriteValue32(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWaitValue32(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWriteValue64(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWaitValue64(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + CUresult CUDAAPI cuStreamBatchMemOp(CUstream stream, unsigned int count, CUstreamBatchMemOpParams *paramArray, unsigned int flags); + + CUresult CUDAAPI cuStreamWriteValue32_ptsz(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWaitValue32_ptsz(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWriteValue64_ptsz(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWaitValue64_ptsz(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + CUresult CUDAAPI cuStreamBatchMemOp_ptsz(CUstream stream, unsigned int count, CUstreamBatchMemOpParams *paramArray, unsigned int flags); + + CUresult CUDAAPI cuStreamWriteValue32_v2(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWaitValue32_v2(CUstream stream, CUdeviceptr addr, cuuint32_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWriteValue64_v2(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + CUresult CUDAAPI cuStreamWaitValue64_v2(CUstream stream, CUdeviceptr addr, cuuint64_t value, unsigned int flags); + CUresult CUDAAPI cuStreamBatchMemOp_v2(CUstream stream, unsigned int count, CUstreamBatchMemOpParams *paramArray, unsigned int flags); + CUresult CUDAAPI cuMemPrefetchAsync(CUdeviceptr devPtr, size_t count, CUdevice dstDevice, CUstream hStream); + CUresult CUDAAPI cuMemPrefetchAsync_v2(CUdeviceptr devPtr, size_t count, CUmemLocation location, unsigned int flags, CUstream hStream); + CUresult CUDAAPI cuLaunchCooperativeKernel(CUfunction f, unsigned int gridDimX, unsigned int gridDimY, unsigned int gridDimZ, unsigned int blockDimX, unsigned int blockDimY, unsigned int blockDimZ, unsigned int sharedMemBytes, CUstream hStream, void **kernelParams); + CUresult CUDAAPI cuSignalExternalSemaphoresAsync(const CUexternalSemaphore *extSemArray, const CUDA_EXTERNAL_SEMAPHORE_SIGNAL_PARAMS *paramsArray, unsigned int numExtSems, CUstream stream); + CUresult CUDAAPI cuWaitExternalSemaphoresAsync(const CUexternalSemaphore *extSemArray, const CUDA_EXTERNAL_SEMAPHORE_WAIT_PARAMS *paramsArray, unsigned int numExtSems, CUstream stream); + CUresult CUDAAPI cuStreamBeginCapture(CUstream hStream); + CUresult CUDAAPI cuStreamBeginCapture_ptsz(CUstream hStream); + CUresult CUDAAPI cuStreamBeginCapture_v2(CUstream hStream, CUstreamCaptureMode mode); + CUresult CUDAAPI cuStreamBeginCaptureToGraph(CUstream hStream, CUgraph hGraph, const CUgraphNode *dependencies, const CUgraphEdgeData *dependencyData, size_t numDependencies, CUstreamCaptureMode mode); + CUresult CUDAAPI cuStreamEndCapture(CUstream hStream, CUgraph *phGraph); + CUresult CUDAAPI cuStreamIsCapturing(CUstream hStream, CUstreamCaptureStatus *captureStatus); + CUresult CUDAAPI cuStreamGetCaptureInfo(CUstream hStream, CUstreamCaptureStatus *captureStatus_out, cuuint64_t *id_out); + CUresult CUDAAPI cuStreamGetCaptureInfo_ptsz(CUstream hStream, CUstreamCaptureStatus *captureStatus_out, cuuint64_t *id_out); + CUresult CUDAAPI cuStreamGetCaptureInfo_v2(CUstream hStream, CUstreamCaptureStatus *captureStatus_out, cuuint64_t *id_out, CUgraph *graph_out, const CUgraphNode **dependencies_out, size_t *numDependencies_out); + CUresult CUDAAPI cuStreamGetCaptureInfo_v3(CUstream hStream, CUstreamCaptureStatus *captureStatus_out, cuuint64_t *id_out, CUgraph *graph_out, const CUgraphNode **dependencies_out, const CUgraphEdgeData **edgeData_out, size_t *numDependencies_out); + CUresult CUDAAPI cuGraphAddKernelNode(CUgraphNode *phGraphNode, CUgraph hGraph, const CUgraphNode *dependencies, size_t numDependencies, const CUDA_KERNEL_NODE_PARAMS_v1 *nodeParams); + CUresult CUDAAPI cuGraphKernelNodeGetParams(CUgraphNode hNode, CUDA_KERNEL_NODE_PARAMS_v1 *nodeParams); + CUresult CUDAAPI cuGraphKernelNodeSetParams(CUgraphNode hNode, const CUDA_KERNEL_NODE_PARAMS_v1 *nodeParams); + CUresult CUDAAPI cuGraphExecKernelNodeSetParams(CUgraphExec hGraphExec, CUgraphNode hNode, const CUDA_KERNEL_NODE_PARAMS_v1 *nodeParams); + CUresult CUDAAPI cuGraphInstantiateWithParams(CUgraphExec *phGraphExec, CUgraph hGraph, CUDA_GRAPH_INSTANTIATE_PARAMS *instantiateParams); + CUresult CUDAAPI cuGraphExecUpdate(CUgraphExec hGraphExec, CUgraph hGraph, CUgraphNode *hErrorNode_out, CUgraphExecUpdateResult *updateResult_out); + CUresult CUDAAPI cuGraphUpload(CUgraphExec hGraph, CUstream hStream); + CUresult CUDAAPI cuGraphLaunch(CUgraphExec hGraph, CUstream hStream); + CUresult CUDAAPI cuStreamCopyAttributes(CUstream dstStream, CUstream srcStream); + CUresult CUDAAPI cuStreamGetAttribute(CUstream hStream, CUstreamAttrID attr, CUstreamAttrValue *value); + CUresult CUDAAPI cuStreamSetAttribute(CUstream hStream, CUstreamAttrID attr, const CUstreamAttrValue *param); + + CUresult CUDAAPI cuIpcOpenMemHandle(CUdeviceptr *pdptr, CUipcMemHandle handle, unsigned int Flags); + CUresult CUDAAPI cuGraphInstantiate(CUgraphExec *phGraphExec, CUgraph hGraph, CUgraphNode *phErrorNode, char *logBuffer, size_t bufferSize); + CUresult CUDAAPI cuGraphInstantiate_v2(CUgraphExec *phGraphExec, CUgraph hGraph, CUgraphNode *phErrorNode, char *logBuffer, size_t bufferSize); + + CUresult CUDAAPI cuMemMapArrayAsync(CUarrayMapInfo *mapInfoList, unsigned int count, CUstream hStream); + + CUresult CUDAAPI cuMemFreeAsync(CUdeviceptr dptr, CUstream hStream); + CUresult CUDAAPI cuMemAllocAsync(CUdeviceptr *dptr, size_t bytesize, CUstream hStream); + CUresult CUDAAPI cuMemAllocFromPoolAsync(CUdeviceptr *dptr, size_t bytesize, CUmemoryPool pool, CUstream hStream); + + CUresult CUDAAPI cuStreamUpdateCaptureDependencies(CUstream hStream, CUgraphNode *dependencies, size_t numDependencies, unsigned int flags); + CUresult CUDAAPI cuStreamUpdateCaptureDependencies_v2(CUstream hStream, CUgraphNode *dependencies, const CUgraphEdgeData *dependencyData, size_t numDependencies, unsigned int flags); + + CUresult CUDAAPI cuGetProcAddress(const char *symbol, void **pfn, int cudaVersion, cuuint64_t flags); + +#elif defined(__CUDA_API_PER_THREAD_DEFAULT_STREAM) +static inline CUresult cuGetProcAddress_v2_ptsz(const char *symbol, void **funcPtr, int driverVersion, cuuint64_t flags, CUdriverProcAddressQueryResult *symbolStatus) { + const int procAddressMask = (CU_GET_PROC_ADDRESS_LEGACY_STREAM| + CU_GET_PROC_ADDRESS_PER_THREAD_DEFAULT_STREAM); + if ((flags & procAddressMask) == 0) { + flags |= CU_GET_PROC_ADDRESS_PER_THREAD_DEFAULT_STREAM; + } + return cuGetProcAddress_v2(symbol, funcPtr, driverVersion, flags, symbolStatus); +} +#define cuGetProcAddress_v2 cuGetProcAddress_v2_ptsz +#endif + +#ifdef __cplusplus +} +#endif + +#if defined(__GNUC__) + #if defined(__CUDA_API_PUSH_VISIBILITY_DEFAULT) + #pragma GCC visibility pop + #endif +#endif + +#undef __CUDA_DEPRECATED + +#endif /* __cuda_cuda_h__ */ From 1f91fd4448d43a88a02a5e6e0d9d9601d52dd2ea Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 23 Apr 2026 22:50:04 -0700 Subject: [PATCH 14/25] rdma: bind HTTP socket to token NIC + process-wide cuObjClient MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Three changes in the RDMA client path, all needed to make cuObject 1.2 multipath work reliably end-to-end against an S3 server: 1. rdma.h: extract the source-NIC GID from the RDMA token (field 7 of the cuObj descriptor per cuObjRDMADESCRprotocolformat.pdf) and pin the outgoing HTTP socket to that interface via httplib set_interface (CURLOPT_INTERFACE). Under RoundRobin multipath libcuobjclient may mint a token referencing the backup NIC while the kernel's default route sends HTTP out the primary NIC; without this binding the server's RDMA_READ targets a peer whose flow was never primed on this session, causing IBV_WC_RETRY_EXC_ERR and a 3.7s stall. 2. client.h + client.cc: promote cuObjClient to a process-wide Meyers singleton exposed as Client::SharedRDMAClient(). libcuobjclient drives libcufile which maintains process-global state (device / peer cache, health monitor, multipath registration); running the constructor from multiple threads simultaneously on process startup tripped a glibc heap-corruption abort ("malloc(): invalid size (unsorted)"). Singleton init via [stmt.dcl]/4 is thread-safe and happens exactly once. 3. client.cc: Client::PutObject(PutObjectRDMAArgs) HTTP fallback was constructing PutObjectArgs without copying args.bucket / .object / .region, so fall-through requests from the RDMA path failed with "bucket name cannot be empty". Set those fields explicitly so the fallback delivers the same request over HTTP. Validated on a 2-NIC ConnectX-7 client (primary + backup) against a single-NIC server, 3×3min warp putRDMA chaos runs (baseline, primary-down, backup-down) and a 60s PUT+GET round-trip over 130k objects: zero application-visible errors, ETag stable between RDMA PUT, RDMA GET, and plain HTTP GET of the same objects. --- include/miniocpp/client.h | 13 +++++++ include/miniocpp/rdma.h | 43 ++++++++++++++++++++ src/client.cc | 82 +++++++++++++++++++++------------------ 3 files changed, 100 insertions(+), 38 deletions(-) diff --git a/include/miniocpp/client.h b/include/miniocpp/client.h index ffe2829f..e9cfce97 100644 --- a/include/miniocpp/client.h +++ b/include/miniocpp/client.h @@ -111,6 +111,19 @@ class Client : public BaseClient { PutObjectResponse PutObject(PutObjectArgs args, std::string& upload_id, char* buf); + // Process-wide RDMA client, one instance for the whole process, lazily + // initialised on first use via std::call_once. Reasons this has to be + // process-wide rather than per-Client instance: + // (1) libcuobjclient drives libcufile which maintains process-global + // state (cufile.json, device/peer cache, health monitor threads, + // multipath registration). Two concurrent constructors corrupt + // the glibc heap ("malloc(): invalid size (unsorted)"). + // (2) Even after init, reusing a single client avoids the per-call + // connect+register race that used to make isConnected() flap + // under concurrency and silently skip RDMA in favour of HTTP. + // See SharedRDMAClient() in client.cc for the definition. + static cuObjClient& SharedRDMAClient(); + public: explicit Client(BaseUrl& base_url, creds::Provider* const provider = nullptr); ~Client() = default; diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h index 12401b80..26cc2aae 100644 --- a/include/miniocpp/rdma.h +++ b/include/miniocpp/rdma.h @@ -34,6 +34,10 @@ // that pass pinned host memory (posix_memalign / aligned_alloc) don't need // CUDA at all — cuFile detects host pointers via cuFileGetMemoryType and // skips the GPU codepath. +#include +#include +#include + #include "credentials.h" #include "error.h" #include "nvidia-cufile.h" @@ -62,6 +66,32 @@ inline constexpr int kRDMAReplyNotImplemented = 501; // Return codes for rdmaPut/rdmaGet inline constexpr ssize_t kRDMANotSupported = -2; +// Extract the client NIC IP from the 81-char RDMA token. libcuobjclient +// 1.2.0+ encodes the source NIC's GID in the last 32 hex chars of the +// descriptor as an IPv4-mapped IPv6 suffix ("...ffffAABBCCDD"). Binding +// the outbound HTTP socket to that address (via CURLOPT_INTERFACE / +// httplib::set_interface) keeps the TCP session and the RDMA peer on +// the same NIC, so the server's RDMA_READ back to the client hits the +// same HCA that delivered the HTTP request. Returns empty string if the +// token doesn't follow the expected layout (older client, non-multipath). +inline static std::string parseClientNICFromToken(const char* token) { + if (token == nullptr) return {}; + size_t n = strlen(token); + if (n < 32) return {}; + const char* tail = token + n - 32; + for (int i = 0; i < 20; ++i) { + if (tail[i] != '0') return {}; + } + if (tail[20] != 'f' || tail[21] != 'f' || tail[22] != 'f' || tail[23] != 'f') { + return {}; + } + unsigned int a, b, c, d; + if (std::sscanf(tail + 24, "%2x%2x%2x%2x", &a, &b, &c, &d) != 4) return {}; + char buf[16]; + std::snprintf(buf, sizeof(buf), "%u.%u.%u.%u", a, b, c, d); + return std::string(buf); +} + // Maximum attempts for NIC-failover aware retry. Two attempts is sufficient: // the first failure is what surfaces the bad NIC to libcuobjclient's // async-event + health-check threads; the second mint will route to the @@ -135,6 +165,14 @@ inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, httplib::Client cli(url.String()); cli.set_connection_timeout(5); cli.set_read_timeout(10); + // Pin the TCP source address to the same NIC whose GID is embedded in + // the RDMA token. Without this, multipath can pick a backup NIC for + // the token while the kernel sends HTTP out the primary NIC, and the + // server's RDMA_READ has no healthy path back to the token's peer. + std::string client_nic = parseClientNICFromToken(token); + if (!client_nic.empty()) { + cli.set_interface(client_nic); + } auto res = cli.Put(full_path, headers, "", ""); if (res.error() != httplib::Error::Success) { @@ -220,6 +258,11 @@ inline static ssize_t rdmaGet(s3_rdma_client_ctx_t* sctx, const char* token, httplib::Client cli(url.String()); cli.set_connection_timeout(5); cli.set_read_timeout(10); + // Pin TCP source to the token's NIC — see rdmaPut above for rationale. + std::string client_nic = parseClientNICFromToken(token); + if (!client_nic.empty()) { + cli.set_interface(client_nic); + } auto res = cli.Get(path, headers); if (res.error() != httplib::Error::Success) { diff --git a/src/client.cc b/src/client.cc index fa552000..35cf1eb4 100644 --- a/src/client.cc +++ b/src/client.cc @@ -150,6 +150,19 @@ void RemoveObjectsResult::Populate() { } } +// Meyers singleton — thread-safe per C++11 [stmt.dcl]/4 ("If control +// enters the declaration concurrently while the variable is being +// initialized, the concurrent execution shall wait for completion of the +// initialization."). This replaces the previous per-call cuObjClient +// construction, which was racy under concurrency and caused the +// glibc-level "malloc(): invalid size (unsorted)" abort when multiple +// warp workers started up simultaneously. +cuObjClient& Client::SharedRDMAClient() { + static CUObjIOOps ops{}; + static cuObjClient client{ops, CUOBJ_PROTO_RDMA_DC_V1}; + return client; +} + Client::Client(BaseUrl& base_url, creds::Provider* const provider) : BaseClient(base_url, provider) {} @@ -387,20 +400,16 @@ GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { return GetObjectResponse(resp); } - CUObjIOOps ops = {}; - cuObjClient rdmaclient(ops, CUOBJ_PROTO_RDMA_DC_V1); - const size_t size = *args.size; - bool use_rdma = false; - if (rdmaclient.isConnected()) { - int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); - if (res) { - - } else { - use_rdma = true; - } - } + // Use the process-wide SharedRDMAClient() (per-process cuObjClient avoids + // the concurrent-ctor heap corruption we hit when each call built its + // own). Buffer registration is still per-call — keeping PutDescriptor + // in the PutRetry path is required by libcuobjclient to release + // per-transfer multipath slot state; caching the registration made + // throughput collapse. + cuObjClient& rdma_client = SharedRDMAClient(); + bool use_rdma = (rdma_client.cuMemObjGetDescriptor(args.buf, size) == 0); if (use_rdma) { s3_rdma_client_ctx getCtx = { @@ -412,8 +421,8 @@ GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { .op = CUOBJ_GET, }; - ssize_t ret = rdmaGetWithRetry(&rdmaclient, &getCtx, args.buf, size); - rdmaclient.cuMemObjPutDescriptor(args.buf); + ssize_t ret = rdmaGetWithRetry(&rdma_client, &getCtx, args.buf, size); + rdma_client.cuMemObjPutDescriptor(args.buf); if (ret > 0) { GetObjectResponse resp; @@ -450,20 +459,11 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { return PutObjectResponse(resp); } - CUObjIOOps ops = {}; - cuObjClient rdmaclient(ops, CUOBJ_PROTO_RDMA_DC_V1); - const size_t size = *args.size; - bool use_rdma = false; - if (rdmaclient.isConnected()) { - int res = rdmaclient.cuMemObjGetDescriptor(args.buf, size); - if (res) { - - } else { - use_rdma = true; - } - } + // See GetObject(GetObjectRDMAArgs) for rationale. + cuObjClient& rdma_client = SharedRDMAClient(); + bool use_rdma = (rdma_client.cuMemObjGetDescriptor(args.buf, size) == 0); if (use_rdma) { s3_rdma_client_ctx putCtx = { @@ -475,8 +475,8 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { .op = CUOBJ_PUT, }; - ssize_t ret = rdmaPutWithRetry(&rdmaclient, &putCtx, args.buf, size); - rdmaclient.cuMemObjPutDescriptor(args.buf); + ssize_t ret = rdmaPutWithRetry(&rdma_client, &putCtx, args.buf, size); + rdma_client.cuMemObjPutDescriptor(args.buf); if (ret > 0) { PutObjectResponse resp; @@ -487,12 +487,17 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { // fall through to HTTP path. } - // HTTP fallback path + // HTTP fallback path. We must propagate bucket/object/region onto the + // PutObjectArgs — without them utils::CheckBucketName() rejects the call + // with "bucket name cannot be empty" before a single byte is sent. std::stringstream ss(std::ios_base::in | std::ios_base::out); ss.rdbuf()->pubsetbuf(args.buf, size); minio::s3::PutObjectArgs aargs(ss, static_cast(size), 16 * 1024 * 1024UL); + aargs.bucket = args.bucket; + aargs.object = args.object; + aargs.region = region; return PutObject(aargs); } @@ -895,12 +900,13 @@ PutObjectResponse Client::PutObject(PutObjectArgs args) { "unable to allocate system memory with alignment"); } - CUObjIOOps ops = {}; - std::unique_ptr rdmaclient( - new cuObjClient(ops, CUOBJ_PROTO_RDMA_DC_V1)); - - if (rdmaclient->isConnected()) { - res = rdmaclient->cuMemObjGetDescriptor(buf, args.part_size); + // Reuse the process-wide SharedRDMAClient() rather than constructing + // per-call; see client.h for the race rationale. `buf` here is the + // multipart part buffer, registered once for the whole multipart + // upload and deregistered at the end. + cuObjClient& rdma_client = SharedRDMAClient(); + if (rdma_client.isConnected()) { + res = rdma_client.cuMemObjGetDescriptor(buf, args.part_size); if (res) { free(buf); return error::make("unable to register RDMA buffer"); @@ -908,7 +914,7 @@ PutObjectResponse Client::PutObject(PutObjectArgs args) { } std::string upload_id; - args.rdmaclient = rdmaclient.get(); + args.rdmaclient = &rdma_client; PutObjectResponse resp = PutObject(args, upload_id, buf); if (!resp && !upload_id.empty()) { @@ -920,8 +926,8 @@ PutObjectResponse Client::PutObject(PutObjectArgs args) { AbortMultipartUpload(amu_args); } - if (rdmaclient->isConnected()) { - res = rdmaclient->cuMemObjPutDescriptor(buf); + if (rdma_client.isConnected()) { + res = rdma_client.cuMemObjPutDescriptor(buf); if (res) { free(buf); return error::make("unable to deregister RDMA buffer"); From 1420b78f454234b2fe26e0e8782da3d1f6d85442 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 14 May 2026 21:28:02 -0700 Subject: [PATCH 15/25] rdma: propagate region on RDMA HTTP fallback + harden Validate Three related fixes on the RDMA path: 1. include/miniocpp/baseclient.h: add a public GetBaseUrl() accessor. FFI shims (minio-go's api-put-object.cpp PutObjectRDMA / GetObjectRDMA C glue) need to read the client-configured region at call time and stamp it onto PutObjectRDMAArgs / GetObjectRDMAArgs. base_url_ was protected with no getter, so the shim had no way to forward it short of widening the C API. A const accessor is the minimal change. 2. src/client.cc: Client::GetObject(GetObjectRDMAArgs) HTTP fallback was setting targs.bucket and targs.object but dropping the region we just resolved via GetRegion(). For buckets in a non-default region this meant the fallback signed against the wrong region; for the default region it cost a redundant GetRegion() roundtrip inside BaseClient::GetObject. Matches the PutObject(PutObjectRDMAArgs) fallback added in fd468d9. 3. src/args.cc: PutObjectRDMAArgs::Validate() and GetObjectRDMAArgs:: Validate() now chain through ObjectArgs::Validate() to catch an empty bucket/object at the call site, rather than letting it slip into the RDMA path and surface as a confusing fallback failure. We chain to ObjectArgs rather than the more specific parent (GetObjectArgs/PutObjectBaseArgs) because the latter require fields the RDMA path doesn't use (datafunc / part_size). --- include/miniocpp/baseclient.h | 7 +++++++ src/args.cc | 13 +++++++++++++ src/client.cc | 6 ++++++ 3 files changed, 26 insertions(+) diff --git a/include/miniocpp/baseclient.h b/include/miniocpp/baseclient.h index 3258234a..468847e4 100644 --- a/include/miniocpp/baseclient.h +++ b/include/miniocpp/baseclient.h @@ -66,6 +66,13 @@ class BaseClient { virtual ~BaseClient() = default; + // Read-only access to the configured BaseUrl. Used by FFI shims that need + // the region/endpoint at call time without re-plumbing it through every + // call site (e.g. PutObjectRDMA / GetObjectRDMA in minio-go's C glue, where + // it propagates onto PutObjectRDMAArgs so the HTTP fallback inherits a + // known region instead of paying a GetRegion() roundtrip). + const BaseUrl& GetBaseUrl() const { return base_url_; } + void Debug(bool flag) { debug_ = flag; } void IgnoreCertCheck(bool flag) { ignore_cert_check_ = flag; } diff --git a/src/args.cc b/src/args.cc index d8684968..3cbeb971 100644 --- a/src/args.cc +++ b/src/args.cc @@ -225,6 +225,14 @@ error::Error DownloadObjectArgs::Validate() const { } error::Error GetObjectRDMAArgs::Validate() const { + // Validate bucket+object via the ObjectArgs chain so an empty bucket + // is rejected here with "bucket name cannot be empty" instead of slipping + // through to the HTTP fallback in Client::GetObject(GetObjectRDMAArgs). + // We deliberately skip GetObjectArgs::Validate() because it requires + // datafunc, which the RDMA path does not use (writes go straight to buf). + if (error::Error err = ObjectArgs::Validate()) { + return err; + } if (!this->buf) { return error::Error("buffer must be set"); } @@ -236,6 +244,11 @@ error::Error GetObjectRDMAArgs::Validate() const { } error::Error PutObjectRDMAArgs::Validate() const { + // See GetObjectRDMAArgs::Validate() for rationale on calling ObjectArgs + // directly instead of a more specific parent. + if (error::Error err = ObjectArgs::Validate()) { + return err; + } if (!this->buf) { return error::Error("buffer must be set"); } diff --git a/src/client.cc b/src/client.cc index 35cf1eb4..965b2262 100644 --- a/src/client.cc +++ b/src/client.cc @@ -433,12 +433,18 @@ GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { // fall through to HTTP path. } + // HTTP fallback path. Propagate the region resolved above onto targs so the + // fallback request is signed against the bucket's actual region instead of + // re-paying a GetRegion() roundtrip (and so a non-default region is honored + // when GET falls back). bucket/object were already being copied; matches + // the PutObject(PutObjectRDMAArgs) fallback below. GetObjectArgs targs; std::stringstream ss(std::ios_base::in | std::ios_base::out); ss.rdbuf()->pubsetbuf(args.buf, size); targs.bucket = args.bucket; targs.object = args.object; + targs.region = region; targs.datafunc = [&ss = ss](minio::http::DataFunctionArgs args) -> bool { ss << args.datachunk; return true; From b2857ad20c560c65084fbb969e7e20ba3e74523c Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 14 May 2026 21:55:41 -0700 Subject: [PATCH 16/25] rdma: silence -Wmissing-field-initializers on s3_rdma_client_ctx Designated-initializer construction of s3_rdma_client_ctx at the four single-shot Put/Get callsites omits std::string fields that are either populated by the callee (etag, checksum) or only used in multipart contexts (uploadId, partNumber). Without in-class defaults on those strings, GCC raises -Wmissing-field-initializers on every callsite. Give every member an explicit in-class default so the omissions are intentional and silent. Functionally a no-op (std::string already default-constructs to empty), but removes noise that was masking real warnings during build. --- include/miniocpp/nvidia-cuobjclient.h | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/include/miniocpp/nvidia-cuobjclient.h b/include/miniocpp/nvidia-cuobjclient.h index 1aa5a35d..e0a8432f 100644 --- a/include/miniocpp/nvidia-cuobjclient.h +++ b/include/miniocpp/nvidia-cuobjclient.h @@ -317,16 +317,21 @@ std::shared_ptr getSpan(std::shared_ptr &telem, std::string name); typedef struct s3_rdma_client_ctx { + // All members carry explicit in-class defaults so designated-initializer + // construction (e.g. `s3_rdma_client_ctx{.bucket=..., .op=...}`) does not + // trip -Wmissing-field-initializers for the std::string fields we leave + // unspecified at single-shot Put/Get call sites (uploadId/partNumber for + // non-multipart paths, etag/checksum for fields populated by the callee). minio::creds::Provider *const provider = nullptr; - std::string bucket; - std::string object; - std::string uploadId; + std::string bucket = {}; + std::string object = {}; + std::string uploadId = {}; size_t partNumber = 0; - std::string etag; - minio::s3::BaseUrl url; - std::string region; + std::string etag = {}; + minio::s3::BaseUrl url = {}; + std::string region = {}; cuObjOpType_t op = CUOBJ_INVALID; - std::string checksum; + std::string checksum = {}; } s3_rdma_client_ctx_t; #endif From bf6e19e37196b2d597e348ed1a10f8eca4505dd2 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 21 May 2026 14:12:14 -0700 Subject: [PATCH 17/25] rdma: drop vendored cpp-httplib, route control plane through curlpp MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Removes the ~10,700-line vendored copy of cpp-httplib (rdma-httplib.h) and rewrites rdmaPut / rdmaGet against minio::http::Request, which the rest of the SDK already uses (libcurl via curlpp). The protocol shape — Content-Length: 0 on the response body with the actual transferred byte count delivered via x-amz-rdma-bytes-transferred — is fully compatible with libcurl; the original httplib dependency was worked around an earlier protocol revision where Content-Length itself was abused to carry the transferred count without a body. While here, fix a latent correctness bug: rdmaGet was returning the caller-supplied size unconditionally and never reading x-amz-rdma-bytes-transferred, so ranged / partial-content GETs silently misreported actual bytes transferred. We now parse and return the server-reported count, falling back to the caller-supplied size only if the header is absent (older server). NIC pinning (CURLOPT_INTERFACE) and aggressive connect/read timeouts required by the control plane are exposed as new fields on http::Request so other call sites can reuse them. --- CMakeLists.txt | 1 - include/miniocpp/http.h | 13 + include/miniocpp/rdma-httplib.h | 10702 ------------------------------ include/miniocpp/rdma.h | 131 +- src/http.cc | 10 + 5 files changed, 91 insertions(+), 10766 deletions(-) delete mode 100644 include/miniocpp/rdma-httplib.h diff --git a/CMakeLists.txt b/CMakeLists.txt index 8cefd5fe..2d05240e 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -113,7 +113,6 @@ set(MINIO_CPP_HEADERS include/miniocpp/nvidia-cuobjclient.h include/miniocpp/providers.h include/miniocpp/rdma.h - include/miniocpp/rdma-httplib.h include/miniocpp/request.h include/miniocpp/response.h include/miniocpp/select.h diff --git a/include/miniocpp/http.h b/include/miniocpp/http.h index 433d8efb..91c0f24a 100644 --- a/include/miniocpp/http.h +++ b/include/miniocpp/http.h @@ -120,6 +120,19 @@ struct Request { std::string key_file; std::string cert_file; + // Pin the outbound socket to a specific interface or local IP via + // CURLOPT_INTERFACE. Used by the RDMA control plane to keep HTTP on the + // same NIC whose GID is embedded in the RDMA token, so the server's + // RDMA_READ has a healthy path back to that NIC. Empty == let kernel route. + std::string nic_interface; + + // Per-request connect/total timeout overrides in seconds. 0 == use libcurl + // defaults. Used by the RDMA control plane to fail fast on a dead NIC so + // the caller can retry (and pick up the failover NIC on the next attempt) + // instead of blocking on TCP's default ~75s SYN timeout. + long connect_timeout_secs = 0; + long timeout_secs = 0; + Request(Method method, Url url); ~Request() = default; diff --git a/include/miniocpp/rdma-httplib.h b/include/miniocpp/rdma-httplib.h deleted file mode 100644 index 2a5e027a..00000000 --- a/include/miniocpp/rdma-httplib.h +++ /dev/null @@ -1,10702 +0,0 @@ -// -// httplib.h -// -// Copyright (c) 2024 Yuji Hirose. All rights reserved. -// MIT License -// - -#ifndef CPPHTTPLIB_HTTPLIB_H -#define CPPHTTPLIB_HTTPLIB_H - -#define CPPHTTPLIB_VERSION "0.18.0" - -/* - * Configuration - */ - -#ifndef CPPHTTPLIB_KEEPALIVE_TIMEOUT_SECOND -#define CPPHTTPLIB_KEEPALIVE_TIMEOUT_SECOND 5 -#endif - -#ifndef CPPHTTPLIB_KEEPALIVE_MAX_COUNT -#define CPPHTTPLIB_KEEPALIVE_MAX_COUNT 100 -#endif - -#ifndef CPPHTTPLIB_CONNECTION_TIMEOUT_SECOND -#define CPPHTTPLIB_CONNECTION_TIMEOUT_SECOND 300 -#endif - -#ifndef CPPHTTPLIB_CONNECTION_TIMEOUT_USECOND -#define CPPHTTPLIB_CONNECTION_TIMEOUT_USECOND 0 -#endif - -#ifndef CPPHTTPLIB_SERVER_READ_TIMEOUT_SECOND -#define CPPHTTPLIB_SERVER_READ_TIMEOUT_SECOND 5 -#endif - -#ifndef CPPHTTPLIB_SERVER_READ_TIMEOUT_USECOND -#define CPPHTTPLIB_SERVER_READ_TIMEOUT_USECOND 0 -#endif - -#ifndef CPPHTTPLIB_SERVER_WRITE_TIMEOUT_SECOND -#define CPPHTTPLIB_SERVER_WRITE_TIMEOUT_SECOND 5 -#endif - -#ifndef CPPHTTPLIB_SERVER_WRITE_TIMEOUT_USECOND -#define CPPHTTPLIB_SERVER_WRITE_TIMEOUT_USECOND 0 -#endif - -#ifndef CPPHTTPLIB_CLIENT_READ_TIMEOUT_SECOND -#define CPPHTTPLIB_CLIENT_READ_TIMEOUT_SECOND 300 -#endif - -#ifndef CPPHTTPLIB_CLIENT_READ_TIMEOUT_USECOND -#define CPPHTTPLIB_CLIENT_READ_TIMEOUT_USECOND 0 -#endif - -#ifndef CPPHTTPLIB_CLIENT_WRITE_TIMEOUT_SECOND -#define CPPHTTPLIB_CLIENT_WRITE_TIMEOUT_SECOND 5 -#endif - -#ifndef CPPHTTPLIB_CLIENT_WRITE_TIMEOUT_USECOND -#define CPPHTTPLIB_CLIENT_WRITE_TIMEOUT_USECOND 0 -#endif - -#ifndef CPPHTTPLIB_IDLE_INTERVAL_SECOND -#define CPPHTTPLIB_IDLE_INTERVAL_SECOND 0 -#endif - -#ifndef CPPHTTPLIB_IDLE_INTERVAL_USECOND -#ifdef _WIN32 -#define CPPHTTPLIB_IDLE_INTERVAL_USECOND 10000 -#else -#define CPPHTTPLIB_IDLE_INTERVAL_USECOND 0 -#endif -#endif - -#ifndef CPPHTTPLIB_REQUEST_URI_MAX_LENGTH -#define CPPHTTPLIB_REQUEST_URI_MAX_LENGTH 8192 -#endif - -#ifndef CPPHTTPLIB_HEADER_MAX_LENGTH -#define CPPHTTPLIB_HEADER_MAX_LENGTH 8192 -#endif - -#ifndef CPPHTTPLIB_REDIRECT_MAX_COUNT -#define CPPHTTPLIB_REDIRECT_MAX_COUNT 20 -#endif - -#ifndef CPPHTTPLIB_MULTIPART_FORM_DATA_FILE_MAX_COUNT -#define CPPHTTPLIB_MULTIPART_FORM_DATA_FILE_MAX_COUNT 1024 -#endif - -#ifndef CPPHTTPLIB_PAYLOAD_MAX_LENGTH -#define CPPHTTPLIB_PAYLOAD_MAX_LENGTH ((std::numeric_limits::max)()) -#endif - -#ifndef CPPHTTPLIB_FORM_URL_ENCODED_PAYLOAD_MAX_LENGTH -#define CPPHTTPLIB_FORM_URL_ENCODED_PAYLOAD_MAX_LENGTH 8192 -#endif - -#ifndef CPPHTTPLIB_RANGE_MAX_COUNT -#define CPPHTTPLIB_RANGE_MAX_COUNT 1024 -#endif - -#ifndef CPPHTTPLIB_TCP_NODELAY -#define CPPHTTPLIB_TCP_NODELAY false -#endif - -#ifndef CPPHTTPLIB_IPV6_V6ONLY -#define CPPHTTPLIB_IPV6_V6ONLY false -#endif - -#ifndef CPPHTTPLIB_RECV_BUFSIZ -#define CPPHTTPLIB_RECV_BUFSIZ size_t(16384u) -#endif - -#ifndef CPPHTTPLIB_COMPRESSION_BUFSIZ -#define CPPHTTPLIB_COMPRESSION_BUFSIZ size_t(16384u) -#endif - -#ifndef CPPHTTPLIB_THREAD_POOL_COUNT -#define CPPHTTPLIB_THREAD_POOL_COUNT \ - ((std::max)(8u, std::thread::hardware_concurrency() > 0 \ - ? std::thread::hardware_concurrency() - 1 \ - : 0)) -#endif - -#ifndef CPPHTTPLIB_RECV_FLAGS -#define CPPHTTPLIB_RECV_FLAGS 0 -#endif - -#ifndef CPPHTTPLIB_SEND_FLAGS -#define CPPHTTPLIB_SEND_FLAGS 0 -#endif - -#ifndef CPPHTTPLIB_LISTEN_BACKLOG -#define CPPHTTPLIB_LISTEN_BACKLOG 5 -#endif - -/* - * Headers - */ - -#ifdef _WIN32 -#ifndef _CRT_SECURE_NO_WARNINGS -#define _CRT_SECURE_NO_WARNINGS -#endif //_CRT_SECURE_NO_WARNINGS - -#ifndef _CRT_NONSTDC_NO_DEPRECATE -#define _CRT_NONSTDC_NO_DEPRECATE -#endif //_CRT_NONSTDC_NO_DEPRECATE - -#if defined(_MSC_VER) -#if _MSC_VER < 1900 -#error Sorry, Visual Studio versions prior to 2015 are not supported -#endif - -#pragma comment(lib, "ws2_32.lib") - -#ifdef _WIN64 -using ssize_t = __int64; -#else -using ssize_t = long; -#endif -#endif // _MSC_VER - -#ifndef S_ISREG -#define S_ISREG(m) (((m) & S_IFREG) == S_IFREG) -#endif // S_ISREG - -#ifndef S_ISDIR -#define S_ISDIR(m) (((m) & S_IFDIR) == S_IFDIR) -#endif // S_ISDIR - -#ifndef NOMINMAX -#define NOMINMAX -#endif // NOMINMAX - -#include -#include -#include - -#ifndef WSA_FLAG_NO_HANDLE_INHERIT -#define WSA_FLAG_NO_HANDLE_INHERIT 0x80 -#endif - -using socket_t = SOCKET; -#ifdef CPPHTTPLIB_USE_POLL -#define poll(fds, nfds, timeout) WSAPoll(fds, nfds, timeout) -#endif - -#else // not _WIN32 - -#include -#if !defined(_AIX) && !defined(__MVS__) -#include -#endif -#ifdef __MVS__ -#include -#ifndef NI_MAXHOST -#define NI_MAXHOST 1025 -#endif -#endif -#include -#include -#include -#ifdef __linux__ -#include -#endif -#include -#ifdef CPPHTTPLIB_USE_POLL -#include -#endif -#include -#include -#include -#include -#include -#include - -#include - -using socket_t = int; -#ifndef INVALID_SOCKET -#define INVALID_SOCKET (-1) -#endif -#endif //_WIN32 - -#include -#include -#include - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -#ifdef _WIN32 -#include - -// these are defined in wincrypt.h and it breaks compilation if BoringSSL is -// used -#undef X509_NAME -#undef X509_CERT_PAIR -#undef X509_EXTENSIONS -#undef PKCS7_SIGNER_INFO - -#ifdef _MSC_VER -#pragma comment(lib, "crypt32.lib") -#endif -#elif defined(CPPHTTPLIB_USE_CERTS_FROM_MACOSX_KEYCHAIN) && defined(__APPLE__) -#include -#if TARGET_OS_OSX -#include -#include -#endif // TARGET_OS_OSX -#endif // _WIN32 - -#include -#include -#include -#include - -#if defined(_WIN32) && defined(OPENSSL_USE_APPLINK) -#include -#endif - -#include -#include - -#if defined(OPENSSL_IS_BORINGSSL) || defined(LIBRESSL_VERSION_NUMBER) -#if OPENSSL_VERSION_NUMBER < 0x1010107f -#error Please use OpenSSL or a current version of BoringSSL -#endif -#define SSL_get1_peer_certificate SSL_get_peer_certificate -#elif OPENSSL_VERSION_NUMBER < 0x30000000L -#error Sorry, OpenSSL versions prior to 3.0.0 are not supported -#endif - -#endif - -#ifdef CPPHTTPLIB_ZLIB_SUPPORT -#include -#endif - -#ifdef CPPHTTPLIB_BROTLI_SUPPORT -#include -#include -#endif - -/* - * Declaration - */ -namespace httplib { - -namespace detail { - -/* - * Backport std::make_unique from C++14. - * - * NOTE: This code came up with the following stackoverflow post: - * https://stackoverflow.com/questions/10149840/c-arrays-and-make-unique - * - */ - -template -typename std::enable_if::value, std::unique_ptr>::type -make_unique(Args &&...args) { - return std::unique_ptr(new T(std::forward(args)...)); -} - -template -typename std::enable_if::value, std::unique_ptr>::type -make_unique(std::size_t n) { - typedef typename std::remove_extent::type RT; - return std::unique_ptr(new RT[n]); -} - -namespace case_ignore { - -inline unsigned char to_lower(int c) { - const static unsigned char table[256] = { - 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, - 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, - 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, - 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, - 60, 61, 62, 63, 64, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, - 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, - 122, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, - 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, - 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, 134, - 135, 136, 137, 138, 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, - 150, 151, 152, 153, 154, 155, 156, 157, 158, 159, 160, 161, 162, 163, 164, - 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175, 176, 177, 178, 179, - 180, 181, 182, 183, 184, 185, 186, 187, 188, 189, 190, 191, 224, 225, 226, - 227, 228, 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, 240, 241, - 242, 243, 244, 245, 246, 215, 248, 249, 250, 251, 252, 253, 254, 223, 224, - 225, 226, 227, 228, 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, - 240, 241, 242, 243, 244, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254, - 255, - }; - return table[(unsigned char)(char)c]; -} - -inline bool equal(const std::string &a, const std::string &b) { - return a.size() == b.size() && - std::equal(a.begin(), a.end(), b.begin(), [](char ca, char cb) { - return to_lower(ca) == to_lower(cb); - }); -} - -struct equal_to { - bool operator()(const std::string &a, const std::string &b) const { - return equal(a, b); - } -}; - -struct hash { - size_t operator()(const std::string &key) const { - return hash_core(key.data(), key.size(), 0); - } - - size_t hash_core(const char *s, size_t l, size_t h) const { - return (l == 0) - ? h - : hash_core( - s + 1, l - 1, - // Unsets the 6 high bits of h, therefore no - // overflow happens - (((std::numeric_limits::max)() >> 6) & h * 33) ^ - static_cast(to_lower(*s))); - } -}; - -}; // namespace case_ignore - -// This is based on -// "http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2014/n4189". - -struct scope_exit { - explicit scope_exit(std::function &&f) - : exit_function(std::move(f)), execute_on_destruction{true} {} - - scope_exit(scope_exit &&rhs) noexcept - : exit_function(std::move(rhs.exit_function)), - execute_on_destruction{rhs.execute_on_destruction} { - rhs.release(); - } - - ~scope_exit() { - if (execute_on_destruction) { - this->exit_function(); - } - } - - void release() { this->execute_on_destruction = false; } - - private: - scope_exit(const scope_exit &) = delete; - void operator=(const scope_exit &) = delete; - scope_exit &operator=(scope_exit &&) = delete; - - std::function exit_function; - bool execute_on_destruction; -}; - -} // namespace detail - -enum StatusCode { - // Information responses - Continue_100 = 100, - SwitchingProtocol_101 = 101, - Processing_102 = 102, - EarlyHints_103 = 103, - - // Successful responses - OK_200 = 200, - Created_201 = 201, - Accepted_202 = 202, - NonAuthoritativeInformation_203 = 203, - NoContent_204 = 204, - ResetContent_205 = 205, - PartialContent_206 = 206, - MultiStatus_207 = 207, - AlreadyReported_208 = 208, - IMUsed_226 = 226, - - // Redirection messages - MultipleChoices_300 = 300, - MovedPermanently_301 = 301, - Found_302 = 302, - SeeOther_303 = 303, - NotModified_304 = 304, - UseProxy_305 = 305, - unused_306 = 306, - TemporaryRedirect_307 = 307, - PermanentRedirect_308 = 308, - - // Client error responses - BadRequest_400 = 400, - Unauthorized_401 = 401, - PaymentRequired_402 = 402, - Forbidden_403 = 403, - NotFound_404 = 404, - MethodNotAllowed_405 = 405, - NotAcceptable_406 = 406, - ProxyAuthenticationRequired_407 = 407, - RequestTimeout_408 = 408, - Conflict_409 = 409, - Gone_410 = 410, - LengthRequired_411 = 411, - PreconditionFailed_412 = 412, - PayloadTooLarge_413 = 413, - UriTooLong_414 = 414, - UnsupportedMediaType_415 = 415, - RangeNotSatisfiable_416 = 416, - ExpectationFailed_417 = 417, - ImATeapot_418 = 418, - MisdirectedRequest_421 = 421, - UnprocessableContent_422 = 422, - Locked_423 = 423, - FailedDependency_424 = 424, - TooEarly_425 = 425, - UpgradeRequired_426 = 426, - PreconditionRequired_428 = 428, - TooManyRequests_429 = 429, - RequestHeaderFieldsTooLarge_431 = 431, - UnavailableForLegalReasons_451 = 451, - - // Server error responses - InternalServerError_500 = 500, - NotImplemented_501 = 501, - BadGateway_502 = 502, - ServiceUnavailable_503 = 503, - GatewayTimeout_504 = 504, - HttpVersionNotSupported_505 = 505, - VariantAlsoNegotiates_506 = 506, - InsufficientStorage_507 = 507, - LoopDetected_508 = 508, - NotExtended_510 = 510, - NetworkAuthenticationRequired_511 = 511, -}; - -using Headers = - std::unordered_multimap; - -using Params = std::multimap; -using Match = std::smatch; - -using Progress = std::function; - -struct Response; -using ResponseHandler = std::function; - -struct MultipartFormData { - std::string name; - std::string content; - std::string filename; - std::string content_type; -}; -using MultipartFormDataItems = std::vector; -using MultipartFormDataMap = std::multimap; - -class DataSink { - public: - DataSink() : os(&sb_), sb_(*this) {} - - DataSink(const DataSink &) = delete; - DataSink &operator=(const DataSink &) = delete; - DataSink(DataSink &&) = delete; - DataSink &operator=(DataSink &&) = delete; - - std::function write; - std::function is_writable; - std::function done; - std::function done_with_trailer; - std::ostream os; - - private: - class data_sink_streambuf final : public std::streambuf { - public: - explicit data_sink_streambuf(DataSink &sink) : sink_(sink) {} - - protected: - std::streamsize xsputn(const char *s, std::streamsize n) override { - sink_.write(s, static_cast(n)); - return n; - } - - private: - DataSink &sink_; - }; - - data_sink_streambuf sb_; -}; - -using ContentProvider = - std::function; - -using ContentProviderWithoutLength = - std::function; - -using ContentProviderResourceReleaser = std::function; - -struct MultipartFormDataProvider { - std::string name; - ContentProviderWithoutLength provider; - std::string filename; - std::string content_type; -}; -using MultipartFormDataProviderItems = std::vector; - -using ContentReceiverWithProgress = - std::function; - -using ContentReceiver = - std::function; - -using MultipartContentHeader = - std::function; - -class ContentReader { - public: - using Reader = std::function; - using MultipartReader = std::function; - - ContentReader(Reader reader, MultipartReader multipart_reader) - : reader_(std::move(reader)), - multipart_reader_(std::move(multipart_reader)) {} - - bool operator()(MultipartContentHeader header, - ContentReceiver receiver) const { - return multipart_reader_(std::move(header), std::move(receiver)); - } - - bool operator()(ContentReceiver receiver) const { - return reader_(std::move(receiver)); - } - - Reader reader_; - MultipartReader multipart_reader_; -}; - -using Range = std::pair; -using Ranges = std::vector; - -struct Request { - std::string method; - std::string path; - Headers headers; - std::string body; - - std::string remote_addr; - int remote_port = -1; - std::string local_addr; - int local_port = -1; - - // for server - std::string version; - std::string target; - Params params; - MultipartFormDataMap files; - Ranges ranges; - Match matches; - std::unordered_map path_params; - - // for client - ResponseHandler response_handler; - ContentReceiverWithProgress content_receiver; - Progress progress; -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - const SSL *ssl = nullptr; -#endif - - bool has_header(const std::string &key) const; - std::string get_header_value(const std::string &key, const char *def = "", - size_t id = 0) const; - uint64_t get_header_value_u64(const std::string &key, uint64_t def = 0, - size_t id = 0) const; - size_t get_header_value_count(const std::string &key) const; - void set_header(const std::string &key, const std::string &val); - - bool has_param(const std::string &key) const; - std::string get_param_value(const std::string &key, size_t id = 0) const; - size_t get_param_value_count(const std::string &key) const; - - bool is_multipart_form_data() const; - - bool has_file(const std::string &key) const; - MultipartFormData get_file_value(const std::string &key) const; - std::vector get_file_values(const std::string &key) const; - - // private members... - size_t redirect_count_ = CPPHTTPLIB_REDIRECT_MAX_COUNT; - size_t content_length_ = 0; - ContentProvider content_provider_; - bool is_chunked_content_provider_ = false; - size_t authorization_count_ = 0; -}; - -struct Response { - std::string version; - int status = -1; - std::string reason; - Headers headers; - std::string body; - std::string location; // Redirect location - - bool has_header(const std::string &key) const; - std::string get_header_value(const std::string &key, const char *def = "", - size_t id = 0) const; - uint64_t get_header_value_u64(const std::string &key, uint64_t def = 0, - size_t id = 0) const; - size_t get_header_value_count(const std::string &key) const; - void set_header(const std::string &key, const std::string &val); - - void set_redirect(const std::string &url, int status = StatusCode::Found_302); - void set_content(const char *s, size_t n, const std::string &content_type); - void set_content(const std::string &s, const std::string &content_type); - void set_content(std::string &&s, const std::string &content_type); - - void set_content_provider( - size_t length, const std::string &content_type, ContentProvider provider, - ContentProviderResourceReleaser resource_releaser = nullptr); - - void set_content_provider( - const std::string &content_type, ContentProviderWithoutLength provider, - ContentProviderResourceReleaser resource_releaser = nullptr); - - void set_chunked_content_provider( - const std::string &content_type, ContentProviderWithoutLength provider, - ContentProviderResourceReleaser resource_releaser = nullptr); - - void set_file_content(const std::string &path, - const std::string &content_type); - void set_file_content(const std::string &path); - - Response() = default; - Response(const Response &) = default; - Response &operator=(const Response &) = default; - Response(Response &&) = default; - Response &operator=(Response &&) = default; - ~Response() { - if (content_provider_resource_releaser_) { - content_provider_resource_releaser_(content_provider_success_); - } - } - - // private members... - size_t content_length_ = 0; - ContentProvider content_provider_; - ContentProviderResourceReleaser content_provider_resource_releaser_; - bool is_chunked_content_provider_ = false; - bool content_provider_success_ = false; - std::string file_content_path_; - std::string file_content_content_type_; -}; - -class Stream { - public: - virtual ~Stream() = default; - - virtual bool is_readable() const = 0; - virtual bool is_writable() const = 0; - - virtual ssize_t read(char *ptr, size_t size) = 0; - virtual ssize_t write(const char *ptr, size_t size) = 0; - virtual void get_remote_ip_and_port(std::string &ip, int &port) const = 0; - virtual void get_local_ip_and_port(std::string &ip, int &port) const = 0; - virtual socket_t socket() const = 0; - - ssize_t write(const char *ptr); - ssize_t write(const std::string &s); -}; - -class TaskQueue { - public: - TaskQueue() = default; - virtual ~TaskQueue() = default; - - virtual bool enqueue(std::function fn) = 0; - virtual void shutdown() = 0; - - virtual void on_idle() {} -}; - -class ThreadPool final : public TaskQueue { - public: - explicit ThreadPool(size_t n, size_t mqr = 0) - : shutdown_(false), max_queued_requests_(mqr) { - while (n) { - threads_.emplace_back(worker(*this)); - n--; - } - } - - ThreadPool(const ThreadPool &) = delete; - ~ThreadPool() override = default; - - bool enqueue(std::function fn) override { - { - std::unique_lock lock(mutex_); - if (max_queued_requests_ > 0 && jobs_.size() >= max_queued_requests_) { - return false; - } - jobs_.push_back(std::move(fn)); - } - - cond_.notify_one(); - return true; - } - - void shutdown() override { - // Stop all worker threads... - { - std::unique_lock lock(mutex_); - shutdown_ = true; - } - - cond_.notify_all(); - - // Join... - for (auto &t : threads_) { - t.join(); - } - } - - private: - struct worker { - explicit worker(ThreadPool &pool) : pool_(pool) {} - - void operator()() { - for (;;) { - std::function fn; - { - std::unique_lock lock(pool_.mutex_); - - pool_.cond_.wait( - lock, [&] { return !pool_.jobs_.empty() || pool_.shutdown_; }); - - if (pool_.shutdown_ && pool_.jobs_.empty()) { - break; - } - - fn = pool_.jobs_.front(); - pool_.jobs_.pop_front(); - } - - assert(true == static_cast(fn)); - fn(); - } - -#if defined(CPPHTTPLIB_OPENSSL_SUPPORT) && !defined(OPENSSL_IS_BORINGSSL) && \ - !defined(LIBRESSL_VERSION_NUMBER) - OPENSSL_thread_stop(); -#endif - } - - ThreadPool &pool_; - }; - friend struct worker; - - std::vector threads_; - std::list> jobs_; - - bool shutdown_; - size_t max_queued_requests_ = 0; - - std::condition_variable cond_; - std::mutex mutex_; -}; - -using Logger = std::function; - -using SocketOptions = std::function; - -void default_socket_options(socket_t sock); - -const char *status_message(int status); - -std::string get_bearer_token_auth(const Request &req); - -namespace detail { - -class MatcherBase { - public: - virtual ~MatcherBase() = default; - - // Match request path and populate its matches and - virtual bool match(Request &request) const = 0; -}; - -/** - * Captures parameters in request path and stores them in Request::path_params - * - * Capture name is a substring of a pattern from : to /. - * The rest of the pattern is matched agains the request path directly - * Parameters are captured starting from the next character after - * the end of the last matched static pattern fragment until the next /. - * - * Example pattern: - * "/path/fragments/:capture/more/fragments/:second_capture" - * Static fragments: - * "/path/fragments/", "more/fragments/" - * - * Given the following request path: - * "/path/fragments/:1/more/fragments/:2" - * the resulting capture will be - * {{"capture", "1"}, {"second_capture", "2"}} - */ -class PathParamsMatcher final : public MatcherBase { - public: - PathParamsMatcher(const std::string &pattern); - - bool match(Request &request) const override; - - private: - // Treat segment separators as the end of path parameter capture - // Does not need to handle query parameters as they are parsed before path - // matching - static constexpr char separator = '/'; - - // Contains static path fragments to match against, excluding the '/' after - // path params - // Fragments are separated by path params - std::vector static_fragments_; - // Stores the names of the path parameters to be used as keys in the - // Request::path_params map - std::vector param_names_; -}; - -/** - * Performs std::regex_match on request path - * and stores the result in Request::matches - * - * Note that regex match is performed directly on the whole request. - * This means that wildcard patterns may match multiple path segments with /: - * "/begin/(.*)/end" will match both "/begin/middle/end" and "/begin/1/2/end". - */ -class RegexMatcher final : public MatcherBase { - public: - RegexMatcher(const std::string &pattern) : regex_(pattern) {} - - bool match(Request &request) const override; - - private: - std::regex regex_; -}; - -ssize_t write_headers(Stream &strm, const Headers &headers); - -} // namespace detail - -class Server { - public: - using Handler = std::function; - - using ExceptionHandler = - std::function; - - enum class HandlerResponse { - Handled, - Unhandled, - }; - using HandlerWithResponse = - std::function; - - using HandlerWithContentReader = std::function; - - using Expect100ContinueHandler = - std::function; - - Server(); - - virtual ~Server(); - - virtual bool is_valid() const; - - Server &Get(const std::string &pattern, Handler handler); - Server &Post(const std::string &pattern, Handler handler); - Server &Post(const std::string &pattern, HandlerWithContentReader handler); - Server &Put(const std::string &pattern, Handler handler); - Server &Put(const std::string &pattern, HandlerWithContentReader handler); - Server &Patch(const std::string &pattern, Handler handler); - Server &Patch(const std::string &pattern, HandlerWithContentReader handler); - Server &Delete(const std::string &pattern, Handler handler); - Server &Delete(const std::string &pattern, HandlerWithContentReader handler); - Server &Options(const std::string &pattern, Handler handler); - - bool set_base_dir(const std::string &dir, - const std::string &mount_point = std::string()); - bool set_mount_point(const std::string &mount_point, const std::string &dir, - Headers headers = Headers()); - bool remove_mount_point(const std::string &mount_point); - Server &set_file_extension_and_mimetype_mapping(const std::string &ext, - const std::string &mime); - Server &set_default_file_mimetype(const std::string &mime); - Server &set_file_request_handler(Handler handler); - - template - Server &set_error_handler(ErrorHandlerFunc &&handler) { - return set_error_handler_core( - std::forward(handler), - std::is_convertible{}); - } - - Server &set_exception_handler(ExceptionHandler handler); - Server &set_pre_routing_handler(HandlerWithResponse handler); - Server &set_post_routing_handler(Handler handler); - - Server &set_expect_100_continue_handler(Expect100ContinueHandler handler); - Server &set_logger(Logger logger); - - Server &set_address_family(int family); - Server &set_tcp_nodelay(bool on); - Server &set_ipv6_v6only(bool on); - Server &set_socket_options(SocketOptions socket_options); - - Server &set_default_headers(Headers headers); - Server &set_header_writer( - std::function const &writer); - - Server &set_keep_alive_max_count(size_t count); - Server &set_keep_alive_timeout(time_t sec); - - Server &set_read_timeout(time_t sec, time_t usec = 0); - template - Server &set_read_timeout(const std::chrono::duration &duration); - - Server &set_write_timeout(time_t sec, time_t usec = 0); - template - Server &set_write_timeout(const std::chrono::duration &duration); - - Server &set_idle_interval(time_t sec, time_t usec = 0); - template - Server &set_idle_interval(const std::chrono::duration &duration); - - Server &set_payload_max_length(size_t length); - - bool bind_to_port(const std::string &host, int port, int socket_flags = 0); - int bind_to_any_port(const std::string &host, int socket_flags = 0); - bool listen_after_bind(); - - bool listen(const std::string &host, int port, int socket_flags = 0); - - bool is_running() const; - void wait_until_ready() const; - void stop(); - void decommission(); - - std::function new_task_queue; - - protected: - bool process_request(Stream &strm, const std::string &remote_addr, - int remote_port, const std::string &local_addr, - int local_port, bool close_connection, - bool &connection_closed, - const std::function &setup_request); - - std::atomic svr_sock_{INVALID_SOCKET}; - size_t keep_alive_max_count_ = CPPHTTPLIB_KEEPALIVE_MAX_COUNT; - time_t keep_alive_timeout_sec_ = CPPHTTPLIB_KEEPALIVE_TIMEOUT_SECOND; - time_t read_timeout_sec_ = CPPHTTPLIB_SERVER_READ_TIMEOUT_SECOND; - time_t read_timeout_usec_ = CPPHTTPLIB_SERVER_READ_TIMEOUT_USECOND; - time_t write_timeout_sec_ = CPPHTTPLIB_SERVER_WRITE_TIMEOUT_SECOND; - time_t write_timeout_usec_ = CPPHTTPLIB_SERVER_WRITE_TIMEOUT_USECOND; - time_t idle_interval_sec_ = CPPHTTPLIB_IDLE_INTERVAL_SECOND; - time_t idle_interval_usec_ = CPPHTTPLIB_IDLE_INTERVAL_USECOND; - size_t payload_max_length_ = CPPHTTPLIB_PAYLOAD_MAX_LENGTH; - - private: - using Handlers = - std::vector, Handler>>; - using HandlersForContentReader = - std::vector, - HandlerWithContentReader>>; - - static std::unique_ptr make_matcher( - const std::string &pattern); - - Server &set_error_handler_core(HandlerWithResponse handler, std::true_type); - Server &set_error_handler_core(Handler handler, std::false_type); - - socket_t create_server_socket(const std::string &host, int port, - int socket_flags, - SocketOptions socket_options) const; - int bind_internal(const std::string &host, int port, int socket_flags); - bool listen_internal(); - - bool routing(Request &req, Response &res, Stream &strm); - bool handle_file_request(const Request &req, Response &res, - bool head = false); - bool dispatch_request(Request &req, Response &res, - const Handlers &handlers) const; - bool dispatch_request_for_content_reader( - Request &req, Response &res, ContentReader content_reader, - const HandlersForContentReader &handlers) const; - - bool parse_request_line(const char *s, Request &req) const; - void apply_ranges(const Request &req, Response &res, - std::string &content_type, std::string &boundary) const; - bool write_response(Stream &strm, bool close_connection, Request &req, - Response &res); - bool write_response_with_content(Stream &strm, bool close_connection, - const Request &req, Response &res); - bool write_response_core(Stream &strm, bool close_connection, - const Request &req, Response &res, - bool need_apply_ranges); - bool write_content_with_provider(Stream &strm, const Request &req, - Response &res, const std::string &boundary, - const std::string &content_type); - bool read_content(Stream &strm, Request &req, Response &res); - bool read_content_with_content_receiver( - Stream &strm, Request &req, Response &res, ContentReceiver receiver, - MultipartContentHeader multipart_header, - ContentReceiver multipart_receiver); - bool read_content_core(Stream &strm, Request &req, Response &res, - ContentReceiver receiver, - MultipartContentHeader multipart_header, - ContentReceiver multipart_receiver) const; - - virtual bool process_and_close_socket(socket_t sock); - - std::atomic is_running_{false}; - std::atomic is_decommisioned{false}; - - struct MountPointEntry { - std::string mount_point; - std::string base_dir; - Headers headers; - }; - std::vector base_dirs_; - std::map file_extension_and_mimetype_map_; - std::string default_file_mimetype_ = "application/octet-stream"; - Handler file_request_handler_; - - Handlers get_handlers_; - Handlers post_handlers_; - HandlersForContentReader post_handlers_for_content_reader_; - Handlers put_handlers_; - HandlersForContentReader put_handlers_for_content_reader_; - Handlers patch_handlers_; - HandlersForContentReader patch_handlers_for_content_reader_; - Handlers delete_handlers_; - HandlersForContentReader delete_handlers_for_content_reader_; - Handlers options_handlers_; - - HandlerWithResponse error_handler_; - ExceptionHandler exception_handler_; - HandlerWithResponse pre_routing_handler_; - Handler post_routing_handler_; - Expect100ContinueHandler expect_100_continue_handler_; - - Logger logger_; - - int address_family_ = AF_UNSPEC; - bool tcp_nodelay_ = CPPHTTPLIB_TCP_NODELAY; - bool ipv6_v6only_ = CPPHTTPLIB_IPV6_V6ONLY; - SocketOptions socket_options_ = default_socket_options; - - Headers default_headers_; - std::function header_writer_ = - detail::write_headers; -}; - -enum class Error { - Success = 0, - Unknown, - Connection, - BindIPAddress, - Read, - Write, - ExceedRedirectCount, - Canceled, - SSLConnection, - SSLLoadingCerts, - SSLServerVerification, - SSLServerHostnameVerification, - UnsupportedMultipartBoundaryChars, - Compression, - ConnectionTimeout, - ProxyConnection, - - // For internal use only - SSLPeerCouldBeClosed_, -}; - -std::string to_string(Error error); - -std::ostream &operator<<(std::ostream &os, const Error &obj); - -class Result { - public: - Result() = default; - Result(std::unique_ptr &&res, Error err, - Headers &&request_headers = Headers{}) - : res_(std::move(res)), - err_(err), - request_headers_(std::move(request_headers)) {} - // Response - operator bool() const { return res_ != nullptr; } - bool operator==(std::nullptr_t) const { return res_ == nullptr; } - bool operator!=(std::nullptr_t) const { return res_ != nullptr; } - const Response &value() const { return *res_; } - Response &value() { return *res_; } - const Response &operator*() const { return *res_; } - Response &operator*() { return *res_; } - const Response *operator->() const { return res_.get(); } - Response *operator->() { return res_.get(); } - - // Error - Error error() const { return err_; } - - // Request Headers - bool has_request_header(const std::string &key) const; - std::string get_request_header_value(const std::string &key, - const char *def = "", - size_t id = 0) const; - uint64_t get_request_header_value_u64(const std::string &key, - uint64_t def = 0, size_t id = 0) const; - size_t get_request_header_value_count(const std::string &key) const; - - private: - std::unique_ptr res_; - Error err_ = Error::Unknown; - Headers request_headers_; -}; - -class ClientImpl { - public: - explicit ClientImpl(const std::string &host); - - explicit ClientImpl(const std::string &host, int port); - - explicit ClientImpl(const std::string &host, int port, - const std::string &client_cert_path, - const std::string &client_key_path); - - virtual ~ClientImpl(); - - virtual bool is_valid() const; - - Result Get(const std::string &path); - Result Get(const std::string &path, const Headers &headers); - Result Get(const std::string &path, Progress progress); - Result Get(const std::string &path, const Headers &headers, - Progress progress); - Result Get(const std::string &path, ContentReceiver content_receiver); - Result Get(const std::string &path, const Headers &headers, - ContentReceiver content_receiver); - Result Get(const std::string &path, ContentReceiver content_receiver, - Progress progress); - Result Get(const std::string &path, const Headers &headers, - ContentReceiver content_receiver, Progress progress); - Result Get(const std::string &path, ResponseHandler response_handler, - ContentReceiver content_receiver); - Result Get(const std::string &path, const Headers &headers, - ResponseHandler response_handler, - ContentReceiver content_receiver); - Result Get(const std::string &path, ResponseHandler response_handler, - ContentReceiver content_receiver, Progress progress); - Result Get(const std::string &path, const Headers &headers, - ResponseHandler response_handler, ContentReceiver content_receiver, - Progress progress); - - Result Get(const std::string &path, const Params ¶ms, - const Headers &headers, Progress progress = nullptr); - Result Get(const std::string &path, const Params ¶ms, - const Headers &headers, ContentReceiver content_receiver, - Progress progress = nullptr); - Result Get(const std::string &path, const Params ¶ms, - const Headers &headers, ResponseHandler response_handler, - ContentReceiver content_receiver, Progress progress = nullptr); - - Result Head(const std::string &path); - Result Head(const std::string &path, const Headers &headers); - - Result Post(const std::string &path); - Result Post(const std::string &path, const Headers &headers); - Result Post(const std::string &path, const char *body, size_t content_length, - const std::string &content_type); - Result Post(const std::string &path, const Headers &headers, const char *body, - size_t content_length, const std::string &content_type); - Result Post(const std::string &path, const Headers &headers, const char *body, - size_t content_length, const std::string &content_type, - Progress progress); - Result Post(const std::string &path, const std::string &body, - const std::string &content_type); - Result Post(const std::string &path, const std::string &body, - const std::string &content_type, Progress progress); - Result Post(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type); - Result Post(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type, - Progress progress); - Result Post(const std::string &path, size_t content_length, - ContentProvider content_provider, - const std::string &content_type); - Result Post(const std::string &path, - ContentProviderWithoutLength content_provider, - const std::string &content_type); - Result Post(const std::string &path, const Headers &headers, - size_t content_length, ContentProvider content_provider, - const std::string &content_type); - Result Post(const std::string &path, const Headers &headers, - ContentProviderWithoutLength content_provider, - const std::string &content_type); - Result Post(const std::string &path, const Params ¶ms); - Result Post(const std::string &path, const Headers &headers, - const Params ¶ms); - Result Post(const std::string &path, const Headers &headers, - const Params ¶ms, Progress progress); - Result Post(const std::string &path, const MultipartFormDataItems &items); - Result Post(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items); - Result Post(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, const std::string &boundary); - Result Post(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items); - - Result Put(const std::string &path); - Result Put(const std::string &path, const char *body, size_t content_length, - const std::string &content_type); - Result Put(const std::string &path, const Headers &headers, const char *body, - size_t content_length, const std::string &content_type); - Result Put(const std::string &path, const Headers &headers, const char *body, - size_t content_length, const std::string &content_type, - Progress progress); - Result Put(const std::string &path, const std::string &body, - const std::string &content_type); - Result Put(const std::string &path, const std::string &body, - const std::string &content_type, Progress progress); - Result Put(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type); - Result Put(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type, - Progress progress); - Result Put(const std::string &path, size_t content_length, - ContentProvider content_provider, const std::string &content_type); - Result Put(const std::string &path, - ContentProviderWithoutLength content_provider, - const std::string &content_type); - Result Put(const std::string &path, const Headers &headers, - size_t content_length, ContentProvider content_provider, - const std::string &content_type); - Result Put(const std::string &path, const Headers &headers, - ContentProviderWithoutLength content_provider, - const std::string &content_type); - Result Put(const std::string &path, const Params ¶ms); - Result Put(const std::string &path, const Headers &headers, - const Params ¶ms); - Result Put(const std::string &path, const Headers &headers, - const Params ¶ms, Progress progress); - Result Put(const std::string &path, const MultipartFormDataItems &items); - Result Put(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items); - Result Put(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, const std::string &boundary); - Result Put(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items); - - Result Patch(const std::string &path); - Result Patch(const std::string &path, const char *body, size_t content_length, - const std::string &content_type); - Result Patch(const std::string &path, const char *body, size_t content_length, - const std::string &content_type, Progress progress); - Result Patch(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type); - Result Patch(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type, Progress progress); - Result Patch(const std::string &path, const std::string &body, - const std::string &content_type); - Result Patch(const std::string &path, const std::string &body, - const std::string &content_type, Progress progress); - Result Patch(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type); - Result Patch(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type, - Progress progress); - Result Patch(const std::string &path, size_t content_length, - ContentProvider content_provider, - const std::string &content_type); - Result Patch(const std::string &path, - ContentProviderWithoutLength content_provider, - const std::string &content_type); - Result Patch(const std::string &path, const Headers &headers, - size_t content_length, ContentProvider content_provider, - const std::string &content_type); - Result Patch(const std::string &path, const Headers &headers, - ContentProviderWithoutLength content_provider, - const std::string &content_type); - - Result Delete(const std::string &path); - Result Delete(const std::string &path, const Headers &headers); - Result Delete(const std::string &path, const char *body, - size_t content_length, const std::string &content_type); - Result Delete(const std::string &path, const char *body, - size_t content_length, const std::string &content_type, - Progress progress); - Result Delete(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type); - Result Delete(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type, Progress progress); - Result Delete(const std::string &path, const std::string &body, - const std::string &content_type); - Result Delete(const std::string &path, const std::string &body, - const std::string &content_type, Progress progress); - Result Delete(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type); - Result Delete(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type, - Progress progress); - - Result Options(const std::string &path); - Result Options(const std::string &path, const Headers &headers); - - bool send(Request &req, Response &res, Error &error); - Result send(const Request &req); - - void stop(); - - std::string host() const; - int port() const; - - size_t is_socket_open() const; - socket_t socket() const; - - void set_hostname_addr_map(std::map addr_map); - - void set_default_headers(Headers headers); - - void set_header_writer( - std::function const &writer); - - void set_address_family(int family); - void set_tcp_nodelay(bool on); - void set_ipv6_v6only(bool on); - void set_socket_options(SocketOptions socket_options); - - void set_connection_timeout(time_t sec, time_t usec = 0); - template - void set_connection_timeout( - const std::chrono::duration &duration); - - void set_read_timeout(time_t sec, time_t usec = 0); - template - void set_read_timeout(const std::chrono::duration &duration); - - void set_write_timeout(time_t sec, time_t usec = 0); - template - void set_write_timeout(const std::chrono::duration &duration); - - void set_basic_auth(const std::string &username, const std::string &password); - void set_bearer_token_auth(const std::string &token); -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - void set_digest_auth(const std::string &username, - const std::string &password); -#endif - - void set_keep_alive(bool on); - void set_follow_location(bool on); - - void set_url_encode(bool on); - - void set_compress(bool on); - - void set_decompress(bool on); - - void set_interface(const std::string &intf); - - void set_proxy(const std::string &host, int port); - void set_proxy_basic_auth(const std::string &username, - const std::string &password); - void set_proxy_bearer_token_auth(const std::string &token); -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - void set_proxy_digest_auth(const std::string &username, - const std::string &password); -#endif - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - void set_ca_cert_path(const std::string &ca_cert_file_path, - const std::string &ca_cert_dir_path = std::string()); - void set_ca_cert_store(X509_STORE *ca_cert_store); - X509_STORE *create_ca_cert_store(const char *ca_cert, std::size_t size) const; -#endif - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - void enable_server_certificate_verification(bool enabled); - void enable_server_hostname_verification(bool enabled); - void set_server_certificate_verifier(std::function verifier); -#endif - - void set_logger(Logger logger); - - protected: - struct Socket { - socket_t sock = INVALID_SOCKET; -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - SSL *ssl = nullptr; -#endif - - bool is_open() const { return sock != INVALID_SOCKET; } - }; - - virtual bool create_and_connect_socket(Socket &socket, Error &error); - - // All of: - // shutdown_ssl - // shutdown_socket - // close_socket - // should ONLY be called when socket_mutex_ is locked. - // Also, shutdown_ssl and close_socket should also NOT be called concurrently - // with a DIFFERENT thread sending requests using that socket. - virtual void shutdown_ssl(Socket &socket, bool shutdown_gracefully); - void shutdown_socket(Socket &socket) const; - void close_socket(Socket &socket); - - bool process_request(Stream &strm, Request &req, Response &res, - bool close_connection, Error &error); - - bool write_content_with_provider(Stream &strm, const Request &req, - Error &error) const; - - void copy_settings(const ClientImpl &rhs); - - // Socket endpoint information - const std::string host_; - const int port_; - const std::string host_and_port_; - - // Current open socket - Socket socket_; - mutable std::mutex socket_mutex_; - std::recursive_mutex request_mutex_; - - // These are all protected under socket_mutex - size_t socket_requests_in_flight_ = 0; - std::thread::id socket_requests_are_from_thread_ = std::thread::id(); - bool socket_should_be_closed_when_request_is_done_ = false; - - // Hostname-IP map - std::map addr_map_; - - // Default headers - Headers default_headers_; - - // Header writer - std::function header_writer_ = - detail::write_headers; - - // Settings - std::string client_cert_path_; - std::string client_key_path_; - - time_t connection_timeout_sec_ = CPPHTTPLIB_CONNECTION_TIMEOUT_SECOND; - time_t connection_timeout_usec_ = CPPHTTPLIB_CONNECTION_TIMEOUT_USECOND; - time_t read_timeout_sec_ = CPPHTTPLIB_CLIENT_READ_TIMEOUT_SECOND; - time_t read_timeout_usec_ = CPPHTTPLIB_CLIENT_READ_TIMEOUT_USECOND; - time_t write_timeout_sec_ = CPPHTTPLIB_CLIENT_WRITE_TIMEOUT_SECOND; - time_t write_timeout_usec_ = CPPHTTPLIB_CLIENT_WRITE_TIMEOUT_USECOND; - - std::string basic_auth_username_; - std::string basic_auth_password_; - std::string bearer_token_auth_token_; -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - std::string digest_auth_username_; - std::string digest_auth_password_; -#endif - - bool keep_alive_ = false; - bool follow_location_ = false; - - bool url_encode_ = true; - - int address_family_ = AF_UNSPEC; - bool tcp_nodelay_ = CPPHTTPLIB_TCP_NODELAY; - bool ipv6_v6only_ = CPPHTTPLIB_IPV6_V6ONLY; - SocketOptions socket_options_ = nullptr; - - bool compress_ = false; - bool decompress_ = true; - - std::string interface_; - - std::string proxy_host_; - int proxy_port_ = -1; - - std::string proxy_basic_auth_username_; - std::string proxy_basic_auth_password_; - std::string proxy_bearer_token_auth_token_; -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - std::string proxy_digest_auth_username_; - std::string proxy_digest_auth_password_; -#endif - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - std::string ca_cert_file_path_; - std::string ca_cert_dir_path_; - - X509_STORE *ca_cert_store_ = nullptr; -#endif - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - bool server_certificate_verification_ = true; - bool server_hostname_verification_ = true; - std::function server_certificate_verifier_; -#endif - - Logger logger_; - - private: - bool send_(Request &req, Response &res, Error &error); - Result send_(Request &&req); - - socket_t create_client_socket(Error &error) const; - bool read_response_line(Stream &strm, const Request &req, - Response &res) const; - bool write_request(Stream &strm, Request &req, bool close_connection, - Error &error); - bool redirect(Request &req, Response &res, Error &error); - bool handle_request(Stream &strm, Request &req, Response &res, - bool close_connection, Error &error); - std::unique_ptr send_with_content_provider( - Request &req, const char *body, size_t content_length, - ContentProvider content_provider, - ContentProviderWithoutLength content_provider_without_length, - const std::string &content_type, Error &error); - Result send_with_content_provider( - const std::string &method, const std::string &path, - const Headers &headers, const char *body, size_t content_length, - ContentProvider content_provider, - ContentProviderWithoutLength content_provider_without_length, - const std::string &content_type, Progress progress); - ContentProviderWithoutLength get_multipart_content_provider( - const std::string &boundary, const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items) const; - - std::string adjust_host_string(const std::string &host) const; - - virtual bool process_socket(const Socket &socket, - std::function callback); - virtual bool is_ssl() const; -}; - -class Client { - public: - // Universal interface - explicit Client(const std::string &scheme_host_port); - - explicit Client(const std::string &scheme_host_port, - const std::string &client_cert_path, - const std::string &client_key_path); - - // HTTP only interface - explicit Client(const std::string &host, int port); - - explicit Client(const std::string &host, int port, - const std::string &client_cert_path, - const std::string &client_key_path); - - Client(Client &&) = default; - Client &operator=(Client &&) = default; - - ~Client(); - - bool is_valid() const; - - Result Get(const std::string &path); - Result Get(const std::string &path, const Headers &headers); - Result Get(const std::string &path, Progress progress); - Result Get(const std::string &path, const Headers &headers, - Progress progress); - Result Get(const std::string &path, ContentReceiver content_receiver); - Result Get(const std::string &path, const Headers &headers, - ContentReceiver content_receiver); - Result Get(const std::string &path, ContentReceiver content_receiver, - Progress progress); - Result Get(const std::string &path, const Headers &headers, - ContentReceiver content_receiver, Progress progress); - Result Get(const std::string &path, ResponseHandler response_handler, - ContentReceiver content_receiver); - Result Get(const std::string &path, const Headers &headers, - ResponseHandler response_handler, - ContentReceiver content_receiver); - Result Get(const std::string &path, const Headers &headers, - ResponseHandler response_handler, ContentReceiver content_receiver, - Progress progress); - Result Get(const std::string &path, ResponseHandler response_handler, - ContentReceiver content_receiver, Progress progress); - - Result Get(const std::string &path, const Params ¶ms, - const Headers &headers, Progress progress = nullptr); - Result Get(const std::string &path, const Params ¶ms, - const Headers &headers, ContentReceiver content_receiver, - Progress progress = nullptr); - Result Get(const std::string &path, const Params ¶ms, - const Headers &headers, ResponseHandler response_handler, - ContentReceiver content_receiver, Progress progress = nullptr); - - Result Head(const std::string &path); - Result Head(const std::string &path, const Headers &headers); - - Result Post(const std::string &path); - Result Post(const std::string &path, const Headers &headers); - Result Post(const std::string &path, const char *body, size_t content_length, - const std::string &content_type); - Result Post(const std::string &path, const Headers &headers, const char *body, - size_t content_length, const std::string &content_type); - Result Post(const std::string &path, const Headers &headers, const char *body, - size_t content_length, const std::string &content_type, - Progress progress); - Result Post(const std::string &path, const std::string &body, - const std::string &content_type); - Result Post(const std::string &path, const std::string &body, - const std::string &content_type, Progress progress); - Result Post(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type); - Result Post(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type, - Progress progress); - Result Post(const std::string &path, size_t content_length, - ContentProvider content_provider, - const std::string &content_type); - Result Post(const std::string &path, - ContentProviderWithoutLength content_provider, - const std::string &content_type); - Result Post(const std::string &path, const Headers &headers, - size_t content_length, ContentProvider content_provider, - const std::string &content_type); - Result Post(const std::string &path, const Headers &headers, - ContentProviderWithoutLength content_provider, - const std::string &content_type); - Result Post(const std::string &path, const Params ¶ms); - Result Post(const std::string &path, const Headers &headers, - const Params ¶ms); - Result Post(const std::string &path, const Headers &headers, - const Params ¶ms, Progress progress); - Result Post(const std::string &path, const MultipartFormDataItems &items); - Result Post(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items); - Result Post(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, const std::string &boundary); - Result Post(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items); - - Result Put(const std::string &path); - Result Put(const std::string &path, const char *body, size_t content_length, - const std::string &content_type); - Result Put(const std::string &path, const Headers &headers, const char *body, - size_t content_length, const std::string &content_type); - Result Put(const std::string &path, const Headers &headers, const char *body, - size_t content_length, const std::string &content_type, - Progress progress); - Result Put(const std::string &path, const std::string &body, - const std::string &content_type); - Result Put(const std::string &path, const std::string &body, - const std::string &content_type, Progress progress); - Result Put(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type); - Result Put(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type, - Progress progress); - Result Put(const std::string &path, size_t content_length, - ContentProvider content_provider, const std::string &content_type); - Result Put(const std::string &path, - ContentProviderWithoutLength content_provider, - const std::string &content_type); - Result Put(const std::string &path, const Headers &headers, - size_t content_length, ContentProvider content_provider, - const std::string &content_type); - Result Put(const std::string &path, const Headers &headers, - ContentProviderWithoutLength content_provider, - const std::string &content_type); - Result Put(const std::string &path, const Params ¶ms); - Result Put(const std::string &path, const Headers &headers, - const Params ¶ms); - Result Put(const std::string &path, const Headers &headers, - const Params ¶ms, Progress progress); - Result Put(const std::string &path, const MultipartFormDataItems &items); - Result Put(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items); - Result Put(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, const std::string &boundary); - Result Put(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items); - - Result Patch(const std::string &path); - Result Patch(const std::string &path, const char *body, size_t content_length, - const std::string &content_type); - Result Patch(const std::string &path, const char *body, size_t content_length, - const std::string &content_type, Progress progress); - Result Patch(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type); - Result Patch(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type, Progress progress); - Result Patch(const std::string &path, const std::string &body, - const std::string &content_type); - Result Patch(const std::string &path, const std::string &body, - const std::string &content_type, Progress progress); - Result Patch(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type); - Result Patch(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type, - Progress progress); - Result Patch(const std::string &path, size_t content_length, - ContentProvider content_provider, - const std::string &content_type); - Result Patch(const std::string &path, - ContentProviderWithoutLength content_provider, - const std::string &content_type); - Result Patch(const std::string &path, const Headers &headers, - size_t content_length, ContentProvider content_provider, - const std::string &content_type); - Result Patch(const std::string &path, const Headers &headers, - ContentProviderWithoutLength content_provider, - const std::string &content_type); - - Result Delete(const std::string &path); - Result Delete(const std::string &path, const Headers &headers); - Result Delete(const std::string &path, const char *body, - size_t content_length, const std::string &content_type); - Result Delete(const std::string &path, const char *body, - size_t content_length, const std::string &content_type, - Progress progress); - Result Delete(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type); - Result Delete(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type, Progress progress); - Result Delete(const std::string &path, const std::string &body, - const std::string &content_type); - Result Delete(const std::string &path, const std::string &body, - const std::string &content_type, Progress progress); - Result Delete(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type); - Result Delete(const std::string &path, const Headers &headers, - const std::string &body, const std::string &content_type, - Progress progress); - - Result Options(const std::string &path); - Result Options(const std::string &path, const Headers &headers); - - bool send(Request &req, Response &res, Error &error); - Result send(const Request &req); - - void stop(); - - std::string host() const; - int port() const; - - size_t is_socket_open() const; - socket_t socket() const; - - void set_hostname_addr_map(std::map addr_map); - - void set_default_headers(Headers headers); - - void set_header_writer( - std::function const &writer); - - void set_address_family(int family); - void set_tcp_nodelay(bool on); - void set_socket_options(SocketOptions socket_options); - - void set_connection_timeout(time_t sec, time_t usec = 0); - template - void set_connection_timeout( - const std::chrono::duration &duration); - - void set_read_timeout(time_t sec, time_t usec = 0); - template - void set_read_timeout(const std::chrono::duration &duration); - - void set_write_timeout(time_t sec, time_t usec = 0); - template - void set_write_timeout(const std::chrono::duration &duration); - - void set_basic_auth(const std::string &username, const std::string &password); - void set_bearer_token_auth(const std::string &token); -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - void set_digest_auth(const std::string &username, - const std::string &password); -#endif - - void set_keep_alive(bool on); - void set_follow_location(bool on); - - void set_url_encode(bool on); - - void set_compress(bool on); - - void set_decompress(bool on); - - void set_interface(const std::string &intf); - - void set_proxy(const std::string &host, int port); - void set_proxy_basic_auth(const std::string &username, - const std::string &password); - void set_proxy_bearer_token_auth(const std::string &token); -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - void set_proxy_digest_auth(const std::string &username, - const std::string &password); -#endif - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - void enable_server_certificate_verification(bool enabled); - void enable_server_hostname_verification(bool enabled); - void set_server_certificate_verifier(std::function verifier); -#endif - - void set_logger(Logger logger); - - // SSL -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - void set_ca_cert_path(const std::string &ca_cert_file_path, - const std::string &ca_cert_dir_path = std::string()); - - void set_ca_cert_store(X509_STORE *ca_cert_store); - void load_ca_cert_store(const char *ca_cert, std::size_t size); - - long get_openssl_verify_result() const; - - SSL_CTX *ssl_context() const; -#endif - - private: - std::unique_ptr cli_; - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - bool is_ssl_ = false; -#endif -}; - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -class SSLServer : public Server { - public: - SSLServer(const char *cert_path, const char *private_key_path, - const char *client_ca_cert_file_path = nullptr, - const char *client_ca_cert_dir_path = nullptr, - const char *private_key_password = nullptr); - - SSLServer(X509 *cert, EVP_PKEY *private_key, - X509_STORE *client_ca_cert_store = nullptr); - - SSLServer( - const std::function &setup_ssl_ctx_callback); - - ~SSLServer() override; - - bool is_valid() const override; - - SSL_CTX *ssl_context() const; - - void update_certs(X509 *cert, EVP_PKEY *private_key, - X509_STORE *client_ca_cert_store = nullptr); - - private: - bool process_and_close_socket(socket_t sock) override; - - SSL_CTX *ctx_; - std::mutex ctx_mutex_; -}; - -class SSLClient final : public ClientImpl { - public: - explicit SSLClient(const std::string &host); - - explicit SSLClient(const std::string &host, int port); - - explicit SSLClient(const std::string &host, int port, - const std::string &client_cert_path, - const std::string &client_key_path, - const std::string &private_key_password = std::string()); - - explicit SSLClient(const std::string &host, int port, X509 *client_cert, - EVP_PKEY *client_key, - const std::string &private_key_password = std::string()); - - ~SSLClient() override; - - bool is_valid() const override; - - void set_ca_cert_store(X509_STORE *ca_cert_store); - void load_ca_cert_store(const char *ca_cert, std::size_t size); - - long get_openssl_verify_result() const; - - SSL_CTX *ssl_context() const; - - private: - bool create_and_connect_socket(Socket &socket, Error &error) override; - void shutdown_ssl(Socket &socket, bool shutdown_gracefully) override; - void shutdown_ssl_impl(Socket &socket, bool shutdown_gracefully); - - bool process_socket(const Socket &socket, - std::function callback) override; - bool is_ssl() const override; - - bool connect_with_proxy(Socket &sock, Response &res, bool &success, - Error &error); - bool initialize_ssl(Socket &socket, Error &error); - - bool load_certs(); - - bool verify_host(X509 *server_cert) const; - bool verify_host_with_subject_alt_name(X509 *server_cert) const; - bool verify_host_with_common_name(X509 *server_cert) const; - bool check_host_name(const char *pattern, size_t pattern_len) const; - - SSL_CTX *ctx_; - std::mutex ctx_mutex_; - std::once_flag initialize_cert_; - - std::vector host_components_; - - long verify_result_ = 0; - - friend class ClientImpl; -}; -#endif - -/* - * Implementation of template methods. - */ - -namespace detail { - -template -inline void duration_to_sec_and_usec(const T &duration, U callback) { - auto sec = std::chrono::duration_cast(duration).count(); - auto usec = std::chrono::duration_cast( - duration - std::chrono::seconds(sec)) - .count(); - callback(static_cast(sec), static_cast(usec)); -} - -inline uint64_t get_header_value_u64(const Headers &headers, - const std::string &key, uint64_t def, - size_t id) { - auto rng = headers.equal_range(key); - auto it = rng.first; - std::advance(it, static_cast(id)); - if (it != rng.second) { - return std::strtoull(it->second.data(), nullptr, 10); - } - return def; -} - -} // namespace detail - -inline uint64_t Request::get_header_value_u64(const std::string &key, - uint64_t def, size_t id) const { - return detail::get_header_value_u64(headers, key, def, id); -} - -inline uint64_t Response::get_header_value_u64(const std::string &key, - uint64_t def, size_t id) const { - return detail::get_header_value_u64(headers, key, def, id); -} - -inline void default_socket_options(socket_t sock) { - int opt = 1; -#ifdef _WIN32 - setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, - reinterpret_cast(&opt), sizeof(opt)); - setsockopt(sock, SOL_SOCKET, SO_EXCLUSIVEADDRUSE, - reinterpret_cast(&opt), sizeof(opt)); -#else -#ifdef SO_REUSEPORT - setsockopt(sock, SOL_SOCKET, SO_REUSEPORT, - reinterpret_cast(&opt), sizeof(opt)); -#else - setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, - reinterpret_cast(&opt), sizeof(opt)); -#endif -#endif -} - -inline const char *status_message(int status) { - switch (status) { - case StatusCode::Continue_100: - return "Continue"; - case StatusCode::SwitchingProtocol_101: - return "Switching Protocol"; - case StatusCode::Processing_102: - return "Processing"; - case StatusCode::EarlyHints_103: - return "Early Hints"; - case StatusCode::OK_200: - return "OK"; - case StatusCode::Created_201: - return "Created"; - case StatusCode::Accepted_202: - return "Accepted"; - case StatusCode::NonAuthoritativeInformation_203: - return "Non-Authoritative Information"; - case StatusCode::NoContent_204: - return "No Content"; - case StatusCode::ResetContent_205: - return "Reset Content"; - case StatusCode::PartialContent_206: - return "Partial Content"; - case StatusCode::MultiStatus_207: - return "Multi-Status"; - case StatusCode::AlreadyReported_208: - return "Already Reported"; - case StatusCode::IMUsed_226: - return "IM Used"; - case StatusCode::MultipleChoices_300: - return "Multiple Choices"; - case StatusCode::MovedPermanently_301: - return "Moved Permanently"; - case StatusCode::Found_302: - return "Found"; - case StatusCode::SeeOther_303: - return "See Other"; - case StatusCode::NotModified_304: - return "Not Modified"; - case StatusCode::UseProxy_305: - return "Use Proxy"; - case StatusCode::unused_306: - return "unused"; - case StatusCode::TemporaryRedirect_307: - return "Temporary Redirect"; - case StatusCode::PermanentRedirect_308: - return "Permanent Redirect"; - case StatusCode::BadRequest_400: - return "Bad Request"; - case StatusCode::Unauthorized_401: - return "Unauthorized"; - case StatusCode::PaymentRequired_402: - return "Payment Required"; - case StatusCode::Forbidden_403: - return "Forbidden"; - case StatusCode::NotFound_404: - return "Not Found"; - case StatusCode::MethodNotAllowed_405: - return "Method Not Allowed"; - case StatusCode::NotAcceptable_406: - return "Not Acceptable"; - case StatusCode::ProxyAuthenticationRequired_407: - return "Proxy Authentication Required"; - case StatusCode::RequestTimeout_408: - return "Request Timeout"; - case StatusCode::Conflict_409: - return "Conflict"; - case StatusCode::Gone_410: - return "Gone"; - case StatusCode::LengthRequired_411: - return "Length Required"; - case StatusCode::PreconditionFailed_412: - return "Precondition Failed"; - case StatusCode::PayloadTooLarge_413: - return "Payload Too Large"; - case StatusCode::UriTooLong_414: - return "URI Too Long"; - case StatusCode::UnsupportedMediaType_415: - return "Unsupported Media Type"; - case StatusCode::RangeNotSatisfiable_416: - return "Range Not Satisfiable"; - case StatusCode::ExpectationFailed_417: - return "Expectation Failed"; - case StatusCode::ImATeapot_418: - return "I'm a teapot"; - case StatusCode::MisdirectedRequest_421: - return "Misdirected Request"; - case StatusCode::UnprocessableContent_422: - return "Unprocessable Content"; - case StatusCode::Locked_423: - return "Locked"; - case StatusCode::FailedDependency_424: - return "Failed Dependency"; - case StatusCode::TooEarly_425: - return "Too Early"; - case StatusCode::UpgradeRequired_426: - return "Upgrade Required"; - case StatusCode::PreconditionRequired_428: - return "Precondition Required"; - case StatusCode::TooManyRequests_429: - return "Too Many Requests"; - case StatusCode::RequestHeaderFieldsTooLarge_431: - return "Request Header Fields Too Large"; - case StatusCode::UnavailableForLegalReasons_451: - return "Unavailable For Legal Reasons"; - case StatusCode::NotImplemented_501: - return "Not Implemented"; - case StatusCode::BadGateway_502: - return "Bad Gateway"; - case StatusCode::ServiceUnavailable_503: - return "Service Unavailable"; - case StatusCode::GatewayTimeout_504: - return "Gateway Timeout"; - case StatusCode::HttpVersionNotSupported_505: - return "HTTP Version Not Supported"; - case StatusCode::VariantAlsoNegotiates_506: - return "Variant Also Negotiates"; - case StatusCode::InsufficientStorage_507: - return "Insufficient Storage"; - case StatusCode::LoopDetected_508: - return "Loop Detected"; - case StatusCode::NotExtended_510: - return "Not Extended"; - case StatusCode::NetworkAuthenticationRequired_511: - return "Network Authentication Required"; - - default: - case StatusCode::InternalServerError_500: - return "Internal Server Error"; - } -} - -inline std::string get_bearer_token_auth(const Request &req) { - if (req.has_header("Authorization")) { - static std::string BearerHeaderPrefix = "Bearer "; - return req.get_header_value("Authorization") - .substr(BearerHeaderPrefix.length()); - } - return ""; -} - -template -inline Server &Server::set_read_timeout( - const std::chrono::duration &duration) { - detail::duration_to_sec_and_usec( - duration, [&](time_t sec, time_t usec) { set_read_timeout(sec, usec); }); - return *this; -} - -template -inline Server &Server::set_write_timeout( - const std::chrono::duration &duration) { - detail::duration_to_sec_and_usec( - duration, [&](time_t sec, time_t usec) { set_write_timeout(sec, usec); }); - return *this; -} - -template -inline Server &Server::set_idle_interval( - const std::chrono::duration &duration) { - detail::duration_to_sec_and_usec( - duration, [&](time_t sec, time_t usec) { set_idle_interval(sec, usec); }); - return *this; -} - -inline std::string to_string(const Error error) { - switch (error) { - case Error::Success: - return "Success (no error)"; - case Error::Connection: - return "Could not establish connection"; - case Error::BindIPAddress: - return "Failed to bind IP address"; - case Error::Read: - return "Failed to read connection"; - case Error::Write: - return "Failed to write connection"; - case Error::ExceedRedirectCount: - return "Maximum redirect count exceeded"; - case Error::Canceled: - return "Connection handling canceled"; - case Error::SSLConnection: - return "SSL connection failed"; - case Error::SSLLoadingCerts: - return "SSL certificate loading failed"; - case Error::SSLServerVerification: - return "SSL server verification failed"; - case Error::SSLServerHostnameVerification: - return "SSL server hostname verification failed"; - case Error::UnsupportedMultipartBoundaryChars: - return "Unsupported HTTP multipart boundary characters"; - case Error::Compression: - return "Compression failed"; - case Error::ConnectionTimeout: - return "Connection timed out"; - case Error::ProxyConnection: - return "Proxy connection failed"; - case Error::Unknown: - return "Unknown"; - default: - break; - } - - return "Invalid"; -} - -inline std::ostream &operator<<(std::ostream &os, const Error &obj) { - os << to_string(obj); - os << " (" << static_cast::type>(obj) << ')'; - return os; -} - -inline uint64_t Result::get_request_header_value_u64(const std::string &key, - uint64_t def, - size_t id) const { - return detail::get_header_value_u64(request_headers_, key, def, id); -} - -template -inline void ClientImpl::set_connection_timeout( - const std::chrono::duration &duration) { - detail::duration_to_sec_and_usec(duration, [&](time_t sec, time_t usec) { - set_connection_timeout(sec, usec); - }); -} - -template -inline void ClientImpl::set_read_timeout( - const std::chrono::duration &duration) { - detail::duration_to_sec_and_usec( - duration, [&](time_t sec, time_t usec) { set_read_timeout(sec, usec); }); -} - -template -inline void ClientImpl::set_write_timeout( - const std::chrono::duration &duration) { - detail::duration_to_sec_and_usec( - duration, [&](time_t sec, time_t usec) { set_write_timeout(sec, usec); }); -} - -template -inline void Client::set_connection_timeout( - const std::chrono::duration &duration) { - cli_->set_connection_timeout(duration); -} - -template -inline void Client::set_read_timeout( - const std::chrono::duration &duration) { - cli_->set_read_timeout(duration); -} - -template -inline void Client::set_write_timeout( - const std::chrono::duration &duration) { - cli_->set_write_timeout(duration); -} - -/* - * Forward declarations and types that will be part of the .h file if split into - * .h + .cc. - */ - -std::string hosted_at(const std::string &hostname); - -void hosted_at(const std::string &hostname, std::vector &addrs); - -std::string append_query_params(const std::string &path, const Params ¶ms); - -std::pair make_range_header(const Ranges &ranges); - -std::pair make_basic_authentication_header( - const std::string &username, const std::string &password, - bool is_proxy = false); - -namespace detail { - -struct FileStat { - FileStat(const std::string &path); - bool is_file() const; - bool is_dir() const; - - private: - struct stat st_; - int ret_ = -1; -}; - -std::string encode_query_param(const std::string &value); - -std::string decode_url(const std::string &s, bool convert_plus_to_space); - -void read_file(const std::string &path, std::string &out); - -std::string trim_copy(const std::string &s); - -void divide( - const char *data, std::size_t size, char d, - std::function - fn); - -void divide( - const std::string &str, char d, - std::function - fn); - -void split(const char *b, const char *e, char d, - std::function fn); - -void split(const char *b, const char *e, char d, size_t m, - std::function fn); - -bool process_client_socket(socket_t sock, time_t read_timeout_sec, - time_t read_timeout_usec, time_t write_timeout_sec, - time_t write_timeout_usec, - std::function callback); - -socket_t create_client_socket(const std::string &host, const std::string &ip, - int port, int address_family, bool tcp_nodelay, - bool ipv6_v6only, SocketOptions socket_options, - time_t connection_timeout_sec, - time_t connection_timeout_usec, - time_t read_timeout_sec, time_t read_timeout_usec, - time_t write_timeout_sec, - time_t write_timeout_usec, - const std::string &intf, Error &error); - -const char *get_header_value(const Headers &headers, const std::string &key, - const char *def, size_t id); - -std::string params_to_query_str(const Params ¶ms); - -void parse_query_text(const char *data, std::size_t size, Params ¶ms); - -void parse_query_text(const std::string &s, Params ¶ms); - -bool parse_multipart_boundary(const std::string &content_type, - std::string &boundary); - -bool parse_range_header(const std::string &s, Ranges &ranges); - -int close_socket(socket_t sock); - -ssize_t send_socket(socket_t sock, const void *ptr, size_t size, int flags); - -ssize_t read_socket(socket_t sock, void *ptr, size_t size, int flags); - -enum class EncodingType { None = 0, Gzip, Brotli }; - -EncodingType encoding_type(const Request &req, const Response &res); - -class BufferStream final : public Stream { - public: - BufferStream() = default; - ~BufferStream() override = default; - - bool is_readable() const override; - bool is_writable() const override; - ssize_t read(char *ptr, size_t size) override; - ssize_t write(const char *ptr, size_t size) override; - void get_remote_ip_and_port(std::string &ip, int &port) const override; - void get_local_ip_and_port(std::string &ip, int &port) const override; - socket_t socket() const override; - - const std::string &get_buffer() const; - - private: - std::string buffer; - size_t position = 0; -}; - -class compressor { - public: - virtual ~compressor() = default; - - typedef std::function Callback; - virtual bool compress(const char *data, size_t data_length, bool last, - Callback callback) = 0; -}; - -class decompressor { - public: - virtual ~decompressor() = default; - - virtual bool is_valid() const = 0; - - typedef std::function Callback; - virtual bool decompress(const char *data, size_t data_length, - Callback callback) = 0; -}; - -class nocompressor final : public compressor { - public: - ~nocompressor() override = default; - - bool compress(const char *data, size_t data_length, bool /*last*/, - Callback callback) override; -}; - -#ifdef CPPHTTPLIB_ZLIB_SUPPORT -class gzip_compressor final : public compressor { - public: - gzip_compressor(); - ~gzip_compressor() override; - - bool compress(const char *data, size_t data_length, bool last, - Callback callback) override; - - private: - bool is_valid_ = false; - z_stream strm_; -}; - -class gzip_decompressor final : public decompressor { - public: - gzip_decompressor(); - ~gzip_decompressor() override; - - bool is_valid() const override; - - bool decompress(const char *data, size_t data_length, - Callback callback) override; - - private: - bool is_valid_ = false; - z_stream strm_; -}; -#endif - -#ifdef CPPHTTPLIB_BROTLI_SUPPORT -class brotli_compressor final : public compressor { - public: - brotli_compressor(); - ~brotli_compressor(); - - bool compress(const char *data, size_t data_length, bool last, - Callback callback) override; - - private: - BrotliEncoderState *state_ = nullptr; -}; - -class brotli_decompressor final : public decompressor { - public: - brotli_decompressor(); - ~brotli_decompressor(); - - bool is_valid() const override; - - bool decompress(const char *data, size_t data_length, - Callback callback) override; - - private: - BrotliDecoderResult decoder_r; - BrotliDecoderState *decoder_s = nullptr; -}; -#endif - -// NOTE: until the read size reaches `fixed_buffer_size`, use `fixed_buffer` -// to store data. The call can set memory on stack for performance. -class stream_line_reader { - public: - stream_line_reader(Stream &strm, char *fixed_buffer, - size_t fixed_buffer_size); - const char *ptr() const; - size_t size() const; - bool end_with_crlf() const; - bool getline(); - - private: - void append(char c); - - Stream &strm_; - char *fixed_buffer_; - const size_t fixed_buffer_size_; - size_t fixed_buffer_used_size_ = 0; - std::string glowable_buffer_; -}; - -class mmap { - public: - mmap(const char *path); - ~mmap(); - - bool open(const char *path); - void close(); - - bool is_open() const; - size_t size() const; - const char *data() const; - - private: -#if defined(_WIN32) - HANDLE hFile_ = NULL; - HANDLE hMapping_ = NULL; -#else - int fd_ = -1; -#endif - size_t size_ = 0; - void *addr_ = nullptr; - bool is_open_empty_file = false; -}; - -} // namespace detail - -// ---------------------------------------------------------------------------- - -/* - * Implementation that will be part of the .cc file if split into .h + .cc. - */ - -namespace detail { - -inline bool is_hex(char c, int &v) { - if (0x20 <= c && isdigit(c)) { - v = c - '0'; - return true; - } else if ('A' <= c && c <= 'F') { - v = c - 'A' + 10; - return true; - } else if ('a' <= c && c <= 'f') { - v = c - 'a' + 10; - return true; - } - return false; -} - -inline bool from_hex_to_i(const std::string &s, size_t i, size_t cnt, - int &val) { - if (i >= s.size()) { - return false; - } - - val = 0; - for (; cnt; i++, cnt--) { - if (!s[i]) { - return false; - } - auto v = 0; - if (is_hex(s[i], v)) { - val = val * 16 + v; - } else { - return false; - } - } - return true; -} - -inline std::string from_i_to_hex(size_t n) { - static const auto charset = "0123456789abcdef"; - std::string ret; - do { - ret = charset[n & 15] + ret; - n >>= 4; - } while (n > 0); - return ret; -} - -inline size_t to_utf8(int code, char *buff) { - if (code < 0x0080) { - buff[0] = static_cast(code & 0x7F); - return 1; - } else if (code < 0x0800) { - buff[0] = static_cast(0xC0 | ((code >> 6) & 0x1F)); - buff[1] = static_cast(0x80 | (code & 0x3F)); - return 2; - } else if (code < 0xD800) { - buff[0] = static_cast(0xE0 | ((code >> 12) & 0xF)); - buff[1] = static_cast(0x80 | ((code >> 6) & 0x3F)); - buff[2] = static_cast(0x80 | (code & 0x3F)); - return 3; - } else if (code < 0xE000) { // D800 - DFFF is invalid... - return 0; - } else if (code < 0x10000) { - buff[0] = static_cast(0xE0 | ((code >> 12) & 0xF)); - buff[1] = static_cast(0x80 | ((code >> 6) & 0x3F)); - buff[2] = static_cast(0x80 | (code & 0x3F)); - return 3; - } else if (code < 0x110000) { - buff[0] = static_cast(0xF0 | ((code >> 18) & 0x7)); - buff[1] = static_cast(0x80 | ((code >> 12) & 0x3F)); - buff[2] = static_cast(0x80 | ((code >> 6) & 0x3F)); - buff[3] = static_cast(0x80 | (code & 0x3F)); - return 4; - } - - // NOTREACHED - return 0; -} - -// NOTE: This code came up with the following stackoverflow post: -// https://stackoverflow.com/questions/180947/base64-decode-snippet-in-c -inline std::string base64_encode(const std::string &in) { - static const auto lookup = - "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; - - std::string out; - out.reserve(in.size()); - - auto val = 0; - auto valb = -6; - - for (auto c : in) { - val = (val << 8) + static_cast(c); - valb += 8; - while (valb >= 0) { - out.push_back(lookup[(val >> valb) & 0x3F]); - valb -= 6; - } - } - - if (valb > -6) { - out.push_back(lookup[((val << 8) >> (valb + 8)) & 0x3F]); - } - - while (out.size() % 4) { - out.push_back('='); - } - - return out; -} - -inline bool is_valid_path(const std::string &path) { - size_t level = 0; - size_t i = 0; - - // Skip slash - while (i < path.size() && path[i] == '/') { - i++; - } - - while (i < path.size()) { - // Read component - auto beg = i; - while (i < path.size() && path[i] != '/') { - if (path[i] == '\0') { - return false; - } else if (path[i] == '\\') { - return false; - } - i++; - } - - auto len = i - beg; - assert(len > 0); - - if (!path.compare(beg, len, ".")) { - ; - } else if (!path.compare(beg, len, "..")) { - if (level == 0) { - return false; - } - level--; - } else { - level++; - } - - // Skip slash - while (i < path.size() && path[i] == '/') { - i++; - } - } - - return true; -} - -inline FileStat::FileStat(const std::string &path) { - ret_ = stat(path.c_str(), &st_); -} -inline bool FileStat::is_file() const { - return ret_ >= 0 && S_ISREG(st_.st_mode); -} -inline bool FileStat::is_dir() const { - return ret_ >= 0 && S_ISDIR(st_.st_mode); -} - -inline std::string encode_query_param(const std::string &value) { - std::ostringstream escaped; - escaped.fill('0'); - escaped << std::hex; - - for (auto c : value) { - if (std::isalnum(static_cast(c)) || c == '-' || c == '_' || - c == '.' || c == '!' || c == '~' || c == '*' || c == '\'' || c == '(' || - c == ')') { - escaped << c; - } else { - escaped << std::uppercase; - escaped << '%' << std::setw(2) - << static_cast(static_cast(c)); - escaped << std::nouppercase; - } - } - - return escaped.str(); -} - -inline std::string encode_url(const std::string &s) { - std::string result; - result.reserve(s.size()); - - for (size_t i = 0; s[i]; i++) { - switch (s[i]) { - case ' ': - result += "%20"; - break; - case '+': - result += "%2B"; - break; - case '\r': - result += "%0D"; - break; - case '\n': - result += "%0A"; - break; - case '\'': - result += "%27"; - break; - case ',': - result += "%2C"; - break; - // case ':': result += "%3A"; break; // ok? probably... - case ';': - result += "%3B"; - break; - default: - auto c = static_cast(s[i]); - if (c >= 0x80) { - result += '%'; - char hex[4]; - auto len = snprintf(hex, sizeof(hex) - 1, "%02X", c); - assert(len == 2); - result.append(hex, static_cast(len)); - } else { - result += s[i]; - } - break; - } - } - - return result; -} - -inline std::string decode_url(const std::string &s, - bool convert_plus_to_space) { - std::string result; - - for (size_t i = 0; i < s.size(); i++) { - if (s[i] == '%' && i + 1 < s.size()) { - if (s[i + 1] == 'u') { - auto val = 0; - if (from_hex_to_i(s, i + 2, 4, val)) { - // 4 digits Unicode codes - char buff[4]; - size_t len = to_utf8(val, buff); - if (len > 0) { - result.append(buff, len); - } - i += 5; // 'u0000' - } else { - result += s[i]; - } - } else { - auto val = 0; - if (from_hex_to_i(s, i + 1, 2, val)) { - // 2 digits hex codes - result += static_cast(val); - i += 2; // '00' - } else { - result += s[i]; - } - } - } else if (convert_plus_to_space && s[i] == '+') { - result += ' '; - } else { - result += s[i]; - } - } - - return result; -} - -inline void read_file(const std::string &path, std::string &out) { - std::ifstream fs(path, std::ios_base::binary); - fs.seekg(0, std::ios_base::end); - auto size = fs.tellg(); - fs.seekg(0); - out.resize(static_cast(size)); - fs.read(&out[0], static_cast(size)); -} - -inline std::string file_extension(const std::string &path) { - std::smatch m; - static auto re = std::regex("\\.([a-zA-Z0-9]+)$"); - if (std::regex_search(path, m, re)) { - return m[1].str(); - } - return std::string(); -} - -inline bool is_space_or_tab(char c) { return c == ' ' || c == '\t'; } - -inline std::pair trim(const char *b, const char *e, size_t left, - size_t right) { - while (b + left < e && is_space_or_tab(b[left])) { - left++; - } - while (right > 0 && is_space_or_tab(b[right - 1])) { - right--; - } - return std::make_pair(left, right); -} - -inline std::string trim_copy(const std::string &s) { - auto r = trim(s.data(), s.data() + s.size(), 0, s.size()); - return s.substr(r.first, r.second - r.first); -} - -inline std::string trim_double_quotes_copy(const std::string &s) { - if (s.length() >= 2 && s.front() == '"' && s.back() == '"') { - return s.substr(1, s.size() - 2); - } - return s; -} - -inline void divide( - const char *data, std::size_t size, char d, - std::function - fn) { - const auto it = std::find(data, data + size, d); - const auto found = static_cast(it != data + size); - const auto lhs_data = data; - const auto lhs_size = static_cast(it - data); - const auto rhs_data = it + found; - const auto rhs_size = size - lhs_size - found; - - fn(lhs_data, lhs_size, rhs_data, rhs_size); -} - -inline void divide( - const std::string &str, char d, - std::function - fn) { - divide(str.data(), str.size(), d, std::move(fn)); -} - -inline void split(const char *b, const char *e, char d, - std::function fn) { - return split(b, e, d, (std::numeric_limits::max)(), std::move(fn)); -} - -inline void split(const char *b, const char *e, char d, size_t m, - std::function fn) { - size_t i = 0; - size_t beg = 0; - size_t count = 1; - - while (e ? (b + i < e) : (b[i] != '\0')) { - if (b[i] == d && count < m) { - auto r = trim(b, e, beg, i); - if (r.first < r.second) { - fn(&b[r.first], &b[r.second]); - } - beg = i + 1; - count++; - } - i++; - } - - if (i) { - auto r = trim(b, e, beg, i); - if (r.first < r.second) { - fn(&b[r.first], &b[r.second]); - } - } -} - -inline stream_line_reader::stream_line_reader(Stream &strm, char *fixed_buffer, - size_t fixed_buffer_size) - : strm_(strm), - fixed_buffer_(fixed_buffer), - fixed_buffer_size_(fixed_buffer_size) {} - -inline const char *stream_line_reader::ptr() const { - if (glowable_buffer_.empty()) { - return fixed_buffer_; - } else { - return glowable_buffer_.data(); - } -} - -inline size_t stream_line_reader::size() const { - if (glowable_buffer_.empty()) { - return fixed_buffer_used_size_; - } else { - return glowable_buffer_.size(); - } -} - -inline bool stream_line_reader::end_with_crlf() const { - auto end = ptr() + size(); - return size() >= 2 && end[-2] == '\r' && end[-1] == '\n'; -} - -inline bool stream_line_reader::getline() { - fixed_buffer_used_size_ = 0; - glowable_buffer_.clear(); - -#ifndef CPPHTTPLIB_ALLOW_LF_AS_LINE_TERMINATOR - char prev_byte = 0; -#endif - - for (size_t i = 0;; i++) { - char byte; - auto n = strm_.read(&byte, 1); - - if (n < 0) { - return false; - } else if (n == 0) { - if (i == 0) { - return false; - } else { - break; - } - } - - append(byte); - -#ifdef CPPHTTPLIB_ALLOW_LF_AS_LINE_TERMINATOR - if (byte == '\n') { - break; - } -#else - if (prev_byte == '\r' && byte == '\n') { - break; - } - prev_byte = byte; -#endif - } - - return true; -} - -inline void stream_line_reader::append(char c) { - if (fixed_buffer_used_size_ < fixed_buffer_size_ - 1) { - fixed_buffer_[fixed_buffer_used_size_++] = c; - fixed_buffer_[fixed_buffer_used_size_] = '\0'; - } else { - if (glowable_buffer_.empty()) { - assert(fixed_buffer_[fixed_buffer_used_size_] == '\0'); - glowable_buffer_.assign(fixed_buffer_, fixed_buffer_used_size_); - } - glowable_buffer_ += c; - } -} - -inline mmap::mmap(const char *path) { open(path); } - -inline mmap::~mmap() { close(); } - -inline bool mmap::open(const char *path) { - close(); - -#if defined(_WIN32) - std::wstring wpath; - for (size_t i = 0; i < strlen(path); i++) { - wpath += path[i]; - } - -#if _WIN32_WINNT >= _WIN32_WINNT_WIN8 - hFile_ = ::CreateFile2(wpath.c_str(), GENERIC_READ, FILE_SHARE_READ, - OPEN_EXISTING, NULL); -#else - hFile_ = ::CreateFileW(wpath.c_str(), GENERIC_READ, FILE_SHARE_READ, NULL, - OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); -#endif - - if (hFile_ == INVALID_HANDLE_VALUE) { - return false; - } - - LARGE_INTEGER size{}; - if (!::GetFileSizeEx(hFile_, &size)) { - return false; - } - // If the following line doesn't compile due to QuadPart, update Windows SDK. - // See: - // https://github.com/yhirose/cpp-httplib/issues/1903#issuecomment-2316520721 - if (static_cast(size.QuadPart) > - (std::numeric_limits::max)()) { - // `size_t` might be 32-bits, on 32-bits Windows. - return false; - } - size_ = static_cast(size.QuadPart); - -#if _WIN32_WINNT >= _WIN32_WINNT_WIN8 - hMapping_ = - ::CreateFileMappingFromApp(hFile_, NULL, PAGE_READONLY, size_, NULL); -#else - hMapping_ = ::CreateFileMappingW(hFile_, NULL, PAGE_READONLY, 0, 0, NULL); -#endif - - // Special treatment for an empty file... - if (hMapping_ == NULL && size_ == 0) { - close(); - is_open_empty_file = true; - return true; - } - - if (hMapping_ == NULL) { - close(); - return false; - } - -#if _WIN32_WINNT >= _WIN32_WINNT_WIN8 - addr_ = ::MapViewOfFileFromApp(hMapping_, FILE_MAP_READ, 0, 0); -#else - addr_ = ::MapViewOfFile(hMapping_, FILE_MAP_READ, 0, 0, 0); -#endif - - if (addr_ == nullptr) { - close(); - return false; - } -#else - fd_ = ::open(path, O_RDONLY); - if (fd_ == -1) { - return false; - } - - struct stat sb; - if (fstat(fd_, &sb) == -1) { - close(); - return false; - } - size_ = static_cast(sb.st_size); - - addr_ = ::mmap(NULL, size_, PROT_READ, MAP_PRIVATE, fd_, 0); - - // Special treatment for an empty file... - if (addr_ == MAP_FAILED && size_ == 0) { - close(); - is_open_empty_file = true; - return false; - } -#endif - - return true; -} - -inline bool mmap::is_open() const { - return is_open_empty_file ? true : addr_ != nullptr; -} - -inline size_t mmap::size() const { return size_; } - -inline const char *mmap::data() const { - return is_open_empty_file ? "" : static_cast(addr_); -} - -inline void mmap::close() { -#if defined(_WIN32) - if (addr_) { - ::UnmapViewOfFile(addr_); - addr_ = nullptr; - } - - if (hMapping_) { - ::CloseHandle(hMapping_); - hMapping_ = NULL; - } - - if (hFile_ != INVALID_HANDLE_VALUE) { - ::CloseHandle(hFile_); - hFile_ = INVALID_HANDLE_VALUE; - } - - is_open_empty_file = false; -#else - if (addr_ != nullptr) { - munmap(addr_, size_); - addr_ = nullptr; - } - - if (fd_ != -1) { - ::close(fd_); - fd_ = -1; - } -#endif - size_ = 0; -} -inline int close_socket(socket_t sock) { -#ifdef _WIN32 - return closesocket(sock); -#else - return close(sock); -#endif -} - -template -inline ssize_t handle_EINTR(T fn) { - ssize_t res = 0; - while (true) { - res = fn(); - if (res < 0 && errno == EINTR) { - std::this_thread::sleep_for(std::chrono::microseconds{1}); - continue; - } - break; - } - return res; -} - -inline ssize_t read_socket(socket_t sock, void *ptr, size_t size, int flags) { - return handle_EINTR([&]() { - return recv(sock, -#ifdef _WIN32 - static_cast(ptr), static_cast(size), -#else - ptr, size, -#endif - flags); - }); -} - -inline ssize_t send_socket(socket_t sock, const void *ptr, size_t size, - int flags) { - return handle_EINTR([&]() { - return send(sock, -#ifdef _WIN32 - static_cast(ptr), static_cast(size), -#else - ptr, size, -#endif - flags); - }); -} - -inline ssize_t select_read(socket_t sock, time_t sec, time_t usec) { -#ifdef CPPHTTPLIB_USE_POLL - struct pollfd pfd_read; - pfd_read.fd = sock; - pfd_read.events = POLLIN; - - auto timeout = static_cast(sec * 1000 + usec / 1000); - - return handle_EINTR([&]() { return poll(&pfd_read, 1, timeout); }); -#else -#ifndef _WIN32 - if (sock >= FD_SETSIZE) { - return -1; - } -#endif - - fd_set fds; - FD_ZERO(&fds); - FD_SET(sock, &fds); - - timeval tv; - tv.tv_sec = static_cast(sec); - tv.tv_usec = static_cast(usec); - - return handle_EINTR([&]() { - return select(static_cast(sock + 1), &fds, nullptr, nullptr, &tv); - }); -#endif -} - -inline ssize_t select_write(socket_t sock, time_t sec, time_t usec) { -#ifdef CPPHTTPLIB_USE_POLL - struct pollfd pfd_read; - pfd_read.fd = sock; - pfd_read.events = POLLOUT; - - auto timeout = static_cast(sec * 1000 + usec / 1000); - - return handle_EINTR([&]() { return poll(&pfd_read, 1, timeout); }); -#else -#ifndef _WIN32 - if (sock >= FD_SETSIZE) { - return -1; - } -#endif - - fd_set fds; - FD_ZERO(&fds); - FD_SET(sock, &fds); - - timeval tv; - tv.tv_sec = static_cast(sec); - tv.tv_usec = static_cast(usec); - - return handle_EINTR([&]() { - return select(static_cast(sock + 1), nullptr, &fds, nullptr, &tv); - }); -#endif -} - -inline Error wait_until_socket_is_ready(socket_t sock, time_t sec, - time_t usec) { -#ifdef CPPHTTPLIB_USE_POLL - struct pollfd pfd_read; - pfd_read.fd = sock; - pfd_read.events = POLLIN | POLLOUT; - - auto timeout = static_cast(sec * 1000 + usec / 1000); - - auto poll_res = handle_EINTR([&]() { return poll(&pfd_read, 1, timeout); }); - - if (poll_res == 0) { - return Error::ConnectionTimeout; - } - - if (poll_res > 0 && pfd_read.revents & (POLLIN | POLLOUT)) { - auto error = 0; - socklen_t len = sizeof(error); - auto res = getsockopt(sock, SOL_SOCKET, SO_ERROR, - reinterpret_cast(&error), &len); - auto successful = res >= 0 && !error; - return successful ? Error::Success : Error::Connection; - } - - return Error::Connection; -#else -#ifndef _WIN32 - if (sock >= FD_SETSIZE) { - return Error::Connection; - } -#endif - - fd_set fdsr; - FD_ZERO(&fdsr); - FD_SET(sock, &fdsr); - - auto fdsw = fdsr; - auto fdse = fdsr; - - timeval tv; - tv.tv_sec = static_cast(sec); - tv.tv_usec = static_cast(usec); - - auto ret = handle_EINTR([&]() { - return select(static_cast(sock + 1), &fdsr, &fdsw, &fdse, &tv); - }); - - if (ret == 0) { - return Error::ConnectionTimeout; - } - - if (ret > 0 && (FD_ISSET(sock, &fdsr) || FD_ISSET(sock, &fdsw))) { - auto error = 0; - socklen_t len = sizeof(error); - auto res = getsockopt(sock, SOL_SOCKET, SO_ERROR, - reinterpret_cast(&error), &len); - auto successful = res >= 0 && !error; - return successful ? Error::Success : Error::Connection; - } - return Error::Connection; -#endif -} - -inline bool is_socket_alive(socket_t sock) { - const auto val = detail::select_read(sock, 0, 0); - if (val == 0) { - return true; - } else if (val < 0 && errno == EBADF) { - return false; - } - char buf[1]; - return detail::read_socket(sock, &buf[0], sizeof(buf), MSG_PEEK) > 0; -} - -class SocketStream final : public Stream { - public: - SocketStream(socket_t sock, time_t read_timeout_sec, time_t read_timeout_usec, - time_t write_timeout_sec, time_t write_timeout_usec); - ~SocketStream() override; - - bool is_readable() const override; - bool is_writable() const override; - ssize_t read(char *ptr, size_t size) override; - ssize_t write(const char *ptr, size_t size) override; - void get_remote_ip_and_port(std::string &ip, int &port) const override; - void get_local_ip_and_port(std::string &ip, int &port) const override; - socket_t socket() const override; - - private: - socket_t sock_; - time_t read_timeout_sec_; - time_t read_timeout_usec_; - time_t write_timeout_sec_; - time_t write_timeout_usec_; - - std::vector read_buff_; - size_t read_buff_off_ = 0; - size_t read_buff_content_size_ = 0; - - static const size_t read_buff_size_ = 1024l * 4; -}; - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -class SSLSocketStream final : public Stream { - public: - SSLSocketStream(socket_t sock, SSL *ssl, time_t read_timeout_sec, - time_t read_timeout_usec, time_t write_timeout_sec, - time_t write_timeout_usec); - ~SSLSocketStream() override; - - bool is_readable() const override; - bool is_writable() const override; - ssize_t read(char *ptr, size_t size) override; - ssize_t write(const char *ptr, size_t size) override; - void get_remote_ip_and_port(std::string &ip, int &port) const override; - void get_local_ip_and_port(std::string &ip, int &port) const override; - socket_t socket() const override; - - private: - socket_t sock_; - SSL *ssl_; - time_t read_timeout_sec_; - time_t read_timeout_usec_; - time_t write_timeout_sec_; - time_t write_timeout_usec_; -}; -#endif - -template -inline bool process_server_socket_core(const std::atomic &svr_sock, - socket_t sock, - size_t keep_alive_max_count, - time_t keep_alive_timeout_sec, - T callback) { - assert(keep_alive_max_count > 0); - auto ret = false; - auto count = keep_alive_max_count; - while (svr_sock != INVALID_SOCKET && count > 0 && - select_read(sock, keep_alive_timeout_sec, 0) > 0) { - auto close_connection = count == 1; - auto connection_closed = false; - ret = callback(close_connection, connection_closed); - if (!ret || connection_closed) { - break; - } - count--; - } - return ret; -} - -template -inline bool process_server_socket(const std::atomic &svr_sock, - socket_t sock, size_t keep_alive_max_count, - time_t keep_alive_timeout_sec, - time_t read_timeout_sec, - time_t read_timeout_usec, - time_t write_timeout_sec, - time_t write_timeout_usec, T callback) { - return process_server_socket_core( - svr_sock, sock, keep_alive_max_count, keep_alive_timeout_sec, - [&](bool close_connection, bool &connection_closed) { - SocketStream strm(sock, read_timeout_sec, read_timeout_usec, - write_timeout_sec, write_timeout_usec); - return callback(strm, close_connection, connection_closed); - }); -} - -inline bool process_client_socket(socket_t sock, time_t read_timeout_sec, - time_t read_timeout_usec, - time_t write_timeout_sec, - time_t write_timeout_usec, - std::function callback) { - SocketStream strm(sock, read_timeout_sec, read_timeout_usec, - write_timeout_sec, write_timeout_usec); - return callback(strm); -} - -inline int shutdown_socket(socket_t sock) { -#ifdef _WIN32 - return shutdown(sock, SD_BOTH); -#else - return shutdown(sock, SHUT_RDWR); -#endif -} - -inline std::string escape_abstract_namespace_unix_domain(const std::string &s) { - if (s.size() > 1 && s[0] == '\0') { - auto ret = s; - ret[0] = '@'; - return ret; - } - return s; -} - -inline std::string unescape_abstract_namespace_unix_domain( - const std::string &s) { - if (s.size() > 1 && s[0] == '@') { - auto ret = s; - ret[0] = '\0'; - return ret; - } - return s; -} - -template -socket_t create_socket(const std::string &host, const std::string &ip, int port, - int address_family, int socket_flags, bool tcp_nodelay, - bool ipv6_v6only, SocketOptions socket_options, - BindOrConnect bind_or_connect) { - // Get address info - const char *node = nullptr; - struct addrinfo hints; - struct addrinfo *result; - - memset(&hints, 0, sizeof(struct addrinfo)); - hints.ai_socktype = SOCK_STREAM; - hints.ai_protocol = IPPROTO_IP; - - if (!ip.empty()) { - node = ip.c_str(); - // Ask getaddrinfo to convert IP in c-string to address - hints.ai_family = AF_UNSPEC; - hints.ai_flags = AI_NUMERICHOST; - } else { - if (!host.empty()) { - node = host.c_str(); - } - hints.ai_family = address_family; - hints.ai_flags = socket_flags; - } - -#ifndef _WIN32 - if (hints.ai_family == AF_UNIX) { - const auto addrlen = host.length(); - if (addrlen > sizeof(sockaddr_un::sun_path)) { - return INVALID_SOCKET; - } - -#ifdef SOCK_CLOEXEC - auto sock = socket(hints.ai_family, hints.ai_socktype | SOCK_CLOEXEC, - hints.ai_protocol); -#else - auto sock = socket(hints.ai_family, hints.ai_socktype, hints.ai_protocol); -#endif - - if (sock != INVALID_SOCKET) { - sockaddr_un addr{}; - addr.sun_family = AF_UNIX; - - auto unescaped_host = unescape_abstract_namespace_unix_domain(host); - std::copy(unescaped_host.begin(), unescaped_host.end(), addr.sun_path); - - hints.ai_addr = reinterpret_cast(&addr); - hints.ai_addrlen = static_cast( - sizeof(addr) - sizeof(addr.sun_path) + addrlen); - -#ifndef SOCK_CLOEXEC - fcntl(sock, F_SETFD, FD_CLOEXEC); -#endif - - if (socket_options) { - socket_options(sock); - } - - bool dummy; - if (!bind_or_connect(sock, hints, dummy)) { - close_socket(sock); - sock = INVALID_SOCKET; - } - } - return sock; - } -#endif - - auto service = std::to_string(port); - - if (getaddrinfo(node, service.c_str(), &hints, &result)) { -#if defined __linux__ && !defined __ANDROID__ - res_init(); -#endif - return INVALID_SOCKET; - } - auto se = detail::scope_exit([&] { freeaddrinfo(result); }); - - for (auto rp = result; rp; rp = rp->ai_next) { - // Create a socket -#ifdef _WIN32 - auto sock = - WSASocketW(rp->ai_family, rp->ai_socktype, rp->ai_protocol, nullptr, 0, - WSA_FLAG_NO_HANDLE_INHERIT | WSA_FLAG_OVERLAPPED); - /** - * Since the WSA_FLAG_NO_HANDLE_INHERIT is only supported on Windows 7 SP1 - * and above the socket creation fails on older Windows Systems. - * - * Let's try to create a socket the old way in this case. - * - * Reference: - * https://docs.microsoft.com/en-us/windows/win32/api/winsock2/nf-winsock2-wsasocketa - * - * WSA_FLAG_NO_HANDLE_INHERIT: - * This flag is supported on Windows 7 with SP1, Windows Server 2008 R2 with - * SP1, and later - * - */ - if (sock == INVALID_SOCKET) { - sock = socket(rp->ai_family, rp->ai_socktype, rp->ai_protocol); - } -#else - -#ifdef SOCK_CLOEXEC - auto sock = - socket(rp->ai_family, rp->ai_socktype | SOCK_CLOEXEC, rp->ai_protocol); -#else - auto sock = socket(rp->ai_family, rp->ai_socktype, rp->ai_protocol); -#endif - -#endif - if (sock == INVALID_SOCKET) { - continue; - } - -#if !defined _WIN32 && !defined SOCK_CLOEXEC - if (fcntl(sock, F_SETFD, FD_CLOEXEC) == -1) { - close_socket(sock); - continue; - } -#endif - - if (tcp_nodelay) { - auto opt = 1; -#ifdef _WIN32 - setsockopt(sock, IPPROTO_TCP, TCP_NODELAY, - reinterpret_cast(&opt), sizeof(opt)); -#else - setsockopt(sock, IPPROTO_TCP, TCP_NODELAY, - reinterpret_cast(&opt), sizeof(opt)); -#endif - } - - if (rp->ai_family == AF_INET6) { - auto opt = ipv6_v6only ? 1 : 0; -#ifdef _WIN32 - setsockopt(sock, IPPROTO_IPV6, IPV6_V6ONLY, - reinterpret_cast(&opt), sizeof(opt)); -#else - setsockopt(sock, IPPROTO_IPV6, IPV6_V6ONLY, - reinterpret_cast(&opt), sizeof(opt)); -#endif - } - - if (socket_options) { - socket_options(sock); - } - - // bind or connect - auto quit = false; - if (bind_or_connect(sock, *rp, quit)) { - return sock; - } - - close_socket(sock); - - if (quit) { - break; - } - } - - return INVALID_SOCKET; -} - -inline void set_nonblocking(socket_t sock, bool nonblocking) { -#ifdef _WIN32 - auto flags = nonblocking ? 1UL : 0UL; - ioctlsocket(sock, FIONBIO, &flags); -#else - auto flags = fcntl(sock, F_GETFL, 0); - fcntl(sock, F_SETFL, - nonblocking ? (flags | O_NONBLOCK) : (flags & (~O_NONBLOCK))); -#endif -} - -inline bool is_connection_error() { -#ifdef _WIN32 - return WSAGetLastError() != WSAEWOULDBLOCK; -#else - return errno != EINPROGRESS; -#endif -} - -inline bool bind_ip_address(socket_t sock, const std::string &host) { - struct addrinfo hints; - struct addrinfo *result; - - memset(&hints, 0, sizeof(struct addrinfo)); - hints.ai_family = AF_UNSPEC; - hints.ai_socktype = SOCK_STREAM; - hints.ai_protocol = 0; - - if (getaddrinfo(host.c_str(), "0", &hints, &result)) { - return false; - } - auto se = detail::scope_exit([&] { freeaddrinfo(result); }); - - auto ret = false; - for (auto rp = result; rp; rp = rp->ai_next) { - const auto &ai = *rp; - if (!::bind(sock, ai.ai_addr, static_cast(ai.ai_addrlen))) { - ret = true; - break; - } - } - - return ret; -} - -#if !defined _WIN32 && !defined ANDROID && !defined _AIX && !defined __MVS__ -#define USE_IF2IP -#endif - -#ifdef USE_IF2IP -inline std::string if2ip(int address_family, const std::string &ifn) { - struct ifaddrs *ifap; - getifaddrs(&ifap); - auto se = detail::scope_exit([&] { freeifaddrs(ifap); }); - - std::string addr_candidate; - for (auto ifa = ifap; ifa; ifa = ifa->ifa_next) { - if (ifa->ifa_addr && ifn == ifa->ifa_name && - (AF_UNSPEC == address_family || - ifa->ifa_addr->sa_family == address_family)) { - if (ifa->ifa_addr->sa_family == AF_INET) { - auto sa = reinterpret_cast(ifa->ifa_addr); - char buf[INET_ADDRSTRLEN]; - if (inet_ntop(AF_INET, &sa->sin_addr, buf, INET_ADDRSTRLEN)) { - return std::string(buf, INET_ADDRSTRLEN); - } - } else if (ifa->ifa_addr->sa_family == AF_INET6) { - auto sa = reinterpret_cast(ifa->ifa_addr); - if (!IN6_IS_ADDR_LINKLOCAL(&sa->sin6_addr)) { - char buf[INET6_ADDRSTRLEN] = {}; - if (inet_ntop(AF_INET6, &sa->sin6_addr, buf, INET6_ADDRSTRLEN)) { - // equivalent to mac's IN6_IS_ADDR_UNIQUE_LOCAL - auto s6_addr_head = sa->sin6_addr.s6_addr[0]; - if (s6_addr_head == 0xfc || s6_addr_head == 0xfd) { - addr_candidate = std::string(buf, INET6_ADDRSTRLEN); - } else { - return std::string(buf, INET6_ADDRSTRLEN); - } - } - } - } - } - } - return addr_candidate; -} -#endif - -inline socket_t create_client_socket( - const std::string &host, const std::string &ip, int port, - int address_family, bool tcp_nodelay, bool ipv6_v6only, - SocketOptions socket_options, time_t connection_timeout_sec, - time_t connection_timeout_usec, time_t read_timeout_sec, - time_t read_timeout_usec, time_t write_timeout_sec, - time_t write_timeout_usec, const std::string &intf, Error &error) { - auto sock = create_socket( - host, ip, port, address_family, 0, tcp_nodelay, ipv6_v6only, - std::move(socket_options), - [&](socket_t sock2, struct addrinfo &ai, bool &quit) -> bool { - if (!intf.empty()) { -#ifdef USE_IF2IP - auto ip_from_if = if2ip(address_family, intf); - if (ip_from_if.empty()) { - ip_from_if = intf; - } - if (!bind_ip_address(sock2, ip_from_if)) { - error = Error::BindIPAddress; - return false; - } -#endif - } - - set_nonblocking(sock2, true); - - auto ret = - ::connect(sock2, ai.ai_addr, static_cast(ai.ai_addrlen)); - - if (ret < 0) { - if (is_connection_error()) { - error = Error::Connection; - return false; - } - error = wait_until_socket_is_ready(sock2, connection_timeout_sec, - connection_timeout_usec); - if (error != Error::Success) { - if (error == Error::ConnectionTimeout) { - quit = true; - } - return false; - } - } - - set_nonblocking(sock2, false); - - { -#ifdef _WIN32 - auto timeout = static_cast(read_timeout_sec * 1000 + - read_timeout_usec / 1000); - setsockopt(sock2, SOL_SOCKET, SO_RCVTIMEO, - reinterpret_cast(&timeout), sizeof(timeout)); -#else - timeval tv; - tv.tv_sec = static_cast(read_timeout_sec); - tv.tv_usec = static_cast(read_timeout_usec); - setsockopt(sock2, SOL_SOCKET, SO_RCVTIMEO, - reinterpret_cast(&tv), sizeof(tv)); -#endif - } - { - -#ifdef _WIN32 - auto timeout = static_cast(write_timeout_sec * 1000 + - write_timeout_usec / 1000); - setsockopt(sock2, SOL_SOCKET, SO_SNDTIMEO, - reinterpret_cast(&timeout), sizeof(timeout)); -#else - timeval tv; - tv.tv_sec = static_cast(write_timeout_sec); - tv.tv_usec = static_cast(write_timeout_usec); - setsockopt(sock2, SOL_SOCKET, SO_SNDTIMEO, - reinterpret_cast(&tv), sizeof(tv)); -#endif - } - - error = Error::Success; - return true; - }); - - if (sock != INVALID_SOCKET) { - error = Error::Success; - } else { - if (error == Error::Success) { - error = Error::Connection; - } - } - - return sock; -} - -inline bool get_ip_and_port(const struct sockaddr_storage &addr, - socklen_t addr_len, std::string &ip, int &port) { - if (addr.ss_family == AF_INET) { - port = ntohs(reinterpret_cast(&addr)->sin_port); - } else if (addr.ss_family == AF_INET6) { - port = - ntohs(reinterpret_cast(&addr)->sin6_port); - } else { - return false; - } - - std::array ipstr{}; - if (getnameinfo(reinterpret_cast(&addr), addr_len, - ipstr.data(), static_cast(ipstr.size()), nullptr, - 0, NI_NUMERICHOST)) { - return false; - } - - ip = ipstr.data(); - return true; -} - -inline void get_local_ip_and_port(socket_t sock, std::string &ip, int &port) { - struct sockaddr_storage addr; - socklen_t addr_len = sizeof(addr); - if (!getsockname(sock, reinterpret_cast(&addr), - &addr_len)) { - get_ip_and_port(addr, addr_len, ip, port); - } -} - -inline void get_remote_ip_and_port(socket_t sock, std::string &ip, int &port) { - struct sockaddr_storage addr; - socklen_t addr_len = sizeof(addr); - - if (!getpeername(sock, reinterpret_cast(&addr), - &addr_len)) { -#ifndef _WIN32 - if (addr.ss_family == AF_UNIX) { -#if defined(__linux__) - struct ucred ucred; - socklen_t len = sizeof(ucred); - if (getsockopt(sock, SOL_SOCKET, SO_PEERCRED, &ucred, &len) == 0) { - port = ucred.pid; - } -#elif defined(SOL_LOCAL) && defined(SO_PEERPID) // __APPLE__ - pid_t pid; - socklen_t len = sizeof(pid); - if (getsockopt(sock, SOL_LOCAL, SO_PEERPID, &pid, &len) == 0) { - port = pid; - } -#endif - return; - } -#endif - get_ip_and_port(addr, addr_len, ip, port); - } -} - -inline constexpr unsigned int str2tag_core(const char *s, size_t l, - unsigned int h) { - return (l == 0) - ? h - : str2tag_core( - s + 1, l - 1, - // Unsets the 6 high bits of h, therefore no overflow happens - (((std::numeric_limits::max)() >> 6) & - h * 33) ^ - static_cast(*s)); -} - -inline unsigned int str2tag(const std::string &s) { - return str2tag_core(s.data(), s.size(), 0); -} - -namespace udl { - -inline constexpr unsigned int operator"" _t(const char *s, size_t l) { - return str2tag_core(s, l, 0); -} - -} // namespace udl - -inline std::string find_content_type( - const std::string &path, - const std::map &user_data, - const std::string &default_content_type) { - auto ext = file_extension(path); - - auto it = user_data.find(ext); - if (it != user_data.end()) { - return it->second; - } - - using udl::operator""_t; - - switch (str2tag(ext)) { - default: - return default_content_type; - - case "css"_t: - return "text/css"; - case "csv"_t: - return "text/csv"; - case "htm"_t: - case "html"_t: - return "text/html"; - case "js"_t: - case "mjs"_t: - return "text/javascript"; - case "txt"_t: - return "text/plain"; - case "vtt"_t: - return "text/vtt"; - - case "apng"_t: - return "image/apng"; - case "avif"_t: - return "image/avif"; - case "bmp"_t: - return "image/bmp"; - case "gif"_t: - return "image/gif"; - case "png"_t: - return "image/png"; - case "svg"_t: - return "image/svg+xml"; - case "webp"_t: - return "image/webp"; - case "ico"_t: - return "image/x-icon"; - case "tif"_t: - return "image/tiff"; - case "tiff"_t: - return "image/tiff"; - case "jpg"_t: - case "jpeg"_t: - return "image/jpeg"; - - case "mp4"_t: - return "video/mp4"; - case "mpeg"_t: - return "video/mpeg"; - case "webm"_t: - return "video/webm"; - - case "mp3"_t: - return "audio/mp3"; - case "mpga"_t: - return "audio/mpeg"; - case "weba"_t: - return "audio/webm"; - case "wav"_t: - return "audio/wave"; - - case "otf"_t: - return "font/otf"; - case "ttf"_t: - return "font/ttf"; - case "woff"_t: - return "font/woff"; - case "woff2"_t: - return "font/woff2"; - - case "7z"_t: - return "application/x-7z-compressed"; - case "atom"_t: - return "application/atom+xml"; - case "pdf"_t: - return "application/pdf"; - case "json"_t: - return "application/json"; - case "rss"_t: - return "application/rss+xml"; - case "tar"_t: - return "application/x-tar"; - case "xht"_t: - case "xhtml"_t: - return "application/xhtml+xml"; - case "xslt"_t: - return "application/xslt+xml"; - case "xml"_t: - return "application/xml"; - case "gz"_t: - return "application/gzip"; - case "zip"_t: - return "application/zip"; - case "wasm"_t: - return "application/wasm"; - } -} - -inline bool can_compress_content_type(const std::string &content_type) { - using udl::operator""_t; - - auto tag = str2tag(content_type); - - switch (tag) { - case "image/svg+xml"_t: - case "application/javascript"_t: - case "application/json"_t: - case "application/xml"_t: - case "application/protobuf"_t: - case "application/xhtml+xml"_t: - return true; - - case "text/event-stream"_t: - return false; - - default: - return !content_type.rfind("text/", 0); - } -} - -inline EncodingType encoding_type(const Request &req, const Response &res) { - auto ret = - detail::can_compress_content_type(res.get_header_value("Content-Type")); - if (!ret) { - return EncodingType::None; - } - - const auto &s = req.get_header_value("Accept-Encoding"); - (void)(s); - -#ifdef CPPHTTPLIB_BROTLI_SUPPORT - // TODO: 'Accept-Encoding' has br, not br;q=0 - ret = s.find("br") != std::string::npos; - if (ret) { - return EncodingType::Brotli; - } -#endif - -#ifdef CPPHTTPLIB_ZLIB_SUPPORT - // TODO: 'Accept-Encoding' has gzip, not gzip;q=0 - ret = s.find("gzip") != std::string::npos; - if (ret) { - return EncodingType::Gzip; - } -#endif - - return EncodingType::None; -} - -inline bool nocompressor::compress(const char *data, size_t data_length, - bool /*last*/, Callback callback) { - if (!data_length) { - return true; - } - return callback(data, data_length); -} - -#ifdef CPPHTTPLIB_ZLIB_SUPPORT -inline gzip_compressor::gzip_compressor() { - std::memset(&strm_, 0, sizeof(strm_)); - strm_.zalloc = Z_NULL; - strm_.zfree = Z_NULL; - strm_.opaque = Z_NULL; - - is_valid_ = deflateInit2(&strm_, Z_DEFAULT_COMPRESSION, Z_DEFLATED, 31, 8, - Z_DEFAULT_STRATEGY) == Z_OK; -} - -inline gzip_compressor::~gzip_compressor() { deflateEnd(&strm_); } - -inline bool gzip_compressor::compress(const char *data, size_t data_length, - bool last, Callback callback) { - assert(is_valid_); - - do { - constexpr size_t max_avail_in = - (std::numeric_limits::max)(); - - strm_.avail_in = static_cast( - (std::min)(data_length, max_avail_in)); - strm_.next_in = const_cast(reinterpret_cast(data)); - - data_length -= strm_.avail_in; - data += strm_.avail_in; - - auto flush = (last && data_length == 0) ? Z_FINISH : Z_NO_FLUSH; - auto ret = Z_OK; - - std::array buff{}; - do { - strm_.avail_out = static_cast(buff.size()); - strm_.next_out = reinterpret_cast(buff.data()); - - ret = deflate(&strm_, flush); - if (ret == Z_STREAM_ERROR) { - return false; - } - - if (!callback(buff.data(), buff.size() - strm_.avail_out)) { - return false; - } - } while (strm_.avail_out == 0); - - assert((flush == Z_FINISH && ret == Z_STREAM_END) || - (flush == Z_NO_FLUSH && ret == Z_OK)); - assert(strm_.avail_in == 0); - } while (data_length > 0); - - return true; -} - -inline gzip_decompressor::gzip_decompressor() { - std::memset(&strm_, 0, sizeof(strm_)); - strm_.zalloc = Z_NULL; - strm_.zfree = Z_NULL; - strm_.opaque = Z_NULL; - - // 15 is the value of wbits, which should be at the maximum possible value - // to ensure that any gzip stream can be decoded. The offset of 32 specifies - // that the stream type should be automatically detected either gzip or - // deflate. - is_valid_ = inflateInit2(&strm_, 32 + 15) == Z_OK; -} - -inline gzip_decompressor::~gzip_decompressor() { inflateEnd(&strm_); } - -inline bool gzip_decompressor::is_valid() const { return is_valid_; } - -inline bool gzip_decompressor::decompress(const char *data, size_t data_length, - Callback callback) { - assert(is_valid_); - - auto ret = Z_OK; - - do { - constexpr size_t max_avail_in = - (std::numeric_limits::max)(); - - strm_.avail_in = static_cast( - (std::min)(data_length, max_avail_in)); - strm_.next_in = const_cast(reinterpret_cast(data)); - - data_length -= strm_.avail_in; - data += strm_.avail_in; - - std::array buff{}; - while (strm_.avail_in > 0 && ret == Z_OK) { - strm_.avail_out = static_cast(buff.size()); - strm_.next_out = reinterpret_cast(buff.data()); - - ret = inflate(&strm_, Z_NO_FLUSH); - - assert(ret != Z_STREAM_ERROR); - switch (ret) { - case Z_NEED_DICT: - case Z_DATA_ERROR: - case Z_MEM_ERROR: - inflateEnd(&strm_); - return false; - } - - if (!callback(buff.data(), buff.size() - strm_.avail_out)) { - return false; - } - } - - if (ret != Z_OK && ret != Z_STREAM_END) { - return false; - } - - } while (data_length > 0); - - return true; -} -#endif - -#ifdef CPPHTTPLIB_BROTLI_SUPPORT -inline brotli_compressor::brotli_compressor() { - state_ = BrotliEncoderCreateInstance(nullptr, nullptr, nullptr); -} - -inline brotli_compressor::~brotli_compressor() { - BrotliEncoderDestroyInstance(state_); -} - -inline bool brotli_compressor::compress(const char *data, size_t data_length, - bool last, Callback callback) { - std::array buff{}; - - auto operation = last ? BROTLI_OPERATION_FINISH : BROTLI_OPERATION_PROCESS; - auto available_in = data_length; - auto next_in = reinterpret_cast(data); - - for (;;) { - if (last) { - if (BrotliEncoderIsFinished(state_)) { - break; - } - } else { - if (!available_in) { - break; - } - } - - auto available_out = buff.size(); - auto next_out = buff.data(); - - if (!BrotliEncoderCompressStream(state_, operation, &available_in, &next_in, - &available_out, &next_out, nullptr)) { - return false; - } - - auto output_bytes = buff.size() - available_out; - if (output_bytes) { - callback(reinterpret_cast(buff.data()), output_bytes); - } - } - - return true; -} - -inline brotli_decompressor::brotli_decompressor() { - decoder_s = BrotliDecoderCreateInstance(0, 0, 0); - decoder_r = decoder_s ? BROTLI_DECODER_RESULT_NEEDS_MORE_INPUT - : BROTLI_DECODER_RESULT_ERROR; -} - -inline brotli_decompressor::~brotli_decompressor() { - if (decoder_s) { - BrotliDecoderDestroyInstance(decoder_s); - } -} - -inline bool brotli_decompressor::is_valid() const { return decoder_s; } - -inline bool brotli_decompressor::decompress(const char *data, - size_t data_length, - Callback callback) { - if (decoder_r == BROTLI_DECODER_RESULT_SUCCESS || - decoder_r == BROTLI_DECODER_RESULT_ERROR) { - return 0; - } - - auto next_in = reinterpret_cast(data); - size_t avail_in = data_length; - size_t total_out; - - decoder_r = BROTLI_DECODER_RESULT_NEEDS_MORE_OUTPUT; - - std::array buff{}; - while (decoder_r == BROTLI_DECODER_RESULT_NEEDS_MORE_OUTPUT) { - char *next_out = buff.data(); - size_t avail_out = buff.size(); - - decoder_r = BrotliDecoderDecompressStream( - decoder_s, &avail_in, &next_in, &avail_out, - reinterpret_cast(&next_out), &total_out); - - if (decoder_r == BROTLI_DECODER_RESULT_ERROR) { - return false; - } - - if (!callback(buff.data(), buff.size() - avail_out)) { - return false; - } - } - - return decoder_r == BROTLI_DECODER_RESULT_SUCCESS || - decoder_r == BROTLI_DECODER_RESULT_NEEDS_MORE_INPUT; -} -#endif - -inline bool has_header(const Headers &headers, const std::string &key) { - return headers.find(key) != headers.end(); -} - -inline const char *get_header_value(const Headers &headers, - const std::string &key, const char *def, - size_t id) { - auto rng = headers.equal_range(key); - auto it = rng.first; - std::advance(it, static_cast(id)); - if (it != rng.second) { - return it->second.c_str(); - } - return def; -} - -template -inline bool parse_header(const char *beg, const char *end, T fn) { - // Skip trailing spaces and tabs. - while (beg < end && is_space_or_tab(end[-1])) { - end--; - } - - auto p = beg; - while (p < end && *p != ':') { - p++; - } - - if (p == end) { - return false; - } - - auto key_end = p; - - if (*p++ != ':') { - return false; - } - - while (p < end && is_space_or_tab(*p)) { - p++; - } - - if (p < end) { - auto key_len = key_end - beg; - if (!key_len) { - return false; - } - - auto key = std::string(beg, key_end); - auto val = case_ignore::equal(key, "Location") - ? std::string(p, end) - : decode_url(std::string(p, end), false); - - // NOTE: From RFC 9110: - // Field values containing CR, LF, or NUL characters are - // invalid and dangerous, due to the varying ways that - // implementations might parse and interpret those - // characters; a recipient of CR, LF, or NUL within a field - // value MUST either reject the message or replace each of - // those characters with SP before further processing or - // forwarding of that message. - static const std::string CR_LF_NUL("\r\n\0", 3); - if (val.find_first_of(CR_LF_NUL) != std::string::npos) { - return false; - } - - fn(key, val); - return true; - } - - return false; -} - -inline bool read_headers(Stream &strm, Headers &headers) { - const auto bufsiz = 2048; - char buf[bufsiz]; - stream_line_reader line_reader(strm, buf, bufsiz); - - for (;;) { - if (!line_reader.getline()) { - return false; - } - - // Check if the line ends with CRLF. - auto line_terminator_len = 2; - if (line_reader.end_with_crlf()) { - // Blank line indicates end of headers. - if (line_reader.size() == 2) { - break; - } - } else { -#ifdef CPPHTTPLIB_ALLOW_LF_AS_LINE_TERMINATOR - // Blank line indicates end of headers. - if (line_reader.size() == 1) { - break; - } - line_terminator_len = 1; -#else - continue; // Skip invalid line. -#endif - } - - if (line_reader.size() > CPPHTTPLIB_HEADER_MAX_LENGTH) { - return false; - } - - // Exclude line terminator - auto end = line_reader.ptr() + line_reader.size() - line_terminator_len; - - if (!parse_header(line_reader.ptr(), end, - [&](const std::string &key, std::string &val) { - headers.emplace(key, val); - })) { - return false; - } - } - - return true; -} - -inline bool read_content_with_length(Stream &strm, uint64_t len, - Progress progress, - ContentReceiverWithProgress out) { - char buf[CPPHTTPLIB_RECV_BUFSIZ]; - - uint64_t r = 0; - while (r < len) { - auto read_len = static_cast(len - r); - auto n = strm.read(buf, (std::min)(read_len, CPPHTTPLIB_RECV_BUFSIZ)); - if (n <= 0) { - return false; - } - - if (!out(buf, static_cast(n), r, len)) { - return false; - } - r += static_cast(n); - - if (progress) { - if (!progress(r, len)) { - return false; - } - } - } - - return true; -} - -inline void skip_content_with_length(Stream &strm, uint64_t len) { - char buf[CPPHTTPLIB_RECV_BUFSIZ]; - uint64_t r = 0; - while (r < len) { - auto read_len = static_cast(len - r); - auto n = strm.read(buf, (std::min)(read_len, CPPHTTPLIB_RECV_BUFSIZ)); - if (n <= 0) { - return; - } - r += static_cast(n); - } -} - -inline bool read_content_without_length(Stream &strm, - ContentReceiverWithProgress out) { - char buf[CPPHTTPLIB_RECV_BUFSIZ]; - uint64_t r = 0; - for (;;) { - auto n = strm.read(buf, CPPHTTPLIB_RECV_BUFSIZ); - if (n <= 0) { - return true; - } - - if (!out(buf, static_cast(n), r, 0)) { - return false; - } - r += static_cast(n); - } - - return true; -} - -template -inline bool read_content_chunked(Stream &strm, T &x, - ContentReceiverWithProgress out) { - const auto bufsiz = 16; - char buf[bufsiz]; - - stream_line_reader line_reader(strm, buf, bufsiz); - - if (!line_reader.getline()) { - return false; - } - - unsigned long chunk_len; - while (true) { - char *end_ptr; - - chunk_len = std::strtoul(line_reader.ptr(), &end_ptr, 16); - - if (end_ptr == line_reader.ptr()) { - return false; - } - if (chunk_len == ULONG_MAX) { - return false; - } - - if (chunk_len == 0) { - break; - } - - if (!read_content_with_length(strm, chunk_len, nullptr, out)) { - return false; - } - - if (!line_reader.getline()) { - return false; - } - - if (strcmp(line_reader.ptr(), "\r\n") != 0) { - return false; - } - - if (!line_reader.getline()) { - return false; - } - } - - assert(chunk_len == 0); - - // NOTE: In RFC 9112, '7.1 Chunked Transfer Coding' mentiones "The chunked - // transfer coding is complete when a chunk with a chunk-size of zero is - // received, possibly followed by a trailer section, and finally terminated by - // an empty line". https://www.rfc-editor.org/rfc/rfc9112.html#section-7.1 - // - // In '7.1.3. Decoding Chunked', however, the pseudo-code in the section - // does't care for the existence of the final CRLF. In other words, it seems - // to be ok whether the final CRLF exists or not in the chunked data. - // https://www.rfc-editor.org/rfc/rfc9112.html#section-7.1.3 - // - // According to the reference code in RFC 9112, cpp-htpplib now allows - // chuncked transfer coding data without the final CRLF. - if (!line_reader.getline()) { - return true; - } - - while (strcmp(line_reader.ptr(), "\r\n") != 0) { - if (line_reader.size() > CPPHTTPLIB_HEADER_MAX_LENGTH) { - return false; - } - - // Exclude line terminator - constexpr auto line_terminator_len = 2; - auto end = line_reader.ptr() + line_reader.size() - line_terminator_len; - - parse_header(line_reader.ptr(), end, - [&](const std::string &key, const std::string &val) { - x.headers.emplace(key, val); - }); - - if (!line_reader.getline()) { - return false; - } - } - - return true; -} - -inline bool is_chunked_transfer_encoding(const Headers &headers) { - return case_ignore::equal( - get_header_value(headers, "Transfer-Encoding", "", 0), "chunked"); -} - -template -bool prepare_content_receiver(T &x, int &status, - ContentReceiverWithProgress receiver, - bool decompress, U callback) { - if (decompress) { - std::string encoding = x.get_header_value("Content-Encoding"); - std::unique_ptr decompressor; - - if (encoding == "gzip" || encoding == "deflate") { -#ifdef CPPHTTPLIB_ZLIB_SUPPORT - decompressor = detail::make_unique(); -#else - status = StatusCode::UnsupportedMediaType_415; - return false; -#endif - } else if (encoding.find("br") != std::string::npos) { -#ifdef CPPHTTPLIB_BROTLI_SUPPORT - decompressor = detail::make_unique(); -#else - status = StatusCode::UnsupportedMediaType_415; - return false; -#endif - } - - if (decompressor) { - if (decompressor->is_valid()) { - ContentReceiverWithProgress out = [&](const char *buf, size_t n, - uint64_t off, uint64_t len) { - return decompressor->decompress(buf, n, - [&](const char *buf2, size_t n2) { - return receiver(buf2, n2, off, len); - }); - }; - return callback(std::move(out)); - } else { - status = StatusCode::InternalServerError_500; - return false; - } - } - } - - ContentReceiverWithProgress out = [&](const char *buf, size_t n, uint64_t off, - uint64_t len) { - return receiver(buf, n, off, len); - }; - return callback(std::move(out)); -} - -template -bool read_content(Stream &strm, T &x, size_t payload_max_length, int &status, - Progress progress, ContentReceiverWithProgress receiver, - bool decompress) { - return prepare_content_receiver( - x, status, std::move(receiver), decompress, - [&](const ContentReceiverWithProgress &out) { - auto ret = true; - auto exceed_payload_max_length = false; - - if (is_chunked_transfer_encoding(x.headers)) { - ret = read_content_chunked(strm, x, out); - } else if (!has_header(x.headers, "Content-Length")) { - ret = read_content_without_length(strm, out); - } else { - auto len = get_header_value_u64(x.headers, "Content-Length", 0, 0); - if (len > payload_max_length) { - exceed_payload_max_length = true; - skip_content_with_length(strm, len); - ret = false; - } else if (len > 0) { - ret = read_content_with_length(strm, len, std::move(progress), out); - } - } - - if (!ret) { - status = exceed_payload_max_length ? StatusCode::PayloadTooLarge_413 - : StatusCode::BadRequest_400; - } - return ret; - }); -} - -inline ssize_t write_request_line(Stream &strm, const std::string &method, - const std::string &path) { - std::string s = method; - s += " "; - s += path; - s += " HTTP/1.1\r\n"; - return strm.write(s.data(), s.size()); -} - -inline ssize_t write_response_line(Stream &strm, int status) { - std::string s = "HTTP/1.1 "; - s += std::to_string(status); - s += " "; - s += httplib::status_message(status); - s += "\r\n"; - return strm.write(s.data(), s.size()); -} - -inline ssize_t write_headers(Stream &strm, const Headers &headers) { - ssize_t write_len = 0; - for (const auto &x : headers) { - std::string s; - s = x.first; - s += ": "; - s += x.second; - s += "\r\n"; - - auto len = strm.write(s.data(), s.size()); - if (len < 0) { - return len; - } - write_len += len; - } - auto len = strm.write("\r\n"); - if (len < 0) { - return len; - } - write_len += len; - return write_len; -} - -inline bool write_data(Stream &strm, const char *d, size_t l) { - size_t offset = 0; - while (offset < l) { - auto length = strm.write(d + offset, l - offset); - if (length < 0) { - return false; - } - offset += static_cast(length); - } - return true; -} - -template -inline bool write_content(Stream &strm, const ContentProvider &content_provider, - size_t offset, size_t length, T is_shutting_down, - Error &error) { - size_t end_offset = offset + length; - auto ok = true; - DataSink data_sink; - - data_sink.write = [&](const char *d, size_t l) -> bool { - if (ok) { - if (strm.is_writable() && write_data(strm, d, l)) { - offset += l; - } else { - ok = false; - } - } - return ok; - }; - - data_sink.is_writable = [&]() -> bool { return strm.is_writable(); }; - - while (offset < end_offset && !is_shutting_down()) { - if (!strm.is_writable()) { - error = Error::Write; - return false; - } else if (!content_provider(offset, end_offset - offset, data_sink)) { - error = Error::Canceled; - return false; - } else if (!ok) { - error = Error::Write; - return false; - } - } - - error = Error::Success; - return true; -} - -template -inline bool write_content(Stream &strm, const ContentProvider &content_provider, - size_t offset, size_t length, - const T &is_shutting_down) { - auto error = Error::Success; - return write_content(strm, content_provider, offset, length, is_shutting_down, - error); -} - -template -inline bool write_content_without_length( - Stream &strm, const ContentProvider &content_provider, - const T &is_shutting_down) { - size_t offset = 0; - auto data_available = true; - auto ok = true; - DataSink data_sink; - - data_sink.write = [&](const char *d, size_t l) -> bool { - if (ok) { - offset += l; - if (!strm.is_writable() || !write_data(strm, d, l)) { - ok = false; - } - } - return ok; - }; - - data_sink.is_writable = [&]() -> bool { return strm.is_writable(); }; - - data_sink.done = [&](void) { data_available = false; }; - - while (data_available && !is_shutting_down()) { - if (!strm.is_writable()) { - return false; - } else if (!content_provider(offset, 0, data_sink)) { - return false; - } else if (!ok) { - return false; - } - } - return true; -} - -template -inline bool write_content_chunked(Stream &strm, - const ContentProvider &content_provider, - const T &is_shutting_down, U &compressor, - Error &error) { - size_t offset = 0; - auto data_available = true; - auto ok = true; - DataSink data_sink; - - data_sink.write = [&](const char *d, size_t l) -> bool { - if (ok) { - data_available = l > 0; - offset += l; - - std::string payload; - if (compressor.compress(d, l, false, - [&](const char *data, size_t data_len) { - payload.append(data, data_len); - return true; - })) { - if (!payload.empty()) { - // Emit chunked response header and footer for each chunk - auto chunk = - from_i_to_hex(payload.size()) + "\r\n" + payload + "\r\n"; - if (!strm.is_writable() || - !write_data(strm, chunk.data(), chunk.size())) { - ok = false; - } - } - } else { - ok = false; - } - } - return ok; - }; - - data_sink.is_writable = [&]() -> bool { return strm.is_writable(); }; - - auto done_with_trailer = [&](const Headers *trailer) { - if (!ok) { - return; - } - - data_available = false; - - std::string payload; - if (!compressor.compress(nullptr, 0, true, - [&](const char *data, size_t data_len) { - payload.append(data, data_len); - return true; - })) { - ok = false; - return; - } - - if (!payload.empty()) { - // Emit chunked response header and footer for each chunk - auto chunk = from_i_to_hex(payload.size()) + "\r\n" + payload + "\r\n"; - if (!strm.is_writable() || - !write_data(strm, chunk.data(), chunk.size())) { - ok = false; - return; - } - } - - static const std::string done_marker("0\r\n"); - if (!write_data(strm, done_marker.data(), done_marker.size())) { - ok = false; - } - - // Trailer - if (trailer) { - for (const auto &kv : *trailer) { - std::string field_line = kv.first + ": " + kv.second + "\r\n"; - if (!write_data(strm, field_line.data(), field_line.size())) { - ok = false; - } - } - } - - static const std::string crlf("\r\n"); - if (!write_data(strm, crlf.data(), crlf.size())) { - ok = false; - } - }; - - data_sink.done = [&](void) { done_with_trailer(nullptr); }; - - data_sink.done_with_trailer = [&](const Headers &trailer) { - done_with_trailer(&trailer); - }; - - while (data_available && !is_shutting_down()) { - if (!strm.is_writable()) { - error = Error::Write; - return false; - } else if (!content_provider(offset, 0, data_sink)) { - error = Error::Canceled; - return false; - } else if (!ok) { - error = Error::Write; - return false; - } - } - - error = Error::Success; - return true; -} - -template -inline bool write_content_chunked(Stream &strm, - const ContentProvider &content_provider, - const T &is_shutting_down, U &compressor) { - auto error = Error::Success; - return write_content_chunked(strm, content_provider, is_shutting_down, - compressor, error); -} - -template -inline bool redirect(T &cli, Request &req, Response &res, - const std::string &path, const std::string &location, - Error &error) { - Request new_req = req; - new_req.path = path; - new_req.redirect_count_ -= 1; - - if (res.status == StatusCode::SeeOther_303 && - (req.method != "GET" && req.method != "HEAD")) { - new_req.method = "GET"; - new_req.body.clear(); - new_req.headers.clear(); - } - - Response new_res; - - auto ret = cli.send(new_req, new_res, error); - if (ret) { - req = new_req; - res = new_res; - - if (res.location.empty()) { - res.location = location; - } - } - return ret; -} - -inline std::string params_to_query_str(const Params ¶ms) { - std::string query; - - for (auto it = params.begin(); it != params.end(); ++it) { - if (it != params.begin()) { - query += "&"; - } - query += it->first; - query += "="; - query += encode_query_param(it->second); - } - return query; -} - -inline void parse_query_text(const char *data, std::size_t size, - Params ¶ms) { - std::set cache; - split(data, data + size, '&', [&](const char *b, const char *e) { - std::string kv(b, e); - if (cache.find(kv) != cache.end()) { - return; - } - cache.insert(std::move(kv)); - - std::string key; - std::string val; - divide(b, static_cast(e - b), '=', - [&](const char *lhs_data, std::size_t lhs_size, const char *rhs_data, - std::size_t rhs_size) { - key.assign(lhs_data, lhs_size); - val.assign(rhs_data, rhs_size); - }); - - if (!key.empty()) { - params.emplace(decode_url(key, true), decode_url(val, true)); - } - }); -} - -inline void parse_query_text(const std::string &s, Params ¶ms) { - parse_query_text(s.data(), s.size(), params); -} - -inline bool parse_multipart_boundary(const std::string &content_type, - std::string &boundary) { - auto boundary_keyword = "boundary="; - auto pos = content_type.find(boundary_keyword); - if (pos == std::string::npos) { - return false; - } - auto end = content_type.find(';', pos); - auto beg = pos + strlen(boundary_keyword); - boundary = trim_double_quotes_copy(content_type.substr(beg, end - beg)); - return !boundary.empty(); -} - -inline void parse_disposition_params(const std::string &s, Params ¶ms) { - std::set cache; - split(s.data(), s.data() + s.size(), ';', [&](const char *b, const char *e) { - std::string kv(b, e); - if (cache.find(kv) != cache.end()) { - return; - } - cache.insert(kv); - - std::string key; - std::string val; - split(b, e, '=', [&](const char *b2, const char *e2) { - if (key.empty()) { - key.assign(b2, e2); - } else { - val.assign(b2, e2); - } - }); - - if (!key.empty()) { - params.emplace(trim_double_quotes_copy((key)), - trim_double_quotes_copy((val))); - } - }); -} - -#ifdef CPPHTTPLIB_NO_EXCEPTIONS -inline bool parse_range_header(const std::string &s, Ranges &ranges) { -#else -inline bool parse_range_header(const std::string &s, Ranges &ranges) try { -#endif - auto is_valid = [](const std::string &str) { - return std::all_of(str.cbegin(), str.cend(), - [](unsigned char c) { return std::isdigit(c); }); - }; - - if (s.size() > 7 && s.compare(0, 6, "bytes=") == 0) { - const auto pos = static_cast(6); - const auto len = static_cast(s.size() - 6); - auto all_valid_ranges = true; - split(&s[pos], &s[pos + len], ',', [&](const char *b, const char *e) { - if (!all_valid_ranges) { - return; - } - - const auto it = std::find(b, e, '-'); - if (it == e) { - all_valid_ranges = false; - return; - } - - const auto lhs = std::string(b, it); - const auto rhs = std::string(it + 1, e); - if (!is_valid(lhs) || !is_valid(rhs)) { - all_valid_ranges = false; - return; - } - - const auto first = - static_cast(lhs.empty() ? -1 : std::stoll(lhs)); - const auto last = - static_cast(rhs.empty() ? -1 : std::stoll(rhs)); - if ((first == -1 && last == -1) || - (first != -1 && last != -1 && first > last)) { - all_valid_ranges = false; - return; - } - - ranges.emplace_back(first, last); - }); - return all_valid_ranges && !ranges.empty(); - } - return false; -#ifdef CPPHTTPLIB_NO_EXCEPTIONS -} -#else -} catch (...) { - return false; -} -#endif - -class MultipartFormDataParser { - public: - MultipartFormDataParser() = default; - - void set_boundary(std::string &&boundary) { - boundary_ = boundary; - dash_boundary_crlf_ = dash_ + boundary_ + crlf_; - crlf_dash_boundary_ = crlf_ + dash_ + boundary_; - } - - bool is_valid() const { return is_valid_; } - - bool parse(const char *buf, size_t n, const ContentReceiver &content_callback, - const MultipartContentHeader &header_callback) { - buf_append(buf, n); - - while (buf_size() > 0) { - switch (state_) { - case 0: { // Initial boundary - buf_erase(buf_find(dash_boundary_crlf_)); - if (dash_boundary_crlf_.size() > buf_size()) { - return true; - } - if (!buf_start_with(dash_boundary_crlf_)) { - return false; - } - buf_erase(dash_boundary_crlf_.size()); - state_ = 1; - break; - } - case 1: { // New entry - clear_file_info(); - state_ = 2; - break; - } - case 2: { // Headers - auto pos = buf_find(crlf_); - if (pos > CPPHTTPLIB_HEADER_MAX_LENGTH) { - return false; - } - while (pos < buf_size()) { - // Empty line - if (pos == 0) { - if (!header_callback(file_)) { - is_valid_ = false; - return false; - } - buf_erase(crlf_.size()); - state_ = 3; - break; - } - - const auto header = buf_head(pos); - - if (!parse_header( - header.data(), header.data() + header.size(), - [&](const std::string &, const std::string &) {})) { - is_valid_ = false; - return false; - } - - static const std::string header_content_type = "Content-Type:"; - - if (start_with_case_ignore(header, header_content_type)) { - file_.content_type = - trim_copy(header.substr(header_content_type.size())); - } else { - static const std::regex re_content_disposition( - R"~(^Content-Disposition:\s*form-data;\s*(.*)$)~", - std::regex_constants::icase); - - std::smatch m; - if (std::regex_match(header, m, re_content_disposition)) { - Params params; - parse_disposition_params(m[1], params); - - auto it = params.find("name"); - if (it != params.end()) { - file_.name = it->second; - } else { - is_valid_ = false; - return false; - } - - it = params.find("filename"); - if (it != params.end()) { - file_.filename = it->second; - } - - it = params.find("filename*"); - if (it != params.end()) { - // Only allow UTF-8 enconnding... - static const std::regex re_rfc5987_encoding( - R"~(^UTF-8''(.+?)$)~", std::regex_constants::icase); - - std::smatch m2; - if (std::regex_match(it->second, m2, re_rfc5987_encoding)) { - file_.filename = decode_url(m2[1], false); // override... - } else { - is_valid_ = false; - return false; - } - } - } - } - buf_erase(pos + crlf_.size()); - pos = buf_find(crlf_); - } - if (state_ != 3) { - return true; - } - break; - } - case 3: { // Body - if (crlf_dash_boundary_.size() > buf_size()) { - return true; - } - auto pos = buf_find(crlf_dash_boundary_); - if (pos < buf_size()) { - if (!content_callback(buf_data(), pos)) { - is_valid_ = false; - return false; - } - buf_erase(pos + crlf_dash_boundary_.size()); - state_ = 4; - } else { - auto len = buf_size() - crlf_dash_boundary_.size(); - if (len > 0) { - if (!content_callback(buf_data(), len)) { - is_valid_ = false; - return false; - } - buf_erase(len); - } - return true; - } - break; - } - case 4: { // Boundary - if (crlf_.size() > buf_size()) { - return true; - } - if (buf_start_with(crlf_)) { - buf_erase(crlf_.size()); - state_ = 1; - } else { - if (dash_.size() > buf_size()) { - return true; - } - if (buf_start_with(dash_)) { - buf_erase(dash_.size()); - is_valid_ = true; - buf_erase(buf_size()); // Remove epilogue - } else { - return true; - } - } - break; - } - } - } - - return true; - } - - private: - void clear_file_info() { - file_.name.clear(); - file_.filename.clear(); - file_.content_type.clear(); - } - - bool start_with_case_ignore(const std::string &a, - const std::string &b) const { - if (a.size() < b.size()) { - return false; - } - for (size_t i = 0; i < b.size(); i++) { - if (case_ignore::to_lower(a[i]) != case_ignore::to_lower(b[i])) { - return false; - } - } - return true; - } - - const std::string dash_ = "--"; - const std::string crlf_ = "\r\n"; - std::string boundary_; - std::string dash_boundary_crlf_; - std::string crlf_dash_boundary_; - - size_t state_ = 0; - bool is_valid_ = false; - MultipartFormData file_; - - // Buffer - bool start_with(const std::string &a, size_t spos, size_t epos, - const std::string &b) const { - if (epos - spos < b.size()) { - return false; - } - for (size_t i = 0; i < b.size(); i++) { - if (a[i + spos] != b[i]) { - return false; - } - } - return true; - } - - size_t buf_size() const { return buf_epos_ - buf_spos_; } - - const char *buf_data() const { return &buf_[buf_spos_]; } - - std::string buf_head(size_t l) const { return buf_.substr(buf_spos_, l); } - - bool buf_start_with(const std::string &s) const { - return start_with(buf_, buf_spos_, buf_epos_, s); - } - - size_t buf_find(const std::string &s) const { - auto c = s.front(); - - size_t off = buf_spos_; - while (off < buf_epos_) { - auto pos = off; - while (true) { - if (pos == buf_epos_) { - return buf_size(); - } - if (buf_[pos] == c) { - break; - } - pos++; - } - - auto remaining_size = buf_epos_ - pos; - if (s.size() > remaining_size) { - return buf_size(); - } - - if (start_with(buf_, pos, buf_epos_, s)) { - return pos - buf_spos_; - } - - off = pos + 1; - } - - return buf_size(); - } - - void buf_append(const char *data, size_t n) { - auto remaining_size = buf_size(); - if (remaining_size > 0 && buf_spos_ > 0) { - for (size_t i = 0; i < remaining_size; i++) { - buf_[i] = buf_[buf_spos_ + i]; - } - } - buf_spos_ = 0; - buf_epos_ = remaining_size; - - if (remaining_size + n > buf_.size()) { - buf_.resize(remaining_size + n); - } - - for (size_t i = 0; i < n; i++) { - buf_[buf_epos_ + i] = data[i]; - } - buf_epos_ += n; - } - - void buf_erase(size_t size) { buf_spos_ += size; } - - std::string buf_; - size_t buf_spos_ = 0; - size_t buf_epos_ = 0; -}; - -inline std::string random_string(size_t length) { - static const char data[] = - "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; - - // std::random_device might actually be deterministic on some - // platforms, but due to lack of support in the c++ standard library, - // doing better requires either some ugly hacks or breaking portability. - static std::random_device seed_gen; - - // Request 128 bits of entropy for initialization - static std::seed_seq seed_sequence{seed_gen(), seed_gen(), seed_gen(), - seed_gen()}; - - static std::mt19937 engine(seed_sequence); - - std::string result; - for (size_t i = 0; i < length; i++) { - result += data[engine() % (sizeof(data) - 1)]; - } - return result; -} - -inline std::string make_multipart_data_boundary() { - return "--cpp-httplib-multipart-data-" + detail::random_string(16); -} - -inline bool is_multipart_boundary_chars_valid(const std::string &boundary) { - auto valid = true; - for (size_t i = 0; i < boundary.size(); i++) { - auto c = boundary[i]; - if (!std::isalnum(c) && c != '-' && c != '_') { - valid = false; - break; - } - } - return valid; -} - -template -inline std::string serialize_multipart_formdata_item_begin( - const T &item, const std::string &boundary) { - std::string body = "--" + boundary + "\r\n"; - body += "Content-Disposition: form-data; name=\"" + item.name + "\""; - if (!item.filename.empty()) { - body += "; filename=\"" + item.filename + "\""; - } - body += "\r\n"; - if (!item.content_type.empty()) { - body += "Content-Type: " + item.content_type + "\r\n"; - } - body += "\r\n"; - - return body; -} - -inline std::string serialize_multipart_formdata_item_end() { return "\r\n"; } - -inline std::string serialize_multipart_formdata_finish( - const std::string &boundary) { - return "--" + boundary + "--\r\n"; -} - -inline std::string serialize_multipart_formdata_get_content_type( - const std::string &boundary) { - return "multipart/form-data; boundary=" + boundary; -} - -inline std::string serialize_multipart_formdata( - const MultipartFormDataItems &items, const std::string &boundary, - bool finish = true) { - std::string body; - - for (const auto &item : items) { - body += serialize_multipart_formdata_item_begin(item, boundary); - body += item.content + serialize_multipart_formdata_item_end(); - } - - if (finish) { - body += serialize_multipart_formdata_finish(boundary); - } - - return body; -} - -inline bool range_error(Request &req, Response &res) { - if (!req.ranges.empty() && 200 <= res.status && res.status < 300) { - ssize_t contant_len = static_cast( - res.content_length_ ? res.content_length_ : res.body.size()); - - ssize_t prev_first_pos = -1; - ssize_t prev_last_pos = -1; - size_t overwrapping_count = 0; - - // NOTE: The following Range check is based on '14.2. Range' in RFC 9110 - // 'HTTP Semantics' to avoid potential denial-of-service attacks. - // https://www.rfc-editor.org/rfc/rfc9110#section-14.2 - - // Too many ranges - if (req.ranges.size() > CPPHTTPLIB_RANGE_MAX_COUNT) { - return true; - } - - for (auto &r : req.ranges) { - auto &first_pos = r.first; - auto &last_pos = r.second; - - if (first_pos == -1 && last_pos == -1) { - first_pos = 0; - last_pos = contant_len; - } - - if (first_pos == -1) { - first_pos = contant_len - last_pos; - last_pos = contant_len - 1; - } - - if (last_pos == -1) { - last_pos = contant_len - 1; - } - - // Range must be within content length - if (!(0 <= first_pos && first_pos <= last_pos && - last_pos <= contant_len - 1)) { - return true; - } - - // Ranges must be in ascending order - if (first_pos <= prev_first_pos) { - return true; - } - - // Request must not have more than two overlapping ranges - if (first_pos <= prev_last_pos) { - overwrapping_count++; - if (overwrapping_count > 2) { - return true; - } - } - - prev_first_pos = (std::max)(prev_first_pos, first_pos); - prev_last_pos = (std::max)(prev_last_pos, last_pos); - } - } - - return false; -} - -inline std::pair get_range_offset_and_length( - Range r, size_t content_length) { - assert(r.first != -1 && r.second != -1); - assert(0 <= r.first && r.first < static_cast(content_length)); - assert(r.first <= r.second && - r.second < static_cast(content_length)); - (void)(content_length); - return std::make_pair(r.first, static_cast(r.second - r.first) + 1); -} - -inline std::string make_content_range_header_field( - const std::pair &offset_and_length, size_t content_length) { - auto st = offset_and_length.first; - auto ed = st + offset_and_length.second - 1; - - std::string field = "bytes "; - field += std::to_string(st); - field += "-"; - field += std::to_string(ed); - field += "/"; - field += std::to_string(content_length); - return field; -} - -template -bool process_multipart_ranges_data(const Request &req, - const std::string &boundary, - const std::string &content_type, - size_t content_length, SToken stoken, - CToken ctoken, Content content) { - for (size_t i = 0; i < req.ranges.size(); i++) { - ctoken("--"); - stoken(boundary); - ctoken("\r\n"); - if (!content_type.empty()) { - ctoken("Content-Type: "); - stoken(content_type); - ctoken("\r\n"); - } - - auto offset_and_length = - get_range_offset_and_length(req.ranges[i], content_length); - - ctoken("Content-Range: "); - stoken(make_content_range_header_field(offset_and_length, content_length)); - ctoken("\r\n"); - ctoken("\r\n"); - - if (!content(offset_and_length.first, offset_and_length.second)) { - return false; - } - ctoken("\r\n"); - } - - ctoken("--"); - stoken(boundary); - ctoken("--"); - - return true; -} - -inline void make_multipart_ranges_data(const Request &req, Response &res, - const std::string &boundary, - const std::string &content_type, - size_t content_length, - std::string &data) { - process_multipart_ranges_data( - req, boundary, content_type, content_length, - [&](const std::string &token) { data += token; }, - [&](const std::string &token) { data += token; }, - [&](size_t offset, size_t length) { - assert(offset + length <= content_length); - data += res.body.substr(offset, length); - return true; - }); -} - -inline size_t get_multipart_ranges_data_length(const Request &req, - const std::string &boundary, - const std::string &content_type, - size_t content_length) { - size_t data_length = 0; - - process_multipart_ranges_data( - req, boundary, content_type, content_length, - [&](const std::string &token) { data_length += token.size(); }, - [&](const std::string &token) { data_length += token.size(); }, - [&](size_t /*offset*/, size_t length) { - data_length += length; - return true; - }); - - return data_length; -} - -template -inline bool write_multipart_ranges_data(Stream &strm, const Request &req, - Response &res, - const std::string &boundary, - const std::string &content_type, - size_t content_length, - const T &is_shutting_down) { - return process_multipart_ranges_data( - req, boundary, content_type, content_length, - [&](const std::string &token) { strm.write(token); }, - [&](const std::string &token) { strm.write(token); }, - [&](size_t offset, size_t length) { - return write_content(strm, res.content_provider_, offset, length, - is_shutting_down); - }); -} - -inline bool expect_content(const Request &req) { - if (req.method == "POST" || req.method == "PUT" || req.method == "PATCH" || - req.method == "PRI" || req.method == "DELETE") { - return true; - } - // TODO: check if Content-Length is set - return false; -} - -inline bool has_crlf(const std::string &s) { - auto p = s.c_str(); - while (*p) { - if (*p == '\r' || *p == '\n') { - return true; - } - p++; - } - return false; -} - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -inline std::string message_digest(const std::string &s, const EVP_MD *algo) { - auto context = std::unique_ptr( - EVP_MD_CTX_new(), EVP_MD_CTX_free); - - unsigned int hash_length = 0; - unsigned char hash[EVP_MAX_MD_SIZE]; - - EVP_DigestInit_ex(context.get(), algo, nullptr); - EVP_DigestUpdate(context.get(), s.c_str(), s.size()); - EVP_DigestFinal_ex(context.get(), hash, &hash_length); - - std::stringstream ss; - for (auto i = 0u; i < hash_length; ++i) { - ss << std::hex << std::setw(2) << std::setfill('0') - << static_cast(hash[i]); - } - - return ss.str(); -} - -inline std::string MD5(const std::string &s) { - return message_digest(s, EVP_md5()); -} - -inline std::string SHA_256(const std::string &s) { - return message_digest(s, EVP_sha256()); -} - -inline std::string SHA_512(const std::string &s) { - return message_digest(s, EVP_sha512()); -} -#endif - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -#ifdef _WIN32 -// NOTE: This code came up with the following stackoverflow post: -// https://stackoverflow.com/questions/9507184/can-openssl-on-windows-use-the-system-certificate-store -inline bool load_system_certs_on_windows(X509_STORE *store) { - auto hStore = CertOpenSystemStoreW((HCRYPTPROV_LEGACY)NULL, L"ROOT"); - if (!hStore) { - return false; - } - - auto result = false; - PCCERT_CONTEXT pContext = NULL; - while ((pContext = CertEnumCertificatesInStore(hStore, pContext)) != - nullptr) { - auto encoded_cert = - static_cast(pContext->pbCertEncoded); - - auto x509 = d2i_X509(NULL, &encoded_cert, pContext->cbCertEncoded); - if (x509) { - X509_STORE_add_cert(store, x509); - X509_free(x509); - result = true; - } - } - - CertFreeCertificateContext(pContext); - CertCloseStore(hStore, 0); - - return result; -} -#elif defined(CPPHTTPLIB_USE_CERTS_FROM_MACOSX_KEYCHAIN) && defined(__APPLE__) -#if TARGET_OS_OSX -template -using CFObjectPtr = - std::unique_ptr::type, void (*)(CFTypeRef)>; - -inline void cf_object_ptr_deleter(CFTypeRef obj) { - if (obj) { - CFRelease(obj); - } -} - -inline bool retrieve_certs_from_keychain(CFObjectPtr &certs) { - CFStringRef keys[] = {kSecClass, kSecMatchLimit, kSecReturnRef}; - CFTypeRef values[] = {kSecClassCertificate, kSecMatchLimitAll, - kCFBooleanTrue}; - - CFObjectPtr query( - CFDictionaryCreate(nullptr, reinterpret_cast(keys), values, - sizeof(keys) / sizeof(keys[0]), - &kCFTypeDictionaryKeyCallBacks, - &kCFTypeDictionaryValueCallBacks), - cf_object_ptr_deleter); - - if (!query) { - return false; - } - - CFTypeRef security_items = nullptr; - if (SecItemCopyMatching(query.get(), &security_items) != errSecSuccess || - CFArrayGetTypeID() != CFGetTypeID(security_items)) { - return false; - } - - certs.reset(reinterpret_cast(security_items)); - return true; -} - -inline bool retrieve_root_certs_from_keychain(CFObjectPtr &certs) { - CFArrayRef root_security_items = nullptr; - if (SecTrustCopyAnchorCertificates(&root_security_items) != errSecSuccess) { - return false; - } - - certs.reset(root_security_items); - return true; -} - -inline bool add_certs_to_x509_store(CFArrayRef certs, X509_STORE *store) { - auto result = false; - for (auto i = 0; i < CFArrayGetCount(certs); ++i) { - const auto cert = reinterpret_cast( - CFArrayGetValueAtIndex(certs, i)); - - if (SecCertificateGetTypeID() != CFGetTypeID(cert)) { - continue; - } - - CFDataRef cert_data = nullptr; - if (SecItemExport(cert, kSecFormatX509Cert, 0, nullptr, &cert_data) != - errSecSuccess) { - continue; - } - - CFObjectPtr cert_data_ptr(cert_data, cf_object_ptr_deleter); - - auto encoded_cert = static_cast( - CFDataGetBytePtr(cert_data_ptr.get())); - - auto x509 = - d2i_X509(NULL, &encoded_cert, CFDataGetLength(cert_data_ptr.get())); - - if (x509) { - X509_STORE_add_cert(store, x509); - X509_free(x509); - result = true; - } - } - - return result; -} - -inline bool load_system_certs_on_macos(X509_STORE *store) { - auto result = false; - CFObjectPtr certs(nullptr, cf_object_ptr_deleter); - if (retrieve_certs_from_keychain(certs) && certs) { - result = add_certs_to_x509_store(certs.get(), store); - } - - if (retrieve_root_certs_from_keychain(certs) && certs) { - result = add_certs_to_x509_store(certs.get(), store) || result; - } - - return result; -} -#endif // TARGET_OS_OSX -#endif // _WIN32 -#endif // CPPHTTPLIB_OPENSSL_SUPPORT - -#ifdef _WIN32 -class WSInit { - public: - WSInit() { - WSADATA wsaData; - if (WSAStartup(0x0002, &wsaData) == 0) is_valid_ = true; - } - - ~WSInit() { - if (is_valid_) WSACleanup(); - } - - bool is_valid_ = false; -}; - -static WSInit wsinit_; -#endif - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -inline std::pair make_digest_authentication_header( - const Request &req, const std::map &auth, - size_t cnonce_count, const std::string &cnonce, const std::string &username, - const std::string &password, bool is_proxy = false) { - std::string nc; - { - std::stringstream ss; - ss << std::setfill('0') << std::setw(8) << std::hex << cnonce_count; - nc = ss.str(); - } - - std::string qop; - if (auth.find("qop") != auth.end()) { - qop = auth.at("qop"); - if (qop.find("auth-int") != std::string::npos) { - qop = "auth-int"; - } else if (qop.find("auth") != std::string::npos) { - qop = "auth"; - } else { - qop.clear(); - } - } - - std::string algo = "MD5"; - if (auth.find("algorithm") != auth.end()) { - algo = auth.at("algorithm"); - } - - std::string response; - { - auto H = algo == "SHA-256" ? detail::SHA_256 - : algo == "SHA-512" ? detail::SHA_512 - : detail::MD5; - - auto A1 = username + ":" + auth.at("realm") + ":" + password; - - auto A2 = req.method + ":" + req.path; - if (qop == "auth-int") { - A2 += ":" + H(req.body); - } - - if (qop.empty()) { - response = H(H(A1) + ":" + auth.at("nonce") + ":" + H(A2)); - } else { - response = H(H(A1) + ":" + auth.at("nonce") + ":" + nc + ":" + cnonce + - ":" + qop + ":" + H(A2)); - } - } - - auto opaque = (auth.find("opaque") != auth.end()) ? auth.at("opaque") : ""; - - auto field = "Digest username=\"" + username + "\", realm=\"" + - auth.at("realm") + "\", nonce=\"" + auth.at("nonce") + - "\", uri=\"" + req.path + "\", algorithm=" + algo + - (qop.empty() ? ", response=\"" - : ", qop=" + qop + ", nc=" + nc + ", cnonce=\"" + - cnonce + "\", response=\"") + - response + "\"" + - (opaque.empty() ? "" : ", opaque=\"" + opaque + "\""); - - auto key = is_proxy ? "Proxy-Authorization" : "Authorization"; - return std::make_pair(key, field); -} -#endif - -inline bool parse_www_authenticate(const Response &res, - std::map &auth, - bool is_proxy) { - auto auth_key = is_proxy ? "Proxy-Authenticate" : "WWW-Authenticate"; - if (res.has_header(auth_key)) { - static auto re = std::regex(R"~((?:(?:,\s*)?(.+?)=(?:"(.*?)"|([^,]*))))~"); - auto s = res.get_header_value(auth_key); - auto pos = s.find(' '); - if (pos != std::string::npos) { - auto type = s.substr(0, pos); - if (type == "Basic") { - return false; - } else if (type == "Digest") { - s = s.substr(pos + 1); - auto beg = std::sregex_iterator(s.begin(), s.end(), re); - for (auto i = beg; i != std::sregex_iterator(); ++i) { - const auto &m = *i; - auto key = s.substr(static_cast(m.position(1)), - static_cast(m.length(1))); - auto val = m.length(2) > 0 - ? s.substr(static_cast(m.position(2)), - static_cast(m.length(2))) - : s.substr(static_cast(m.position(3)), - static_cast(m.length(3))); - auth[key] = val; - } - return true; - } - } - } - return false; -} - -class ContentProviderAdapter { - public: - explicit ContentProviderAdapter( - ContentProviderWithoutLength &&content_provider) - : content_provider_(content_provider) {} - - bool operator()(size_t offset, size_t, DataSink &sink) { - return content_provider_(offset, sink); - } - - private: - ContentProviderWithoutLength content_provider_; -}; - -} // namespace detail - -inline std::string hosted_at(const std::string &hostname) { - std::vector addrs; - hosted_at(hostname, addrs); - if (addrs.empty()) { - return std::string(); - } - return addrs[0]; -} - -inline void hosted_at(const std::string &hostname, - std::vector &addrs) { - struct addrinfo hints; - struct addrinfo *result; - - memset(&hints, 0, sizeof(struct addrinfo)); - hints.ai_family = AF_UNSPEC; - hints.ai_socktype = SOCK_STREAM; - hints.ai_protocol = 0; - - if (getaddrinfo(hostname.c_str(), nullptr, &hints, &result)) { -#if defined __linux__ && !defined __ANDROID__ - res_init(); -#endif - return; - } - auto se = detail::scope_exit([&] { freeaddrinfo(result); }); - - for (auto rp = result; rp; rp = rp->ai_next) { - const auto &addr = - *reinterpret_cast(rp->ai_addr); - std::string ip; - auto dummy = -1; - if (detail::get_ip_and_port(addr, sizeof(struct sockaddr_storage), ip, - dummy)) { - addrs.push_back(ip); - } - } -} - -inline std::string append_query_params(const std::string &path, - const Params ¶ms) { - std::string path_with_query = path; - const static std::regex re("[^?]+\\?.*"); - auto delm = std::regex_match(path, re) ? '&' : '?'; - path_with_query += delm + detail::params_to_query_str(params); - return path_with_query; -} - -// Header utilities -inline std::pair make_range_header( - const Ranges &ranges) { - std::string field = "bytes="; - auto i = 0; - for (const auto &r : ranges) { - if (i != 0) { - field += ", "; - } - if (r.first != -1) { - field += std::to_string(r.first); - } - field += '-'; - if (r.second != -1) { - field += std::to_string(r.second); - } - i++; - } - return std::make_pair("Range", std::move(field)); -} - -inline std::pair make_basic_authentication_header( - const std::string &username, const std::string &password, bool is_proxy) { - auto field = "Basic " + detail::base64_encode(username + ":" + password); - auto key = is_proxy ? "Proxy-Authorization" : "Authorization"; - return std::make_pair(key, std::move(field)); -} - -inline std::pair -make_bearer_token_authentication_header(const std::string &token, - bool is_proxy = false) { - auto field = "Bearer " + token; - auto key = is_proxy ? "Proxy-Authorization" : "Authorization"; - return std::make_pair(key, std::move(field)); -} - -// Request implementation -inline bool Request::has_header(const std::string &key) const { - return detail::has_header(headers, key); -} - -inline std::string Request::get_header_value(const std::string &key, - const char *def, size_t id) const { - return detail::get_header_value(headers, key, def, id); -} - -inline size_t Request::get_header_value_count(const std::string &key) const { - auto r = headers.equal_range(key); - return static_cast(std::distance(r.first, r.second)); -} - -inline void Request::set_header(const std::string &key, - const std::string &val) { - if (!detail::has_crlf(key) && !detail::has_crlf(val)) { - headers.emplace(key, val); - } -} - -inline bool Request::has_param(const std::string &key) const { - return params.find(key) != params.end(); -} - -inline std::string Request::get_param_value(const std::string &key, - size_t id) const { - auto rng = params.equal_range(key); - auto it = rng.first; - std::advance(it, static_cast(id)); - if (it != rng.second) { - return it->second; - } - return std::string(); -} - -inline size_t Request::get_param_value_count(const std::string &key) const { - auto r = params.equal_range(key); - return static_cast(std::distance(r.first, r.second)); -} - -inline bool Request::is_multipart_form_data() const { - const auto &content_type = get_header_value("Content-Type"); - return !content_type.rfind("multipart/form-data", 0); -} - -inline bool Request::has_file(const std::string &key) const { - return files.find(key) != files.end(); -} - -inline MultipartFormData Request::get_file_value(const std::string &key) const { - auto it = files.find(key); - if (it != files.end()) { - return it->second; - } - return MultipartFormData(); -} - -inline std::vector Request::get_file_values( - const std::string &key) const { - std::vector values; - auto rng = files.equal_range(key); - for (auto it = rng.first; it != rng.second; it++) { - values.push_back(it->second); - } - return values; -} - -// Response implementation -inline bool Response::has_header(const std::string &key) const { - return headers.find(key) != headers.end(); -} - -inline std::string Response::get_header_value(const std::string &key, - const char *def, - size_t id) const { - return detail::get_header_value(headers, key, def, id); -} - -inline size_t Response::get_header_value_count(const std::string &key) const { - auto r = headers.equal_range(key); - return static_cast(std::distance(r.first, r.second)); -} - -inline void Response::set_header(const std::string &key, - const std::string &val) { - if (!detail::has_crlf(key) && !detail::has_crlf(val)) { - headers.emplace(key, val); - } -} - -inline void Response::set_redirect(const std::string &url, int stat) { - if (!detail::has_crlf(url)) { - set_header("Location", url); - if (300 <= stat && stat < 400) { - this->status = stat; - } else { - this->status = StatusCode::Found_302; - } - } -} - -inline void Response::set_content(const char *s, size_t n, - const std::string &content_type) { - body.assign(s, n); - - auto rng = headers.equal_range("Content-Type"); - headers.erase(rng.first, rng.second); - set_header("Content-Type", content_type); -} - -inline void Response::set_content(const std::string &s, - const std::string &content_type) { - set_content(s.data(), s.size(), content_type); -} - -inline void Response::set_content(std::string &&s, - const std::string &content_type) { - body = std::move(s); - - auto rng = headers.equal_range("Content-Type"); - headers.erase(rng.first, rng.second); - set_header("Content-Type", content_type); -} - -inline void Response::set_content_provider( - size_t in_length, const std::string &content_type, ContentProvider provider, - ContentProviderResourceReleaser resource_releaser) { - set_header("Content-Type", content_type); - content_length_ = in_length; - if (in_length > 0) { - content_provider_ = std::move(provider); - } - content_provider_resource_releaser_ = std::move(resource_releaser); - is_chunked_content_provider_ = false; -} - -inline void Response::set_content_provider( - const std::string &content_type, ContentProviderWithoutLength provider, - ContentProviderResourceReleaser resource_releaser) { - set_header("Content-Type", content_type); - content_length_ = 0; - content_provider_ = detail::ContentProviderAdapter(std::move(provider)); - content_provider_resource_releaser_ = std::move(resource_releaser); - is_chunked_content_provider_ = false; -} - -inline void Response::set_chunked_content_provider( - const std::string &content_type, ContentProviderWithoutLength provider, - ContentProviderResourceReleaser resource_releaser) { - set_header("Content-Type", content_type); - content_length_ = 0; - content_provider_ = detail::ContentProviderAdapter(std::move(provider)); - content_provider_resource_releaser_ = std::move(resource_releaser); - is_chunked_content_provider_ = true; -} - -inline void Response::set_file_content(const std::string &path, - const std::string &content_type) { - file_content_path_ = path; - file_content_content_type_ = content_type; -} - -inline void Response::set_file_content(const std::string &path) { - file_content_path_ = path; -} - -// Result implementation -inline bool Result::has_request_header(const std::string &key) const { - return request_headers_.find(key) != request_headers_.end(); -} - -inline std::string Result::get_request_header_value(const std::string &key, - const char *def, - size_t id) const { - return detail::get_header_value(request_headers_, key, def, id); -} - -inline size_t Result::get_request_header_value_count( - const std::string &key) const { - auto r = request_headers_.equal_range(key); - return static_cast(std::distance(r.first, r.second)); -} - -// Stream implementation -inline ssize_t Stream::write(const char *ptr) { - return write(ptr, strlen(ptr)); -} - -inline ssize_t Stream::write(const std::string &s) { - return write(s.data(), s.size()); -} - -namespace detail { - -// Socket stream implementation -inline SocketStream::SocketStream(socket_t sock, time_t read_timeout_sec, - time_t read_timeout_usec, - time_t write_timeout_sec, - time_t write_timeout_usec) - : sock_(sock), - read_timeout_sec_(read_timeout_sec), - read_timeout_usec_(read_timeout_usec), - write_timeout_sec_(write_timeout_sec), - write_timeout_usec_(write_timeout_usec), - read_buff_(read_buff_size_, 0) {} - -inline SocketStream::~SocketStream() = default; - -inline bool SocketStream::is_readable() const { - return select_read(sock_, read_timeout_sec_, read_timeout_usec_) > 0; -} - -inline bool SocketStream::is_writable() const { - return select_write(sock_, write_timeout_sec_, write_timeout_usec_) > 0 && - is_socket_alive(sock_); -} - -inline ssize_t SocketStream::read(char *ptr, size_t size) { -#ifdef _WIN32 - size = - (std::min)(size, static_cast((std::numeric_limits::max)())); -#else - size = (std::min)(size, - static_cast((std::numeric_limits::max)())); -#endif - - if (read_buff_off_ < read_buff_content_size_) { - auto remaining_size = read_buff_content_size_ - read_buff_off_; - if (size <= remaining_size) { - memcpy(ptr, read_buff_.data() + read_buff_off_, size); - read_buff_off_ += size; - return static_cast(size); - } else { - memcpy(ptr, read_buff_.data() + read_buff_off_, remaining_size); - read_buff_off_ += remaining_size; - return static_cast(remaining_size); - } - } - - if (!is_readable()) { - return -1; - } - - read_buff_off_ = 0; - read_buff_content_size_ = 0; - - if (size < read_buff_size_) { - auto n = read_socket(sock_, read_buff_.data(), read_buff_size_, - CPPHTTPLIB_RECV_FLAGS); - if (n <= 0) { - return n; - } else if (n <= static_cast(size)) { - memcpy(ptr, read_buff_.data(), static_cast(n)); - return n; - } else { - memcpy(ptr, read_buff_.data(), size); - read_buff_off_ = size; - read_buff_content_size_ = static_cast(n); - return static_cast(size); - } - } else { - return read_socket(sock_, ptr, size, CPPHTTPLIB_RECV_FLAGS); - } -} - -inline ssize_t SocketStream::write(const char *ptr, size_t size) { - if (!is_writable()) { - return -1; - } - -#if defined(_WIN32) && !defined(_WIN64) - size = - (std::min)(size, static_cast((std::numeric_limits::max)())); -#endif - - return send_socket(sock_, ptr, size, CPPHTTPLIB_SEND_FLAGS); -} - -inline void SocketStream::get_remote_ip_and_port(std::string &ip, - int &port) const { - return detail::get_remote_ip_and_port(sock_, ip, port); -} - -inline void SocketStream::get_local_ip_and_port(std::string &ip, - int &port) const { - return detail::get_local_ip_and_port(sock_, ip, port); -} - -inline socket_t SocketStream::socket() const { return sock_; } - -// Buffer stream implementation -inline bool BufferStream::is_readable() const { return true; } - -inline bool BufferStream::is_writable() const { return true; } - -inline ssize_t BufferStream::read(char *ptr, size_t size) { -#if defined(_MSC_VER) && _MSC_VER < 1910 - auto len_read = buffer._Copy_s(ptr, size, size, position); -#else - auto len_read = buffer.copy(ptr, size, position); -#endif - position += static_cast(len_read); - return static_cast(len_read); -} - -inline ssize_t BufferStream::write(const char *ptr, size_t size) { - buffer.append(ptr, size); - return static_cast(size); -} - -inline void BufferStream::get_remote_ip_and_port(std::string & /*ip*/, - int & /*port*/) const {} - -inline void BufferStream::get_local_ip_and_port(std::string & /*ip*/, - int & /*port*/) const {} - -inline socket_t BufferStream::socket() const { return 0; } - -inline const std::string &BufferStream::get_buffer() const { return buffer; } - -inline PathParamsMatcher::PathParamsMatcher(const std::string &pattern) { - static constexpr char marker[] = "/:"; - - // One past the last ending position of a path param substring - std::size_t last_param_end = 0; - -#ifndef CPPHTTPLIB_NO_EXCEPTIONS - // Needed to ensure that parameter names are unique during matcher - // construction - // If exceptions are disabled, only last duplicate path - // parameter will be set - std::unordered_set param_name_set; -#endif - - while (true) { - const auto marker_pos = pattern.find( - marker, last_param_end == 0 ? last_param_end : last_param_end - 1); - if (marker_pos == std::string::npos) { - break; - } - - static_fragments_.push_back( - pattern.substr(last_param_end, marker_pos - last_param_end + 1)); - - const auto param_name_start = marker_pos + 2; - - auto sep_pos = pattern.find(separator, param_name_start); - if (sep_pos == std::string::npos) { - sep_pos = pattern.length(); - } - - auto param_name = - pattern.substr(param_name_start, sep_pos - param_name_start); - -#ifndef CPPHTTPLIB_NO_EXCEPTIONS - if (param_name_set.find(param_name) != param_name_set.cend()) { - std::string msg = "Encountered path parameter '" + param_name + - "' multiple times in route pattern '" + pattern + "'."; - throw std::invalid_argument(msg); - } -#endif - - param_names_.push_back(std::move(param_name)); - - last_param_end = sep_pos + 1; - } - - if (last_param_end < pattern.length()) { - static_fragments_.push_back(pattern.substr(last_param_end)); - } -} - -inline bool PathParamsMatcher::match(Request &request) const { - request.matches = std::smatch(); - request.path_params.clear(); - request.path_params.reserve(param_names_.size()); - - // One past the position at which the path matched the pattern last time - std::size_t starting_pos = 0; - for (size_t i = 0; i < static_fragments_.size(); ++i) { - const auto &fragment = static_fragments_[i]; - - if (starting_pos + fragment.length() > request.path.length()) { - return false; - } - - // Avoid unnecessary allocation by using strncmp instead of substr + - // comparison - if (std::strncmp(request.path.c_str() + starting_pos, fragment.c_str(), - fragment.length()) != 0) { - return false; - } - - starting_pos += fragment.length(); - - // Should only happen when we have a static fragment after a param - // Example: '/users/:id/subscriptions' - // The 'subscriptions' fragment here does not have a corresponding param - if (i >= param_names_.size()) { - continue; - } - - auto sep_pos = request.path.find(separator, starting_pos); - if (sep_pos == std::string::npos) { - sep_pos = request.path.length(); - } - - const auto ¶m_name = param_names_[i]; - - request.path_params.emplace( - param_name, request.path.substr(starting_pos, sep_pos - starting_pos)); - - // Mark everything up to '/' as matched - starting_pos = sep_pos + 1; - } - // Returns false if the path is longer than the pattern - return starting_pos >= request.path.length(); -} - -inline bool RegexMatcher::match(Request &request) const { - request.path_params.clear(); - return std::regex_match(request.path, request.matches, regex_); -} - -} // namespace detail - -// HTTP server implementation -inline Server::Server() - : new_task_queue( - [] { return new ThreadPool(CPPHTTPLIB_THREAD_POOL_COUNT); }) { -#ifndef _WIN32 - signal(SIGPIPE, SIG_IGN); -#endif -} - -inline Server::~Server() = default; - -inline std::unique_ptr Server::make_matcher( - const std::string &pattern) { - if (pattern.find("/:") != std::string::npos) { - return detail::make_unique(pattern); - } else { - return detail::make_unique(pattern); - } -} - -inline Server &Server::Get(const std::string &pattern, Handler handler) { - get_handlers_.emplace_back(make_matcher(pattern), std::move(handler)); - return *this; -} - -inline Server &Server::Post(const std::string &pattern, Handler handler) { - post_handlers_.emplace_back(make_matcher(pattern), std::move(handler)); - return *this; -} - -inline Server &Server::Post(const std::string &pattern, - HandlerWithContentReader handler) { - post_handlers_for_content_reader_.emplace_back(make_matcher(pattern), - std::move(handler)); - return *this; -} - -inline Server &Server::Put(const std::string &pattern, Handler handler) { - put_handlers_.emplace_back(make_matcher(pattern), std::move(handler)); - return *this; -} - -inline Server &Server::Put(const std::string &pattern, - HandlerWithContentReader handler) { - put_handlers_for_content_reader_.emplace_back(make_matcher(pattern), - std::move(handler)); - return *this; -} - -inline Server &Server::Patch(const std::string &pattern, Handler handler) { - patch_handlers_.emplace_back(make_matcher(pattern), std::move(handler)); - return *this; -} - -inline Server &Server::Patch(const std::string &pattern, - HandlerWithContentReader handler) { - patch_handlers_for_content_reader_.emplace_back(make_matcher(pattern), - std::move(handler)); - return *this; -} - -inline Server &Server::Delete(const std::string &pattern, Handler handler) { - delete_handlers_.emplace_back(make_matcher(pattern), std::move(handler)); - return *this; -} - -inline Server &Server::Delete(const std::string &pattern, - HandlerWithContentReader handler) { - delete_handlers_for_content_reader_.emplace_back(make_matcher(pattern), - std::move(handler)); - return *this; -} - -inline Server &Server::Options(const std::string &pattern, Handler handler) { - options_handlers_.emplace_back(make_matcher(pattern), std::move(handler)); - return *this; -} - -inline bool Server::set_base_dir(const std::string &dir, - const std::string &mount_point) { - return set_mount_point(mount_point, dir); -} - -inline bool Server::set_mount_point(const std::string &mount_point, - const std::string &dir, Headers headers) { - detail::FileStat stat(dir); - if (stat.is_dir()) { - std::string mnt = !mount_point.empty() ? mount_point : "/"; - if (!mnt.empty() && mnt[0] == '/') { - base_dirs_.push_back({mnt, dir, std::move(headers)}); - return true; - } - } - return false; -} - -inline bool Server::remove_mount_point(const std::string &mount_point) { - for (auto it = base_dirs_.begin(); it != base_dirs_.end(); ++it) { - if (it->mount_point == mount_point) { - base_dirs_.erase(it); - return true; - } - } - return false; -} - -inline Server &Server::set_file_extension_and_mimetype_mapping( - const std::string &ext, const std::string &mime) { - file_extension_and_mimetype_map_[ext] = mime; - return *this; -} - -inline Server &Server::set_default_file_mimetype(const std::string &mime) { - default_file_mimetype_ = mime; - return *this; -} - -inline Server &Server::set_file_request_handler(Handler handler) { - file_request_handler_ = std::move(handler); - return *this; -} - -inline Server &Server::set_error_handler_core(HandlerWithResponse handler, - std::true_type) { - error_handler_ = std::move(handler); - return *this; -} - -inline Server &Server::set_error_handler_core(Handler handler, - std::false_type) { - error_handler_ = [handler](const Request &req, Response &res) { - handler(req, res); - return HandlerResponse::Handled; - }; - return *this; -} - -inline Server &Server::set_exception_handler(ExceptionHandler handler) { - exception_handler_ = std::move(handler); - return *this; -} - -inline Server &Server::set_pre_routing_handler(HandlerWithResponse handler) { - pre_routing_handler_ = std::move(handler); - return *this; -} - -inline Server &Server::set_post_routing_handler(Handler handler) { - post_routing_handler_ = std::move(handler); - return *this; -} - -inline Server &Server::set_logger(Logger logger) { - logger_ = std::move(logger); - return *this; -} - -inline Server &Server::set_expect_100_continue_handler( - Expect100ContinueHandler handler) { - expect_100_continue_handler_ = std::move(handler); - return *this; -} - -inline Server &Server::set_address_family(int family) { - address_family_ = family; - return *this; -} - -inline Server &Server::set_tcp_nodelay(bool on) { - tcp_nodelay_ = on; - return *this; -} - -inline Server &Server::set_ipv6_v6only(bool on) { - ipv6_v6only_ = on; - return *this; -} - -inline Server &Server::set_socket_options(SocketOptions socket_options) { - socket_options_ = std::move(socket_options); - return *this; -} - -inline Server &Server::set_default_headers(Headers headers) { - default_headers_ = std::move(headers); - return *this; -} - -inline Server &Server::set_header_writer( - std::function const &writer) { - header_writer_ = writer; - return *this; -} - -inline Server &Server::set_keep_alive_max_count(size_t count) { - keep_alive_max_count_ = count; - return *this; -} - -inline Server &Server::set_keep_alive_timeout(time_t sec) { - keep_alive_timeout_sec_ = sec; - return *this; -} - -inline Server &Server::set_read_timeout(time_t sec, time_t usec) { - read_timeout_sec_ = sec; - read_timeout_usec_ = usec; - return *this; -} - -inline Server &Server::set_write_timeout(time_t sec, time_t usec) { - write_timeout_sec_ = sec; - write_timeout_usec_ = usec; - return *this; -} - -inline Server &Server::set_idle_interval(time_t sec, time_t usec) { - idle_interval_sec_ = sec; - idle_interval_usec_ = usec; - return *this; -} - -inline Server &Server::set_payload_max_length(size_t length) { - payload_max_length_ = length; - return *this; -} - -inline bool Server::bind_to_port(const std::string &host, int port, - int socket_flags) { - auto ret = bind_internal(host, port, socket_flags); - if (ret == -1) { - is_decommisioned = true; - } - return ret >= 0; -} -inline int Server::bind_to_any_port(const std::string &host, int socket_flags) { - auto ret = bind_internal(host, 0, socket_flags); - if (ret == -1) { - is_decommisioned = true; - } - return ret; -} - -inline bool Server::listen_after_bind() { return listen_internal(); } - -inline bool Server::listen(const std::string &host, int port, - int socket_flags) { - return bind_to_port(host, port, socket_flags) && listen_internal(); -} - -inline bool Server::is_running() const { return is_running_; } - -inline void Server::wait_until_ready() const { - while (!is_running_ && !is_decommisioned) { - std::this_thread::sleep_for(std::chrono::milliseconds{1}); - } -} - -inline void Server::stop() { - if (is_running_) { - assert(svr_sock_ != INVALID_SOCKET); - std::atomic sock(svr_sock_.exchange(INVALID_SOCKET)); - detail::shutdown_socket(sock); - detail::close_socket(sock); - } - is_decommisioned = false; -} - -inline void Server::decommission() { is_decommisioned = true; } - -inline bool Server::parse_request_line(const char *s, Request &req) const { - auto len = strlen(s); - if (len < 2 || s[len - 2] != '\r' || s[len - 1] != '\n') { - return false; - } - len -= 2; - - { - size_t count = 0; - - detail::split(s, s + len, ' ', [&](const char *b, const char *e) { - switch (count) { - case 0: - req.method = std::string(b, e); - break; - case 1: - req.target = std::string(b, e); - break; - case 2: - req.version = std::string(b, e); - break; - default: - break; - } - count++; - }); - - if (count != 3) { - return false; - } - } - - static const std::set methods{ - "GET", "HEAD", "POST", "PUT", "DELETE", - "CONNECT", "OPTIONS", "TRACE", "PATCH", "PRI"}; - - if (methods.find(req.method) == methods.end()) { - return false; - } - - if (req.version != "HTTP/1.1" && req.version != "HTTP/1.0") { - return false; - } - - { - // Skip URL fragment - for (size_t i = 0; i < req.target.size(); i++) { - if (req.target[i] == '#') { - req.target.erase(i); - break; - } - } - - detail::divide(req.target, '?', - [&](const char *lhs_data, std::size_t lhs_size, - const char *rhs_data, std::size_t rhs_size) { - req.path = detail::decode_url( - std::string(lhs_data, lhs_size), false); - detail::parse_query_text(rhs_data, rhs_size, req.params); - }); - } - - return true; -} - -inline bool Server::write_response(Stream &strm, bool close_connection, - Request &req, Response &res) { - // NOTE: `req.ranges` should be empty, otherwise it will be applied - // incorrectly to the error content. - req.ranges.clear(); - return write_response_core(strm, close_connection, req, res, false); -} - -inline bool Server::write_response_with_content(Stream &strm, - bool close_connection, - const Request &req, - Response &res) { - return write_response_core(strm, close_connection, req, res, true); -} - -inline bool Server::write_response_core(Stream &strm, bool close_connection, - const Request &req, Response &res, - bool need_apply_ranges) { - assert(res.status != -1); - - if (400 <= res.status && error_handler_ && - error_handler_(req, res) == HandlerResponse::Handled) { - need_apply_ranges = true; - } - - std::string content_type; - std::string boundary; - if (need_apply_ranges) { - apply_ranges(req, res, content_type, boundary); - } - - // Prepare additional headers - if (close_connection || req.get_header_value("Connection") == "close") { - res.set_header("Connection", "close"); - } else { - std::string s = "timeout="; - s += std::to_string(keep_alive_timeout_sec_); - s += ", max="; - s += std::to_string(keep_alive_max_count_); - res.set_header("Keep-Alive", s); - } - - if ((!res.body.empty() || res.content_length_ > 0 || res.content_provider_) && - !res.has_header("Content-Type")) { - res.set_header("Content-Type", "text/plain"); - } - - if (res.body.empty() && !res.content_length_ && !res.content_provider_ && - !res.has_header("Content-Length")) { - res.set_header("Content-Length", "0"); - } - - if (req.method == "HEAD" && !res.has_header("Accept-Ranges")) { - res.set_header("Accept-Ranges", "bytes"); - } - - if (post_routing_handler_) { - post_routing_handler_(req, res); - } - - // Response line and headers - { - detail::BufferStream bstrm; - if (!detail::write_response_line(bstrm, res.status)) { - return false; - } - if (!header_writer_(bstrm, res.headers)) { - return false; - } - - // Flush buffer - auto &data = bstrm.get_buffer(); - detail::write_data(strm, data.data(), data.size()); - } - - // Body - auto ret = true; - if (req.method != "HEAD") { - if (!res.body.empty()) { - if (!detail::write_data(strm, res.body.data(), res.body.size())) { - ret = false; - } - } else if (res.content_provider_) { - if (write_content_with_provider(strm, req, res, boundary, content_type)) { - res.content_provider_success_ = true; - } else { - ret = false; - } - } - } - - // Log - if (logger_) { - logger_(req, res); - } - - return ret; -} - -inline bool Server::write_content_with_provider( - Stream &strm, const Request &req, Response &res, - const std::string &boundary, const std::string &content_type) { - auto is_shutting_down = [this]() { - return this->svr_sock_ == INVALID_SOCKET; - }; - - if (res.content_length_ > 0) { - if (req.ranges.empty()) { - return detail::write_content(strm, res.content_provider_, 0, - res.content_length_, is_shutting_down); - } else if (req.ranges.size() == 1) { - auto offset_and_length = detail::get_range_offset_and_length( - req.ranges[0], res.content_length_); - - return detail::write_content(strm, res.content_provider_, - offset_and_length.first, - offset_and_length.second, is_shutting_down); - } else { - return detail::write_multipart_ranges_data( - strm, req, res, boundary, content_type, res.content_length_, - is_shutting_down); - } - } else { - if (res.is_chunked_content_provider_) { - auto type = detail::encoding_type(req, res); - - std::unique_ptr compressor; - if (type == detail::EncodingType::Gzip) { -#ifdef CPPHTTPLIB_ZLIB_SUPPORT - compressor = detail::make_unique(); -#endif - } else if (type == detail::EncodingType::Brotli) { -#ifdef CPPHTTPLIB_BROTLI_SUPPORT - compressor = detail::make_unique(); -#endif - } else { - compressor = detail::make_unique(); - } - assert(compressor != nullptr); - - return detail::write_content_chunked(strm, res.content_provider_, - is_shutting_down, *compressor); - } else { - return detail::write_content_without_length(strm, res.content_provider_, - is_shutting_down); - } - } -} - -inline bool Server::read_content(Stream &strm, Request &req, Response &res) { - MultipartFormDataMap::iterator cur; - auto file_count = 0; - if (read_content_core( - strm, req, res, - // Regular - [&](const char *buf, size_t n) { - if (req.body.size() + n > req.body.max_size()) { - return false; - } - req.body.append(buf, n); - return true; - }, - // Multipart - [&](const MultipartFormData &file) { - if (file_count++ == CPPHTTPLIB_MULTIPART_FORM_DATA_FILE_MAX_COUNT) { - return false; - } - cur = req.files.emplace(file.name, file); - return true; - }, - [&](const char *buf, size_t n) { - auto &content = cur->second.content; - if (content.size() + n > content.max_size()) { - return false; - } - content.append(buf, n); - return true; - })) { - const auto &content_type = req.get_header_value("Content-Type"); - if (!content_type.find("application/x-www-form-urlencoded")) { - if (req.body.size() > CPPHTTPLIB_FORM_URL_ENCODED_PAYLOAD_MAX_LENGTH) { - res.status = StatusCode::PayloadTooLarge_413; // NOTE: should be 414? - return false; - } - detail::parse_query_text(req.body, req.params); - } - return true; - } - return false; -} - -inline bool Server::read_content_with_content_receiver( - Stream &strm, Request &req, Response &res, ContentReceiver receiver, - MultipartContentHeader multipart_header, - ContentReceiver multipart_receiver) { - return read_content_core(strm, req, res, std::move(receiver), - std::move(multipart_header), - std::move(multipart_receiver)); -} - -inline bool Server::read_content_core( - Stream &strm, Request &req, Response &res, ContentReceiver receiver, - MultipartContentHeader multipart_header, - ContentReceiver multipart_receiver) const { - detail::MultipartFormDataParser multipart_form_data_parser; - ContentReceiverWithProgress out; - - if (req.is_multipart_form_data()) { - const auto &content_type = req.get_header_value("Content-Type"); - std::string boundary; - if (!detail::parse_multipart_boundary(content_type, boundary)) { - res.status = StatusCode::BadRequest_400; - return false; - } - - multipart_form_data_parser.set_boundary(std::move(boundary)); - out = [&](const char *buf, size_t n, uint64_t /*off*/, uint64_t /*len*/) { - /* For debug - size_t pos = 0; - while (pos < n) { - auto read_size = (std::min)(1, n - pos); - auto ret = multipart_form_data_parser.parse( - buf + pos, read_size, multipart_receiver, multipart_header); - if (!ret) { return false; } - pos += read_size; - } - return true; - */ - return multipart_form_data_parser.parse(buf, n, multipart_receiver, - multipart_header); - }; - } else { - out = [receiver](const char *buf, size_t n, uint64_t /*off*/, - uint64_t /*len*/) { return receiver(buf, n); }; - } - - if (req.method == "DELETE" && !req.has_header("Content-Length")) { - return true; - } - - if (!detail::read_content(strm, req, payload_max_length_, res.status, nullptr, - out, true)) { - return false; - } - - if (req.is_multipart_form_data()) { - if (!multipart_form_data_parser.is_valid()) { - res.status = StatusCode::BadRequest_400; - return false; - } - } - - return true; -} - -inline bool Server::handle_file_request(const Request &req, Response &res, - bool head) { - for (const auto &entry : base_dirs_) { - // Prefix match - if (!req.path.compare(0, entry.mount_point.size(), entry.mount_point)) { - std::string sub_path = "/" + req.path.substr(entry.mount_point.size()); - if (detail::is_valid_path(sub_path)) { - auto path = entry.base_dir + sub_path; - if (path.back() == '/') { - path += "index.html"; - } - - detail::FileStat stat(path); - - if (stat.is_dir()) { - res.set_redirect(sub_path + "/", StatusCode::MovedPermanently_301); - return true; - } - - if (stat.is_file()) { - for (const auto &kv : entry.headers) { - res.set_header(kv.first, kv.second); - } - - auto mm = std::make_shared(path.c_str()); - if (!mm->is_open()) { - return false; - } - - res.set_content_provider( - mm->size(), - detail::find_content_type(path, file_extension_and_mimetype_map_, - default_file_mimetype_), - [mm](size_t offset, size_t length, DataSink &sink) -> bool { - sink.write(mm->data() + offset, length); - return true; - }); - - if (!head && file_request_handler_) { - file_request_handler_(req, res); - } - - return true; - } - } - } - } - return false; -} - -inline socket_t Server::create_server_socket( - const std::string &host, int port, int socket_flags, - SocketOptions socket_options) const { - return detail::create_socket( - host, std::string(), port, address_family_, socket_flags, tcp_nodelay_, - ipv6_v6only_, std::move(socket_options), - [](socket_t sock, struct addrinfo &ai, bool & /*quit*/) -> bool { - if (::bind(sock, ai.ai_addr, static_cast(ai.ai_addrlen))) { - return false; - } - if (::listen(sock, CPPHTTPLIB_LISTEN_BACKLOG)) { - return false; - } - return true; - }); -} - -inline int Server::bind_internal(const std::string &host, int port, - int socket_flags) { - if (is_decommisioned) { - return -1; - } - - if (!is_valid()) { - return -1; - } - - svr_sock_ = create_server_socket(host, port, socket_flags, socket_options_); - if (svr_sock_ == INVALID_SOCKET) { - return -1; - } - - if (port == 0) { - struct sockaddr_storage addr; - socklen_t addr_len = sizeof(addr); - if (getsockname(svr_sock_, reinterpret_cast(&addr), - &addr_len) == -1) { - return -1; - } - if (addr.ss_family == AF_INET) { - return ntohs(reinterpret_cast(&addr)->sin_port); - } else if (addr.ss_family == AF_INET6) { - return ntohs(reinterpret_cast(&addr)->sin6_port); - } else { - return -1; - } - } else { - return port; - } -} - -inline bool Server::listen_internal() { - if (is_decommisioned) { - return false; - } - - auto ret = true; - is_running_ = true; - auto se = detail::scope_exit([&]() { is_running_ = false; }); - - { - std::unique_ptr task_queue(new_task_queue()); - - while (svr_sock_ != INVALID_SOCKET) { -#ifndef _WIN32 - if (idle_interval_sec_ > 0 || idle_interval_usec_ > 0) { -#endif - auto val = detail::select_read(svr_sock_, idle_interval_sec_, - idle_interval_usec_); - if (val == 0) { // Timeout - task_queue->on_idle(); - continue; - } -#ifndef _WIN32 - } -#endif - -#if defined _WIN32 - // sockets conneced via WASAccept inherit flags NO_HANDLE_INHERIT, - // OVERLAPPED - socket_t sock = WSAAccept(svr_sock_, nullptr, nullptr, nullptr, 0); -#elif defined SOCK_CLOEXEC - socket_t sock = accept4(svr_sock_, nullptr, nullptr, SOCK_CLOEXEC); -#else - socket_t sock = accept(svr_sock_, nullptr, nullptr); -#endif - - if (sock == INVALID_SOCKET) { - if (errno == EMFILE) { - // The per-process limit of open file descriptors has been reached. - // Try to accept new connections after a short sleep. - std::this_thread::sleep_for(std::chrono::microseconds{1}); - continue; - } else if (errno == EINTR || errno == EAGAIN) { - continue; - } - if (svr_sock_ != INVALID_SOCKET) { - detail::close_socket(svr_sock_); - ret = false; - } else { - ; // The server socket was closed by user. - } - break; - } - - { -#ifdef _WIN32 - auto timeout = static_cast(read_timeout_sec_ * 1000 + - read_timeout_usec_ / 1000); - setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, - reinterpret_cast(&timeout), sizeof(timeout)); -#else - timeval tv; - tv.tv_sec = static_cast(read_timeout_sec_); - tv.tv_usec = static_cast(read_timeout_usec_); - setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, - reinterpret_cast(&tv), sizeof(tv)); -#endif - } - { -#ifdef _WIN32 - auto timeout = static_cast(write_timeout_sec_ * 1000 + - write_timeout_usec_ / 1000); - setsockopt(sock, SOL_SOCKET, SO_SNDTIMEO, - reinterpret_cast(&timeout), sizeof(timeout)); -#else - timeval tv; - tv.tv_sec = static_cast(write_timeout_sec_); - tv.tv_usec = static_cast(write_timeout_usec_); - setsockopt(sock, SOL_SOCKET, SO_SNDTIMEO, - reinterpret_cast(&tv), sizeof(tv)); -#endif - } - - if (!task_queue->enqueue( - [this, sock]() { process_and_close_socket(sock); })) { - detail::shutdown_socket(sock); - detail::close_socket(sock); - } - } - - task_queue->shutdown(); - } - - is_decommisioned = !ret; - return ret; -} - -inline bool Server::routing(Request &req, Response &res, Stream &strm) { - if (pre_routing_handler_ && - pre_routing_handler_(req, res) == HandlerResponse::Handled) { - return true; - } - - // File handler - auto is_head_request = req.method == "HEAD"; - if ((req.method == "GET" || is_head_request) && - handle_file_request(req, res, is_head_request)) { - return true; - } - - if (detail::expect_content(req)) { - // Content reader handler - { - ContentReader reader( - [&](ContentReceiver receiver) { - return read_content_with_content_receiver( - strm, req, res, std::move(receiver), nullptr, nullptr); - }, - [&](MultipartContentHeader header, ContentReceiver receiver) { - return read_content_with_content_receiver(strm, req, res, nullptr, - std::move(header), - std::move(receiver)); - }); - - if (req.method == "POST") { - if (dispatch_request_for_content_reader( - req, res, std::move(reader), - post_handlers_for_content_reader_)) { - return true; - } - } else if (req.method == "PUT") { - if (dispatch_request_for_content_reader( - req, res, std::move(reader), - put_handlers_for_content_reader_)) { - return true; - } - } else if (req.method == "PATCH") { - if (dispatch_request_for_content_reader( - req, res, std::move(reader), - patch_handlers_for_content_reader_)) { - return true; - } - } else if (req.method == "DELETE") { - if (dispatch_request_for_content_reader( - req, res, std::move(reader), - delete_handlers_for_content_reader_)) { - return true; - } - } - } - - // Read content into `req.body` - if (!read_content(strm, req, res)) { - return false; - } - } - - // Regular handler - if (req.method == "GET" || req.method == "HEAD") { - return dispatch_request(req, res, get_handlers_); - } else if (req.method == "POST") { - return dispatch_request(req, res, post_handlers_); - } else if (req.method == "PUT") { - return dispatch_request(req, res, put_handlers_); - } else if (req.method == "DELETE") { - return dispatch_request(req, res, delete_handlers_); - } else if (req.method == "OPTIONS") { - return dispatch_request(req, res, options_handlers_); - } else if (req.method == "PATCH") { - return dispatch_request(req, res, patch_handlers_); - } - - res.status = StatusCode::BadRequest_400; - return false; -} - -inline bool Server::dispatch_request(Request &req, Response &res, - const Handlers &handlers) const { - for (const auto &x : handlers) { - const auto &matcher = x.first; - const auto &handler = x.second; - - if (matcher->match(req)) { - handler(req, res); - return true; - } - } - return false; -} - -inline void Server::apply_ranges(const Request &req, Response &res, - std::string &content_type, - std::string &boundary) const { - if (req.ranges.size() > 1 && res.status == StatusCode::PartialContent_206) { - auto it = res.headers.find("Content-Type"); - if (it != res.headers.end()) { - content_type = it->second; - res.headers.erase(it); - } - - boundary = detail::make_multipart_data_boundary(); - - res.set_header("Content-Type", - "multipart/byteranges; boundary=" + boundary); - } - - auto type = detail::encoding_type(req, res); - - if (res.body.empty()) { - if (res.content_length_ > 0) { - size_t length = 0; - if (req.ranges.empty() || res.status != StatusCode::PartialContent_206) { - length = res.content_length_; - } else if (req.ranges.size() == 1) { - auto offset_and_length = detail::get_range_offset_and_length( - req.ranges[0], res.content_length_); - - length = offset_and_length.second; - - auto content_range = detail::make_content_range_header_field( - offset_and_length, res.content_length_); - res.set_header("Content-Range", content_range); - } else { - length = detail::get_multipart_ranges_data_length( - req, boundary, content_type, res.content_length_); - } - res.set_header("Content-Length", std::to_string(length)); - } else { - if (res.content_provider_) { - if (res.is_chunked_content_provider_) { - res.set_header("Transfer-Encoding", "chunked"); - if (type == detail::EncodingType::Gzip) { - res.set_header("Content-Encoding", "gzip"); - } else if (type == detail::EncodingType::Brotli) { - res.set_header("Content-Encoding", "br"); - } - } - } - } - } else { - if (req.ranges.empty() || res.status != StatusCode::PartialContent_206) { - ; - } else if (req.ranges.size() == 1) { - auto offset_and_length = - detail::get_range_offset_and_length(req.ranges[0], res.body.size()); - auto offset = offset_and_length.first; - auto length = offset_and_length.second; - - auto content_range = detail::make_content_range_header_field( - offset_and_length, res.body.size()); - res.set_header("Content-Range", content_range); - - assert(offset + length <= res.body.size()); - res.body = res.body.substr(offset, length); - } else { - std::string data; - detail::make_multipart_ranges_data(req, res, boundary, content_type, - res.body.size(), data); - res.body.swap(data); - } - - if (type != detail::EncodingType::None) { - std::unique_ptr compressor; - std::string content_encoding; - - if (type == detail::EncodingType::Gzip) { -#ifdef CPPHTTPLIB_ZLIB_SUPPORT - compressor = detail::make_unique(); - content_encoding = "gzip"; -#endif - } else if (type == detail::EncodingType::Brotli) { -#ifdef CPPHTTPLIB_BROTLI_SUPPORT - compressor = detail::make_unique(); - content_encoding = "br"; -#endif - } - - if (compressor) { - std::string compressed; - if (compressor->compress(res.body.data(), res.body.size(), true, - [&](const char *data, size_t data_len) { - compressed.append(data, data_len); - return true; - })) { - res.body.swap(compressed); - res.set_header("Content-Encoding", content_encoding); - } - } - } - - auto length = std::to_string(res.body.size()); - res.set_header("Content-Length", length); - } -} - -inline bool Server::dispatch_request_for_content_reader( - Request &req, Response &res, ContentReader content_reader, - const HandlersForContentReader &handlers) const { - for (const auto &x : handlers) { - const auto &matcher = x.first; - const auto &handler = x.second; - - if (matcher->match(req)) { - handler(req, res, content_reader); - return true; - } - } - return false; -} - -inline bool Server::process_request( - Stream &strm, const std::string &remote_addr, int remote_port, - const std::string &local_addr, int local_port, bool close_connection, - bool &connection_closed, - const std::function &setup_request) { - std::array buf{}; - - detail::stream_line_reader line_reader(strm, buf.data(), buf.size()); - - // Connection has been closed on client - if (!line_reader.getline()) { - return false; - } - - Request req; - - Response res; - res.version = "HTTP/1.1"; - res.headers = default_headers_; - -#ifdef _WIN32 - // TODO: Increase FD_SETSIZE statically (libzmq), dynamically (MySQL). -#else -#ifndef CPPHTTPLIB_USE_POLL - // Socket file descriptor exceeded FD_SETSIZE... - if (strm.socket() >= FD_SETSIZE) { - Headers dummy; - detail::read_headers(strm, dummy); - res.status = StatusCode::InternalServerError_500; - return write_response(strm, close_connection, req, res); - } -#endif -#endif - - // Check if the request URI doesn't exceed the limit - if (line_reader.size() > CPPHTTPLIB_REQUEST_URI_MAX_LENGTH) { - Headers dummy; - detail::read_headers(strm, dummy); - res.status = StatusCode::UriTooLong_414; - return write_response(strm, close_connection, req, res); - } - - // Request line and headers - if (!parse_request_line(line_reader.ptr(), req) || - !detail::read_headers(strm, req.headers)) { - res.status = StatusCode::BadRequest_400; - return write_response(strm, close_connection, req, res); - } - - if (req.get_header_value("Connection") == "close") { - connection_closed = true; - } - - if (req.version == "HTTP/1.0" && - req.get_header_value("Connection") != "Keep-Alive") { - connection_closed = true; - } - - req.remote_addr = remote_addr; - req.remote_port = remote_port; - req.set_header("REMOTE_ADDR", req.remote_addr); - req.set_header("REMOTE_PORT", std::to_string(req.remote_port)); - - req.local_addr = local_addr; - req.local_port = local_port; - req.set_header("LOCAL_ADDR", req.local_addr); - req.set_header("LOCAL_PORT", std::to_string(req.local_port)); - - if (req.has_header("Range")) { - const auto &range_header_value = req.get_header_value("Range"); - if (!detail::parse_range_header(range_header_value, req.ranges)) { - res.status = StatusCode::RangeNotSatisfiable_416; - return write_response(strm, close_connection, req, res); - } - } - - if (setup_request) { - setup_request(req); - } - - if (req.get_header_value("Expect") == "100-continue") { - int status = StatusCode::Continue_100; - if (expect_100_continue_handler_) { - status = expect_100_continue_handler_(req, res); - } - switch (status) { - case StatusCode::Continue_100: - case StatusCode::ExpectationFailed_417: - detail::write_response_line(strm, status); - strm.write("\r\n"); - break; - default: - connection_closed = true; - return write_response(strm, true, req, res); - } - } - - // Routing - auto routed = false; -#ifdef CPPHTTPLIB_NO_EXCEPTIONS - routed = routing(req, res, strm); -#else - try { - routed = routing(req, res, strm); - } catch (std::exception &e) { - if (exception_handler_) { - auto ep = std::current_exception(); - exception_handler_(req, res, ep); - routed = true; - } else { - res.status = StatusCode::InternalServerError_500; - std::string val; - auto s = e.what(); - for (size_t i = 0; s[i]; i++) { - switch (s[i]) { - case '\r': - val += "\\r"; - break; - case '\n': - val += "\\n"; - break; - default: - val += s[i]; - break; - } - } - res.set_header("EXCEPTION_WHAT", val); - } - } catch (...) { - if (exception_handler_) { - auto ep = std::current_exception(); - exception_handler_(req, res, ep); - routed = true; - } else { - res.status = StatusCode::InternalServerError_500; - res.set_header("EXCEPTION_WHAT", "UNKNOWN"); - } - } -#endif - if (routed) { - if (res.status == -1) { - res.status = req.ranges.empty() ? StatusCode::OK_200 - : StatusCode::PartialContent_206; - } - - if (detail::range_error(req, res)) { - res.body.clear(); - res.content_length_ = 0; - res.content_provider_ = nullptr; - res.status = StatusCode::RangeNotSatisfiable_416; - return write_response(strm, close_connection, req, res); - } - - // Serve file content by using a content provider - if (!res.file_content_path_.empty()) { - const auto &path = res.file_content_path_; - auto mm = std::make_shared(path.c_str()); - if (!mm->is_open()) { - res.body.clear(); - res.content_length_ = 0; - res.content_provider_ = nullptr; - res.status = StatusCode::NotFound_404; - return write_response(strm, close_connection, req, res); - } - - auto content_type = res.file_content_content_type_; - if (content_type.empty()) { - content_type = detail::find_content_type( - path, file_extension_and_mimetype_map_, default_file_mimetype_); - } - - res.set_content_provider( - mm->size(), content_type, - [mm](size_t offset, size_t length, DataSink &sink) -> bool { - sink.write(mm->data() + offset, length); - return true; - }); - } - - return write_response_with_content(strm, close_connection, req, res); - } else { - if (res.status == -1) { - res.status = StatusCode::NotFound_404; - } - - return write_response(strm, close_connection, req, res); - } -} - -inline bool Server::is_valid() const { return true; } - -inline bool Server::process_and_close_socket(socket_t sock) { - std::string remote_addr; - int remote_port = 0; - detail::get_remote_ip_and_port(sock, remote_addr, remote_port); - - std::string local_addr; - int local_port = 0; - detail::get_local_ip_and_port(sock, local_addr, local_port); - - auto ret = detail::process_server_socket( - svr_sock_, sock, keep_alive_max_count_, keep_alive_timeout_sec_, - read_timeout_sec_, read_timeout_usec_, write_timeout_sec_, - write_timeout_usec_, - [&](Stream &strm, bool close_connection, bool &connection_closed) { - return process_request(strm, remote_addr, remote_port, local_addr, - local_port, close_connection, connection_closed, - nullptr); - }); - - detail::shutdown_socket(sock); - detail::close_socket(sock); - return ret; -} - -// HTTP client implementation -inline ClientImpl::ClientImpl(const std::string &host) - : ClientImpl(host, 80, std::string(), std::string()) {} - -inline ClientImpl::ClientImpl(const std::string &host, int port) - : ClientImpl(host, port, std::string(), std::string()) {} - -inline ClientImpl::ClientImpl(const std::string &host, int port, - const std::string &client_cert_path, - const std::string &client_key_path) - : host_(detail::escape_abstract_namespace_unix_domain(host)), - port_(port), - host_and_port_(adjust_host_string(host_) + ":" + std::to_string(port)), - client_cert_path_(client_cert_path), - client_key_path_(client_key_path) {} - -inline ClientImpl::~ClientImpl() { - std::lock_guard guard(socket_mutex_); - shutdown_socket(socket_); - close_socket(socket_); -} - -inline bool ClientImpl::is_valid() const { return true; } - -inline void ClientImpl::copy_settings(const ClientImpl &rhs) { - client_cert_path_ = rhs.client_cert_path_; - client_key_path_ = rhs.client_key_path_; - connection_timeout_sec_ = rhs.connection_timeout_sec_; - read_timeout_sec_ = rhs.read_timeout_sec_; - read_timeout_usec_ = rhs.read_timeout_usec_; - write_timeout_sec_ = rhs.write_timeout_sec_; - write_timeout_usec_ = rhs.write_timeout_usec_; - basic_auth_username_ = rhs.basic_auth_username_; - basic_auth_password_ = rhs.basic_auth_password_; - bearer_token_auth_token_ = rhs.bearer_token_auth_token_; -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - digest_auth_username_ = rhs.digest_auth_username_; - digest_auth_password_ = rhs.digest_auth_password_; -#endif - keep_alive_ = rhs.keep_alive_; - follow_location_ = rhs.follow_location_; - url_encode_ = rhs.url_encode_; - address_family_ = rhs.address_family_; - tcp_nodelay_ = rhs.tcp_nodelay_; - ipv6_v6only_ = rhs.ipv6_v6only_; - socket_options_ = rhs.socket_options_; - compress_ = rhs.compress_; - decompress_ = rhs.decompress_; - interface_ = rhs.interface_; - proxy_host_ = rhs.proxy_host_; - proxy_port_ = rhs.proxy_port_; - proxy_basic_auth_username_ = rhs.proxy_basic_auth_username_; - proxy_basic_auth_password_ = rhs.proxy_basic_auth_password_; - proxy_bearer_token_auth_token_ = rhs.proxy_bearer_token_auth_token_; -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - proxy_digest_auth_username_ = rhs.proxy_digest_auth_username_; - proxy_digest_auth_password_ = rhs.proxy_digest_auth_password_; -#endif -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - ca_cert_file_path_ = rhs.ca_cert_file_path_; - ca_cert_dir_path_ = rhs.ca_cert_dir_path_; - ca_cert_store_ = rhs.ca_cert_store_; -#endif -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - server_certificate_verification_ = rhs.server_certificate_verification_; - server_hostname_verification_ = rhs.server_hostname_verification_; - server_certificate_verifier_ = rhs.server_certificate_verifier_; -#endif - logger_ = rhs.logger_; -} - -inline socket_t ClientImpl::create_client_socket(Error &error) const { - if (!proxy_host_.empty() && proxy_port_ != -1) { - return detail::create_client_socket( - proxy_host_, std::string(), proxy_port_, address_family_, tcp_nodelay_, - ipv6_v6only_, socket_options_, connection_timeout_sec_, - connection_timeout_usec_, read_timeout_sec_, read_timeout_usec_, - write_timeout_sec_, write_timeout_usec_, interface_, error); - } - - // Check is custom IP specified for host_ - std::string ip; - auto it = addr_map_.find(host_); - if (it != addr_map_.end()) { - ip = it->second; - } - - return detail::create_client_socket( - host_, ip, port_, address_family_, tcp_nodelay_, ipv6_v6only_, - socket_options_, connection_timeout_sec_, connection_timeout_usec_, - read_timeout_sec_, read_timeout_usec_, write_timeout_sec_, - write_timeout_usec_, interface_, error); -} - -inline bool ClientImpl::create_and_connect_socket(Socket &socket, - Error &error) { - auto sock = create_client_socket(error); - if (sock == INVALID_SOCKET) { - return false; - } - socket.sock = sock; - return true; -} - -inline void ClientImpl::shutdown_ssl(Socket & /*socket*/, - bool /*shutdown_gracefully*/) { - // If there are any requests in flight from threads other than us, then it's - // a thread-unsafe race because individual ssl* objects are not thread-safe. - assert(socket_requests_in_flight_ == 0 || - socket_requests_are_from_thread_ == std::this_thread::get_id()); -} - -inline void ClientImpl::shutdown_socket(Socket &socket) const { - if (socket.sock == INVALID_SOCKET) { - return; - } - detail::shutdown_socket(socket.sock); -} - -inline void ClientImpl::close_socket(Socket &socket) { - // If there are requests in flight in another thread, usually closing - // the socket will be fine and they will simply receive an error when - // using the closed socket, but it is still a bug since rarely the OS - // may reassign the socket id to be used for a new socket, and then - // suddenly they will be operating on a live socket that is different - // than the one they intended! - assert(socket_requests_in_flight_ == 0 || - socket_requests_are_from_thread_ == std::this_thread::get_id()); - - // It is also a bug if this happens while SSL is still active -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - assert(socket.ssl == nullptr); -#endif - if (socket.sock == INVALID_SOCKET) { - return; - } - detail::close_socket(socket.sock); - socket.sock = INVALID_SOCKET; -} - -inline bool ClientImpl::read_response_line(Stream &strm, const Request &req, - Response &res) const { - std::array buf{}; - - detail::stream_line_reader line_reader(strm, buf.data(), buf.size()); - - if (!line_reader.getline()) { - return false; - } - -#ifdef CPPHTTPLIB_ALLOW_LF_AS_LINE_TERMINATOR - const static std::regex re("(HTTP/1\\.[01]) (\\d{3})(?: (.*?))?\r?\n"); -#else - const static std::regex re("(HTTP/1\\.[01]) (\\d{3})(?: (.*?))?\r\n"); -#endif - - std::cmatch m; - if (!std::regex_match(line_reader.ptr(), m, re)) { - return req.method == "CONNECT"; - } - res.version = std::string(m[1]); - res.status = std::stoi(std::string(m[2])); - res.reason = std::string(m[3]); - - // Ignore '100 Continue' - while (res.status == StatusCode::Continue_100) { - if (!line_reader.getline()) { - return false; - } // CRLF - if (!line_reader.getline()) { - return false; - } // next response line - - if (!std::regex_match(line_reader.ptr(), m, re)) { - return false; - } - res.version = std::string(m[1]); - res.status = std::stoi(std::string(m[2])); - res.reason = std::string(m[3]); - } - - return true; -} - -inline bool ClientImpl::send(Request &req, Response &res, Error &error) { - std::lock_guard request_mutex_guard(request_mutex_); - auto ret = send_(req, res, error); - if (error == Error::SSLPeerCouldBeClosed_) { - assert(!ret); - ret = send_(req, res, error); - } - return ret; -} - -inline bool ClientImpl::send_(Request &req, Response &res, Error &error) { - { - std::lock_guard guard(socket_mutex_); - - // Set this to false immediately - if it ever gets set to true by the end of - // the request, we know another thread instructed us to close the socket. - socket_should_be_closed_when_request_is_done_ = false; - - auto is_alive = false; - if (socket_.is_open()) { - is_alive = detail::is_socket_alive(socket_.sock); - if (!is_alive) { - // Attempt to avoid sigpipe by shutting down nongracefully if it seems - // like the other side has already closed the connection Also, there - // cannot be any requests in flight from other threads since we locked - // request_mutex_, so safe to close everything immediately - const bool shutdown_gracefully = false; - shutdown_ssl(socket_, shutdown_gracefully); - shutdown_socket(socket_); - close_socket(socket_); - } - } - - if (!is_alive) { - if (!create_and_connect_socket(socket_, error)) { - return false; - } - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - // TODO: refactoring - if (is_ssl()) { - auto &scli = static_cast(*this); - if (!proxy_host_.empty() && proxy_port_ != -1) { - auto success = false; - if (!scli.connect_with_proxy(socket_, res, success, error)) { - return success; - } - } - - if (!scli.initialize_ssl(socket_, error)) { - return false; - } - } -#endif - } - - // Mark the current socket as being in use so that it cannot be closed by - // anyone else while this request is ongoing, even though we will be - // releasing the mutex. - if (socket_requests_in_flight_ > 1) { - assert(socket_requests_are_from_thread_ == std::this_thread::get_id()); - } - socket_requests_in_flight_ += 1; - socket_requests_are_from_thread_ = std::this_thread::get_id(); - } - - for (const auto &header : default_headers_) { - if (req.headers.find(header.first) == req.headers.end()) { - req.headers.insert(header); - } - } - - auto ret = false; - auto close_connection = !keep_alive_; - - auto se = detail::scope_exit([&]() { - // Briefly lock mutex in order to mark that a request is no longer ongoing - std::lock_guard guard(socket_mutex_); - socket_requests_in_flight_ -= 1; - if (socket_requests_in_flight_ <= 0) { - assert(socket_requests_in_flight_ == 0); - socket_requests_are_from_thread_ = std::thread::id(); - } - - if (socket_should_be_closed_when_request_is_done_ || close_connection || - !ret) { - shutdown_ssl(socket_, true); - shutdown_socket(socket_); - close_socket(socket_); - } - }); - - ret = process_socket(socket_, [&](Stream &strm) { - return handle_request(strm, req, res, close_connection, error); - }); - - if (!ret) { - if (error == Error::Success) { - error = Error::Unknown; - } - } - - return ret; -} - -inline Result ClientImpl::send(const Request &req) { - auto req2 = req; - return send_(std::move(req2)); -} - -inline Result ClientImpl::send_(Request &&req) { - auto res = detail::make_unique(); - auto error = Error::Success; - auto ret = send(req, *res, error); - return Result{ret ? std::move(res) : nullptr, error, std::move(req.headers)}; -} - -inline bool ClientImpl::handle_request(Stream &strm, Request &req, - Response &res, bool close_connection, - Error &error) { - if (req.path.empty()) { - error = Error::Connection; - return false; - } - - auto req_save = req; - - bool ret; - - if (!is_ssl() && !proxy_host_.empty() && proxy_port_ != -1) { - auto req2 = req; - req2.path = "http://" + host_and_port_ + req.path; - ret = process_request(strm, req2, res, close_connection, error); - req = req2; - req.path = req_save.path; - } else { - ret = process_request(strm, req, res, close_connection, error); - } - - if (!ret) { - return false; - } - - if (res.get_header_value("Connection") == "close" || - (res.version == "HTTP/1.0" && res.reason != "Connection established")) { - // TODO this requires a not-entirely-obvious chain of calls to be correct - // for this to be safe. - - // This is safe to call because handle_request is only called by send_ - // which locks the request mutex during the process. It would be a bug - // to call it from a different thread since it's a thread-safety issue - // to do these things to the socket if another thread is using the socket. - std::lock_guard guard(socket_mutex_); - shutdown_ssl(socket_, true); - shutdown_socket(socket_); - close_socket(socket_); - } - - if (300 < res.status && res.status < 400 && follow_location_) { - req = req_save; - ret = redirect(req, res, error); - } - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - if ((res.status == StatusCode::Unauthorized_401 || - res.status == StatusCode::ProxyAuthenticationRequired_407) && - req.authorization_count_ < 5) { - auto is_proxy = res.status == StatusCode::ProxyAuthenticationRequired_407; - const auto &username = - is_proxy ? proxy_digest_auth_username_ : digest_auth_username_; - const auto &password = - is_proxy ? proxy_digest_auth_password_ : digest_auth_password_; - - if (!username.empty() && !password.empty()) { - std::map auth; - if (detail::parse_www_authenticate(res, auth, is_proxy)) { - Request new_req = req; - new_req.authorization_count_ += 1; - new_req.headers.erase(is_proxy ? "Proxy-Authorization" - : "Authorization"); - new_req.headers.insert(detail::make_digest_authentication_header( - req, auth, new_req.authorization_count_, detail::random_string(10), - username, password, is_proxy)); - - Response new_res; - - ret = send(new_req, new_res, error); - if (ret) { - res = new_res; - } - } - } - } -#endif - - return ret; -} - -inline bool ClientImpl::redirect(Request &req, Response &res, Error &error) { - if (req.redirect_count_ == 0) { - error = Error::ExceedRedirectCount; - return false; - } - - auto location = res.get_header_value("location"); - if (location.empty()) { - return false; - } - - const static std::regex re( - R"((?:(https?):)?(?://(?:\[([a-fA-F\d:]+)\]|([^:/?#]+))(?::(\d+))?)?([^?#]*)(\?[^#]*)?(?:#.*)?)"); - - std::smatch m; - if (!std::regex_match(location, m, re)) { - return false; - } - - auto scheme = is_ssl() ? "https" : "http"; - - auto next_scheme = m[1].str(); - auto next_host = m[2].str(); - if (next_host.empty()) { - next_host = m[3].str(); - } - auto port_str = m[4].str(); - auto next_path = m[5].str(); - auto next_query = m[6].str(); - - auto next_port = port_; - if (!port_str.empty()) { - next_port = std::stoi(port_str); - } else if (!next_scheme.empty()) { - next_port = next_scheme == "https" ? 443 : 80; - } - - if (next_scheme.empty()) { - next_scheme = scheme; - } - if (next_host.empty()) { - next_host = host_; - } - if (next_path.empty()) { - next_path = "/"; - } - - auto path = detail::decode_url(next_path, true) + next_query; - - if (next_scheme == scheme && next_host == host_ && next_port == port_) { - return detail::redirect(*this, req, res, path, location, error); - } else { - if (next_scheme == "https") { -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - SSLClient cli(next_host, next_port); - cli.copy_settings(*this); - if (ca_cert_store_) { - cli.set_ca_cert_store(ca_cert_store_); - } - return detail::redirect(cli, req, res, path, location, error); -#else - return false; -#endif - } else { - ClientImpl cli(next_host, next_port); - cli.copy_settings(*this); - return detail::redirect(cli, req, res, path, location, error); - } - } -} - -inline bool ClientImpl::write_content_with_provider(Stream &strm, - const Request &req, - Error &error) const { - auto is_shutting_down = []() { return false; }; - - if (req.is_chunked_content_provider_) { - // TODO: Brotli support - std::unique_ptr compressor; -#ifdef CPPHTTPLIB_ZLIB_SUPPORT - if (compress_) { - compressor = detail::make_unique(); - } else -#endif - { - compressor = detail::make_unique(); - } - - return detail::write_content_chunked(strm, req.content_provider_, - is_shutting_down, *compressor, error); - } else { - return detail::write_content(strm, req.content_provider_, 0, - req.content_length_, is_shutting_down, error); - } -} - -inline bool ClientImpl::write_request(Stream &strm, Request &req, - bool close_connection, Error &error) { - // Prepare additional headers - if (close_connection) { - if (!req.has_header("Connection")) { - req.set_header("Connection", "close"); - } - } - - if (!req.has_header("Host")) { - if (is_ssl()) { - if (port_ == 443) { - req.set_header("Host", host_); - } else { - req.set_header("Host", host_and_port_); - } - } else { - if (port_ == 80) { - req.set_header("Host", host_); - } else { - req.set_header("Host", host_and_port_); - } - } - } - - if (!req.has_header("Accept")) { - req.set_header("Accept", "*/*"); - } - -#ifndef CPPHTTPLIB_NO_DEFAULT_USER_AGENT - if (!req.has_header("User-Agent")) { - auto agent = std::string("cpp-httplib/") + CPPHTTPLIB_VERSION; - req.set_header("User-Agent", agent); - } -#endif - - if (req.body.empty()) { - if (req.content_provider_) { - if (!req.is_chunked_content_provider_) { - if (!req.has_header("Content-Length")) { - auto length = std::to_string(req.content_length_); - req.set_header("Content-Length", length); - } - } - } else { - if (req.method == "POST" || req.method == "PUT" || - req.method == "PATCH") { - req.set_header("Content-Length", "0"); - } - } - } else { - if (!req.has_header("Content-Type")) { - req.set_header("Content-Type", "text/plain"); - } - - if (!req.has_header("Content-Length")) { - auto length = std::to_string(req.body.size()); - req.set_header("Content-Length", length); - } - } - - if (!basic_auth_password_.empty() || !basic_auth_username_.empty()) { - if (!req.has_header("Authorization")) { - req.headers.insert(make_basic_authentication_header( - basic_auth_username_, basic_auth_password_, false)); - } - } - - if (!proxy_basic_auth_username_.empty() && - !proxy_basic_auth_password_.empty()) { - if (!req.has_header("Proxy-Authorization")) { - req.headers.insert(make_basic_authentication_header( - proxy_basic_auth_username_, proxy_basic_auth_password_, true)); - } - } - - if (!bearer_token_auth_token_.empty()) { - if (!req.has_header("Authorization")) { - req.headers.insert(make_bearer_token_authentication_header( - bearer_token_auth_token_, false)); - } - } - - if (!proxy_bearer_token_auth_token_.empty()) { - if (!req.has_header("Proxy-Authorization")) { - req.headers.insert(make_bearer_token_authentication_header( - proxy_bearer_token_auth_token_, true)); - } - } - - // Request line and headers - { - detail::BufferStream bstrm; - - const auto &path = url_encode_ ? detail::encode_url(req.path) : req.path; - detail::write_request_line(bstrm, req.method, path); - - header_writer_(bstrm, req.headers); - - // Flush buffer - auto &data = bstrm.get_buffer(); - if (!detail::write_data(strm, data.data(), data.size())) { - error = Error::Write; - return false; - } - } - - // Body - if (req.body.empty()) { - return write_content_with_provider(strm, req, error); - } - - if (!detail::write_data(strm, req.body.data(), req.body.size())) { - error = Error::Write; - return false; - } - - return true; -} - -inline std::unique_ptr ClientImpl::send_with_content_provider( - Request &req, const char *body, size_t content_length, - ContentProvider content_provider, - ContentProviderWithoutLength content_provider_without_length, - const std::string &content_type, Error &error) { - if (!content_type.empty()) { - req.set_header("Content-Type", content_type); - } - -#ifdef CPPHTTPLIB_ZLIB_SUPPORT - if (compress_) { - req.set_header("Content-Encoding", "gzip"); - } -#endif - -#ifdef CPPHTTPLIB_ZLIB_SUPPORT - if (compress_ && !content_provider_without_length) { - // TODO: Brotli support - detail::gzip_compressor compressor; - - if (content_provider) { - auto ok = true; - size_t offset = 0; - DataSink data_sink; - - data_sink.write = [&](const char *data, size_t data_len) -> bool { - if (ok) { - auto last = offset + data_len == content_length; - - auto ret = compressor.compress( - data, data_len, last, - [&](const char *compressed_data, size_t compressed_data_len) { - req.body.append(compressed_data, compressed_data_len); - return true; - }); - - if (ret) { - offset += data_len; - } else { - ok = false; - } - } - return ok; - }; - - while (ok && offset < content_length) { - if (!content_provider(offset, content_length - offset, data_sink)) { - error = Error::Canceled; - return nullptr; - } - } - } else { - if (!compressor.compress(body, content_length, true, - [&](const char *data, size_t data_len) { - req.body.append(data, data_len); - return true; - })) { - error = Error::Compression; - return nullptr; - } - } - } else -#endif - { - if (content_provider) { - req.content_length_ = content_length; - req.content_provider_ = std::move(content_provider); - req.is_chunked_content_provider_ = false; - } else if (content_provider_without_length) { - req.content_length_ = 0; - req.content_provider_ = detail::ContentProviderAdapter( - std::move(content_provider_without_length)); - req.is_chunked_content_provider_ = true; - req.set_header("Transfer-Encoding", "chunked"); - } else { - req.body.assign(body, content_length); - } - } - - auto res = detail::make_unique(); - return send(req, *res, error) ? std::move(res) : nullptr; -} - -inline Result ClientImpl::send_with_content_provider( - const std::string &method, const std::string &path, const Headers &headers, - const char *body, size_t content_length, ContentProvider content_provider, - ContentProviderWithoutLength content_provider_without_length, - const std::string &content_type, Progress progress) { - Request req; - req.method = method; - req.headers = headers; - req.path = path; - req.progress = progress; - - auto error = Error::Success; - - auto res = send_with_content_provider( - req, body, content_length, std::move(content_provider), - std::move(content_provider_without_length), content_type, error); - - return Result{std::move(res), error, std::move(req.headers)}; -} - -inline std::string ClientImpl::adjust_host_string( - const std::string &host) const { - if (host.find(':') != std::string::npos) { - return "[" + host + "]"; - } - return host; -} - -inline bool ClientImpl::process_request(Stream &strm, Request &req, - Response &res, bool close_connection, - Error &error) { - // Send request - if (!write_request(strm, req, close_connection, error)) { - return false; - } - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - if (is_ssl()) { - auto is_proxy_enabled = !proxy_host_.empty() && proxy_port_ != -1; - if (!is_proxy_enabled) { - char buf[1]; - if (SSL_peek(socket_.ssl, buf, 1) == 0 && - SSL_get_error(socket_.ssl, 0) == SSL_ERROR_ZERO_RETURN) { - error = Error::SSLPeerCouldBeClosed_; - return false; - } - } - } -#endif - - // Receive response and headers - if (!read_response_line(strm, req, res) || - !detail::read_headers(strm, res.headers)) { - error = Error::Read; - return false; - } - - // Body - if ((res.status != StatusCode::NoContent_204) && req.method != "HEAD" && - req.method != "CONNECT") { - auto redirect = 300 < res.status && res.status < 400 && follow_location_; - - if (req.response_handler && !redirect) { - if (!req.response_handler(res)) { - error = Error::Canceled; - return false; - } - } - - auto out = - req.content_receiver - ? static_cast( - [&](const char *buf, size_t n, uint64_t off, uint64_t len) { - if (redirect) { - return true; - } - auto ret = req.content_receiver(buf, n, off, len); - if (!ret) { - error = Error::Canceled; - } - return ret; - }) - : static_cast( - [&](const char *buf, size_t n, uint64_t /*off*/, - uint64_t /*len*/) { - if (res.body.size() + n > res.body.max_size()) { - return false; - } - res.body.append(buf, n); - return true; - }); - - auto progress = [&](uint64_t current, uint64_t total) { - if (!req.progress || redirect) { - return true; - } - auto ret = req.progress(current, total); - if (!ret) { - error = Error::Canceled; - } - return ret; - }; - - if (res.has_header("Content-Length")) { - if (!req.content_receiver) { - auto len = std::min(res.get_header_value_u64("Content-Length"), - res.body.max_size()); - if (len > 0) { - res.body.reserve(len); - } - } - } - - int dummy_status; - if (!detail::read_content(strm, res, (std::numeric_limits::max)(), - dummy_status, std::move(progress), std::move(out), - decompress_)) { - if (error != Error::Canceled) { - error = Error::Read; - } - return false; - } - } - - // Log - if (logger_) { - logger_(req, res); - } - - return true; -} - -inline ContentProviderWithoutLength ClientImpl::get_multipart_content_provider( - const std::string &boundary, const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items) const { - size_t cur_item = 0; - size_t cur_start = 0; - // cur_item and cur_start are copied to within the std::function and maintain - // state between successive calls - return [&, cur_item, cur_start](size_t offset, - DataSink &sink) mutable -> bool { - if (!offset && !items.empty()) { - sink.os << detail::serialize_multipart_formdata(items, boundary, false); - return true; - } else if (cur_item < provider_items.size()) { - if (!cur_start) { - const auto &begin = detail::serialize_multipart_formdata_item_begin( - provider_items[cur_item], boundary); - offset += begin.size(); - cur_start = offset; - sink.os << begin; - } - - DataSink cur_sink; - auto has_data = true; - cur_sink.write = sink.write; - cur_sink.done = [&]() { has_data = false; }; - - if (!provider_items[cur_item].provider(offset - cur_start, cur_sink)) { - return false; - } - - if (!has_data) { - sink.os << detail::serialize_multipart_formdata_item_end(); - cur_item++; - cur_start = 0; - } - return true; - } else { - sink.os << detail::serialize_multipart_formdata_finish(boundary); - sink.done(); - return true; - } - }; -} - -inline bool ClientImpl::process_socket( - const Socket &socket, std::function callback) { - return detail::process_client_socket( - socket.sock, read_timeout_sec_, read_timeout_usec_, write_timeout_sec_, - write_timeout_usec_, std::move(callback)); -} - -inline bool ClientImpl::is_ssl() const { return false; } - -inline Result ClientImpl::Get(const std::string &path) { - return Get(path, Headers(), Progress()); -} - -inline Result ClientImpl::Get(const std::string &path, Progress progress) { - return Get(path, Headers(), std::move(progress)); -} - -inline Result ClientImpl::Get(const std::string &path, const Headers &headers) { - return Get(path, headers, Progress()); -} - -inline Result ClientImpl::Get(const std::string &path, const Headers &headers, - Progress progress) { - Request req; - req.method = "GET"; - req.path = path; - req.headers = headers; - req.progress = std::move(progress); - - return send_(std::move(req)); -} - -inline Result ClientImpl::Get(const std::string &path, - ContentReceiver content_receiver) { - return Get(path, Headers(), nullptr, std::move(content_receiver), nullptr); -} - -inline Result ClientImpl::Get(const std::string &path, - ContentReceiver content_receiver, - Progress progress) { - return Get(path, Headers(), nullptr, std::move(content_receiver), - std::move(progress)); -} - -inline Result ClientImpl::Get(const std::string &path, const Headers &headers, - ContentReceiver content_receiver) { - return Get(path, headers, nullptr, std::move(content_receiver), nullptr); -} - -inline Result ClientImpl::Get(const std::string &path, const Headers &headers, - ContentReceiver content_receiver, - Progress progress) { - return Get(path, headers, nullptr, std::move(content_receiver), - std::move(progress)); -} - -inline Result ClientImpl::Get(const std::string &path, - ResponseHandler response_handler, - ContentReceiver content_receiver) { - return Get(path, Headers(), std::move(response_handler), - std::move(content_receiver), nullptr); -} - -inline Result ClientImpl::Get(const std::string &path, const Headers &headers, - ResponseHandler response_handler, - ContentReceiver content_receiver) { - return Get(path, headers, std::move(response_handler), - std::move(content_receiver), nullptr); -} - -inline Result ClientImpl::Get(const std::string &path, - ResponseHandler response_handler, - ContentReceiver content_receiver, - Progress progress) { - return Get(path, Headers(), std::move(response_handler), - std::move(content_receiver), std::move(progress)); -} - -inline Result ClientImpl::Get(const std::string &path, const Headers &headers, - ResponseHandler response_handler, - ContentReceiver content_receiver, - Progress progress) { - Request req; - req.method = "GET"; - req.path = path; - req.headers = headers; - req.response_handler = std::move(response_handler); - req.content_receiver = [content_receiver]( - const char *data, size_t data_length, - uint64_t /*offset*/, uint64_t /*total_length*/) { - return content_receiver(data, data_length); - }; - req.progress = std::move(progress); - - return send_(std::move(req)); -} - -inline Result ClientImpl::Get(const std::string &path, const Params ¶ms, - const Headers &headers, Progress progress) { - if (params.empty()) { - return Get(path, headers); - } - - std::string path_with_query = append_query_params(path, params); - return Get(path_with_query, headers, std::move(progress)); -} - -inline Result ClientImpl::Get(const std::string &path, const Params ¶ms, - const Headers &headers, - ContentReceiver content_receiver, - Progress progress) { - return Get(path, params, headers, nullptr, std::move(content_receiver), - std::move(progress)); -} - -inline Result ClientImpl::Get(const std::string &path, const Params ¶ms, - const Headers &headers, - ResponseHandler response_handler, - ContentReceiver content_receiver, - Progress progress) { - if (params.empty()) { - return Get(path, headers, std::move(response_handler), - std::move(content_receiver), std::move(progress)); - } - - std::string path_with_query = append_query_params(path, params); - return Get(path_with_query, headers, std::move(response_handler), - std::move(content_receiver), std::move(progress)); -} - -inline Result ClientImpl::Head(const std::string &path) { - return Head(path, Headers()); -} - -inline Result ClientImpl::Head(const std::string &path, - const Headers &headers) { - Request req; - req.method = "HEAD"; - req.headers = headers; - req.path = path; - - return send_(std::move(req)); -} - -inline Result ClientImpl::Post(const std::string &path) { - return Post(path, std::string(), std::string()); -} - -inline Result ClientImpl::Post(const std::string &path, - const Headers &headers) { - return Post(path, headers, nullptr, 0, std::string()); -} - -inline Result ClientImpl::Post(const std::string &path, const char *body, - size_t content_length, - const std::string &content_type) { - return Post(path, Headers(), body, content_length, content_type, nullptr); -} - -inline Result ClientImpl::Post(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type) { - return send_with_content_provider("POST", path, headers, body, content_length, - nullptr, nullptr, content_type, nullptr); -} - -inline Result ClientImpl::Post(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type, - Progress progress) { - return send_with_content_provider("POST", path, headers, body, content_length, - nullptr, nullptr, content_type, progress); -} - -inline Result ClientImpl::Post(const std::string &path, const std::string &body, - const std::string &content_type) { - return Post(path, Headers(), body, content_type); -} - -inline Result ClientImpl::Post(const std::string &path, const std::string &body, - const std::string &content_type, - Progress progress) { - return Post(path, Headers(), body, content_type, progress); -} - -inline Result ClientImpl::Post(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type) { - return send_with_content_provider("POST", path, headers, body.data(), - body.size(), nullptr, nullptr, content_type, - nullptr); -} - -inline Result ClientImpl::Post(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type, - Progress progress) { - return send_with_content_provider("POST", path, headers, body.data(), - body.size(), nullptr, nullptr, content_type, - progress); -} - -inline Result ClientImpl::Post(const std::string &path, const Params ¶ms) { - return Post(path, Headers(), params); -} - -inline Result ClientImpl::Post(const std::string &path, size_t content_length, - ContentProvider content_provider, - const std::string &content_type) { - return Post(path, Headers(), content_length, std::move(content_provider), - content_type); -} - -inline Result ClientImpl::Post(const std::string &path, - ContentProviderWithoutLength content_provider, - const std::string &content_type) { - return Post(path, Headers(), std::move(content_provider), content_type); -} - -inline Result ClientImpl::Post(const std::string &path, const Headers &headers, - size_t content_length, - ContentProvider content_provider, - const std::string &content_type) { - return send_with_content_provider("POST", path, headers, nullptr, - content_length, std::move(content_provider), - nullptr, content_type, nullptr); -} - -inline Result ClientImpl::Post(const std::string &path, const Headers &headers, - ContentProviderWithoutLength content_provider, - const std::string &content_type) { - return send_with_content_provider("POST", path, headers, nullptr, 0, nullptr, - std::move(content_provider), content_type, - nullptr); -} - -inline Result ClientImpl::Post(const std::string &path, const Headers &headers, - const Params ¶ms) { - auto query = detail::params_to_query_str(params); - return Post(path, headers, query, "application/x-www-form-urlencoded"); -} - -inline Result ClientImpl::Post(const std::string &path, const Headers &headers, - const Params ¶ms, Progress progress) { - auto query = detail::params_to_query_str(params); - return Post(path, headers, query, "application/x-www-form-urlencoded", - progress); -} - -inline Result ClientImpl::Post(const std::string &path, - const MultipartFormDataItems &items) { - return Post(path, Headers(), items); -} - -inline Result ClientImpl::Post(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items) { - const auto &boundary = detail::make_multipart_data_boundary(); - const auto &content_type = - detail::serialize_multipart_formdata_get_content_type(boundary); - const auto &body = detail::serialize_multipart_formdata(items, boundary); - return Post(path, headers, body, content_type); -} - -inline Result ClientImpl::Post(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const std::string &boundary) { - if (!detail::is_multipart_boundary_chars_valid(boundary)) { - return Result{nullptr, Error::UnsupportedMultipartBoundaryChars}; - } - - const auto &content_type = - detail::serialize_multipart_formdata_get_content_type(boundary); - const auto &body = detail::serialize_multipart_formdata(items, boundary); - return Post(path, headers, body, content_type); -} - -inline Result ClientImpl::Post( - const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items) { - const auto &boundary = detail::make_multipart_data_boundary(); - const auto &content_type = - detail::serialize_multipart_formdata_get_content_type(boundary); - return send_with_content_provider( - "POST", path, headers, nullptr, 0, nullptr, - get_multipart_content_provider(boundary, items, provider_items), - content_type, nullptr); -} - -inline Result ClientImpl::Put(const std::string &path) { - return Put(path, std::string(), std::string()); -} - -inline Result ClientImpl::Put(const std::string &path, const char *body, - size_t content_length, - const std::string &content_type) { - return Put(path, Headers(), body, content_length, content_type); -} - -inline Result ClientImpl::Put(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type) { - return send_with_content_provider("PUT", path, headers, body, content_length, - nullptr, nullptr, content_type, nullptr); -} - -inline Result ClientImpl::Put(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type, - Progress progress) { - return send_with_content_provider("PUT", path, headers, body, content_length, - nullptr, nullptr, content_type, progress); -} - -inline Result ClientImpl::Put(const std::string &path, const std::string &body, - const std::string &content_type) { - return Put(path, Headers(), body, content_type); -} - -inline Result ClientImpl::Put(const std::string &path, const std::string &body, - const std::string &content_type, - Progress progress) { - return Put(path, Headers(), body, content_type, progress); -} - -inline Result ClientImpl::Put(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type) { - return send_with_content_provider("PUT", path, headers, body.data(), - body.size(), nullptr, nullptr, content_type, - nullptr); -} - -inline Result ClientImpl::Put(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type, - Progress progress) { - return send_with_content_provider("PUT", path, headers, body.data(), - body.size(), nullptr, nullptr, content_type, - progress); -} - -inline Result ClientImpl::Put(const std::string &path, size_t content_length, - ContentProvider content_provider, - const std::string &content_type) { - return Put(path, Headers(), content_length, std::move(content_provider), - content_type); -} - -inline Result ClientImpl::Put(const std::string &path, - ContentProviderWithoutLength content_provider, - const std::string &content_type) { - return Put(path, Headers(), std::move(content_provider), content_type); -} - -inline Result ClientImpl::Put(const std::string &path, const Headers &headers, - size_t content_length, - ContentProvider content_provider, - const std::string &content_type) { - return send_with_content_provider("PUT", path, headers, nullptr, - content_length, std::move(content_provider), - nullptr, content_type, nullptr); -} - -inline Result ClientImpl::Put(const std::string &path, const Headers &headers, - ContentProviderWithoutLength content_provider, - const std::string &content_type) { - return send_with_content_provider("PUT", path, headers, nullptr, 0, nullptr, - std::move(content_provider), content_type, - nullptr); -} - -inline Result ClientImpl::Put(const std::string &path, const Params ¶ms) { - return Put(path, Headers(), params); -} - -inline Result ClientImpl::Put(const std::string &path, const Headers &headers, - const Params ¶ms) { - auto query = detail::params_to_query_str(params); - return Put(path, headers, query, "application/x-www-form-urlencoded"); -} - -inline Result ClientImpl::Put(const std::string &path, const Headers &headers, - const Params ¶ms, Progress progress) { - auto query = detail::params_to_query_str(params); - return Put(path, headers, query, "application/x-www-form-urlencoded", - progress); -} - -inline Result ClientImpl::Put(const std::string &path, - const MultipartFormDataItems &items) { - return Put(path, Headers(), items); -} - -inline Result ClientImpl::Put(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items) { - const auto &boundary = detail::make_multipart_data_boundary(); - const auto &content_type = - detail::serialize_multipart_formdata_get_content_type(boundary); - const auto &body = detail::serialize_multipart_formdata(items, boundary); - return Put(path, headers, body, content_type); -} - -inline Result ClientImpl::Put(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const std::string &boundary) { - if (!detail::is_multipart_boundary_chars_valid(boundary)) { - return Result{nullptr, Error::UnsupportedMultipartBoundaryChars}; - } - - const auto &content_type = - detail::serialize_multipart_formdata_get_content_type(boundary); - const auto &body = detail::serialize_multipart_formdata(items, boundary); - return Put(path, headers, body, content_type); -} - -inline Result ClientImpl::Put( - const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items) { - const auto &boundary = detail::make_multipart_data_boundary(); - const auto &content_type = - detail::serialize_multipart_formdata_get_content_type(boundary); - return send_with_content_provider( - "PUT", path, headers, nullptr, 0, nullptr, - get_multipart_content_provider(boundary, items, provider_items), - content_type, nullptr); -} -inline Result ClientImpl::Patch(const std::string &path) { - return Patch(path, std::string(), std::string()); -} - -inline Result ClientImpl::Patch(const std::string &path, const char *body, - size_t content_length, - const std::string &content_type) { - return Patch(path, Headers(), body, content_length, content_type); -} - -inline Result ClientImpl::Patch(const std::string &path, const char *body, - size_t content_length, - const std::string &content_type, - Progress progress) { - return Patch(path, Headers(), body, content_length, content_type, progress); -} - -inline Result ClientImpl::Patch(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type) { - return Patch(path, headers, body, content_length, content_type, nullptr); -} - -inline Result ClientImpl::Patch(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type, - Progress progress) { - return send_with_content_provider("PATCH", path, headers, body, - content_length, nullptr, nullptr, - content_type, progress); -} - -inline Result ClientImpl::Patch(const std::string &path, - const std::string &body, - const std::string &content_type) { - return Patch(path, Headers(), body, content_type); -} - -inline Result ClientImpl::Patch(const std::string &path, - const std::string &body, - const std::string &content_type, - Progress progress) { - return Patch(path, Headers(), body, content_type, progress); -} - -inline Result ClientImpl::Patch(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type) { - return Patch(path, headers, body, content_type, nullptr); -} - -inline Result ClientImpl::Patch(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type, - Progress progress) { - return send_with_content_provider("PATCH", path, headers, body.data(), - body.size(), nullptr, nullptr, content_type, - progress); -} - -inline Result ClientImpl::Patch(const std::string &path, size_t content_length, - ContentProvider content_provider, - const std::string &content_type) { - return Patch(path, Headers(), content_length, std::move(content_provider), - content_type); -} - -inline Result ClientImpl::Patch(const std::string &path, - ContentProviderWithoutLength content_provider, - const std::string &content_type) { - return Patch(path, Headers(), std::move(content_provider), content_type); -} - -inline Result ClientImpl::Patch(const std::string &path, const Headers &headers, - size_t content_length, - ContentProvider content_provider, - const std::string &content_type) { - return send_with_content_provider("PATCH", path, headers, nullptr, - content_length, std::move(content_provider), - nullptr, content_type, nullptr); -} - -inline Result ClientImpl::Patch(const std::string &path, const Headers &headers, - ContentProviderWithoutLength content_provider, - const std::string &content_type) { - return send_with_content_provider("PATCH", path, headers, nullptr, 0, nullptr, - std::move(content_provider), content_type, - nullptr); -} - -inline Result ClientImpl::Delete(const std::string &path) { - return Delete(path, Headers(), std::string(), std::string()); -} - -inline Result ClientImpl::Delete(const std::string &path, - const Headers &headers) { - return Delete(path, headers, std::string(), std::string()); -} - -inline Result ClientImpl::Delete(const std::string &path, const char *body, - size_t content_length, - const std::string &content_type) { - return Delete(path, Headers(), body, content_length, content_type); -} - -inline Result ClientImpl::Delete(const std::string &path, const char *body, - size_t content_length, - const std::string &content_type, - Progress progress) { - return Delete(path, Headers(), body, content_length, content_type, progress); -} - -inline Result ClientImpl::Delete(const std::string &path, - const Headers &headers, const char *body, - size_t content_length, - const std::string &content_type) { - return Delete(path, headers, body, content_length, content_type, nullptr); -} - -inline Result ClientImpl::Delete(const std::string &path, - const Headers &headers, const char *body, - size_t content_length, - const std::string &content_type, - Progress progress) { - Request req; - req.method = "DELETE"; - req.headers = headers; - req.path = path; - req.progress = progress; - - if (!content_type.empty()) { - req.set_header("Content-Type", content_type); - } - req.body.assign(body, content_length); - - return send_(std::move(req)); -} - -inline Result ClientImpl::Delete(const std::string &path, - const std::string &body, - const std::string &content_type) { - return Delete(path, Headers(), body.data(), body.size(), content_type); -} - -inline Result ClientImpl::Delete(const std::string &path, - const std::string &body, - const std::string &content_type, - Progress progress) { - return Delete(path, Headers(), body.data(), body.size(), content_type, - progress); -} - -inline Result ClientImpl::Delete(const std::string &path, - const Headers &headers, - const std::string &body, - const std::string &content_type) { - return Delete(path, headers, body.data(), body.size(), content_type); -} - -inline Result ClientImpl::Delete(const std::string &path, - const Headers &headers, - const std::string &body, - const std::string &content_type, - Progress progress) { - return Delete(path, headers, body.data(), body.size(), content_type, - progress); -} - -inline Result ClientImpl::Options(const std::string &path) { - return Options(path, Headers()); -} - -inline Result ClientImpl::Options(const std::string &path, - const Headers &headers) { - Request req; - req.method = "OPTIONS"; - req.headers = headers; - req.path = path; - - return send_(std::move(req)); -} - -inline void ClientImpl::stop() { - std::lock_guard guard(socket_mutex_); - - // If there is anything ongoing right now, the ONLY thread-safe thing we can - // do is to shutdown_socket, so that threads using this socket suddenly - // discover they can't read/write any more and error out. Everything else - // (closing the socket, shutting ssl down) is unsafe because these actions are - // not thread-safe. - if (socket_requests_in_flight_ > 0) { - shutdown_socket(socket_); - - // Aside from that, we set a flag for the socket to be closed when we're - // done. - socket_should_be_closed_when_request_is_done_ = true; - return; - } - - // Otherwise, still holding the mutex, we can shut everything down ourselves - shutdown_ssl(socket_, true); - shutdown_socket(socket_); - close_socket(socket_); -} - -inline std::string ClientImpl::host() const { return host_; } - -inline int ClientImpl::port() const { return port_; } - -inline size_t ClientImpl::is_socket_open() const { - std::lock_guard guard(socket_mutex_); - return socket_.is_open(); -} - -inline socket_t ClientImpl::socket() const { return socket_.sock; } - -inline void ClientImpl::set_connection_timeout(time_t sec, time_t usec) { - connection_timeout_sec_ = sec; - connection_timeout_usec_ = usec; -} - -inline void ClientImpl::set_read_timeout(time_t sec, time_t usec) { - read_timeout_sec_ = sec; - read_timeout_usec_ = usec; -} - -inline void ClientImpl::set_write_timeout(time_t sec, time_t usec) { - write_timeout_sec_ = sec; - write_timeout_usec_ = usec; -} - -inline void ClientImpl::set_basic_auth(const std::string &username, - const std::string &password) { - basic_auth_username_ = username; - basic_auth_password_ = password; -} - -inline void ClientImpl::set_bearer_token_auth(const std::string &token) { - bearer_token_auth_token_ = token; -} - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -inline void ClientImpl::set_digest_auth(const std::string &username, - const std::string &password) { - digest_auth_username_ = username; - digest_auth_password_ = password; -} -#endif - -inline void ClientImpl::set_keep_alive(bool on) { keep_alive_ = on; } - -inline void ClientImpl::set_follow_location(bool on) { follow_location_ = on; } - -inline void ClientImpl::set_url_encode(bool on) { url_encode_ = on; } - -inline void ClientImpl::set_hostname_addr_map( - std::map addr_map) { - addr_map_ = std::move(addr_map); -} - -inline void ClientImpl::set_default_headers(Headers headers) { - default_headers_ = std::move(headers); -} - -inline void ClientImpl::set_header_writer( - std::function const &writer) { - header_writer_ = writer; -} - -inline void ClientImpl::set_address_family(int family) { - address_family_ = family; -} - -inline void ClientImpl::set_tcp_nodelay(bool on) { tcp_nodelay_ = on; } - -inline void ClientImpl::set_ipv6_v6only(bool on) { ipv6_v6only_ = on; } - -inline void ClientImpl::set_socket_options(SocketOptions socket_options) { - socket_options_ = std::move(socket_options); -} - -inline void ClientImpl::set_compress(bool on) { compress_ = on; } - -inline void ClientImpl::set_decompress(bool on) { decompress_ = on; } - -inline void ClientImpl::set_interface(const std::string &intf) { - interface_ = intf; -} - -inline void ClientImpl::set_proxy(const std::string &host, int port) { - proxy_host_ = host; - proxy_port_ = port; -} - -inline void ClientImpl::set_proxy_basic_auth(const std::string &username, - const std::string &password) { - proxy_basic_auth_username_ = username; - proxy_basic_auth_password_ = password; -} - -inline void ClientImpl::set_proxy_bearer_token_auth(const std::string &token) { - proxy_bearer_token_auth_token_ = token; -} - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -inline void ClientImpl::set_proxy_digest_auth(const std::string &username, - const std::string &password) { - proxy_digest_auth_username_ = username; - proxy_digest_auth_password_ = password; -} - -inline void ClientImpl::set_ca_cert_path(const std::string &ca_cert_file_path, - const std::string &ca_cert_dir_path) { - ca_cert_file_path_ = ca_cert_file_path; - ca_cert_dir_path_ = ca_cert_dir_path; -} - -inline void ClientImpl::set_ca_cert_store(X509_STORE *ca_cert_store) { - if (ca_cert_store && ca_cert_store != ca_cert_store_) { - ca_cert_store_ = ca_cert_store; - } -} - -inline X509_STORE *ClientImpl::create_ca_cert_store(const char *ca_cert, - std::size_t size) const { - auto mem = BIO_new_mem_buf(ca_cert, static_cast(size)); - auto se = detail::scope_exit([&] { BIO_free_all(mem); }); - if (!mem) { - return nullptr; - } - - auto inf = PEM_X509_INFO_read_bio(mem, nullptr, nullptr, nullptr); - if (!inf) { - return nullptr; - } - - auto cts = X509_STORE_new(); - if (cts) { - for (auto i = 0; i < static_cast(sk_X509_INFO_num(inf)); i++) { - auto itmp = sk_X509_INFO_value(inf, i); - if (!itmp) { - continue; - } - - if (itmp->x509) { - X509_STORE_add_cert(cts, itmp->x509); - } - if (itmp->crl) { - X509_STORE_add_crl(cts, itmp->crl); - } - } - } - - sk_X509_INFO_pop_free(inf, X509_INFO_free); - return cts; -} - -inline void ClientImpl::enable_server_certificate_verification(bool enabled) { - server_certificate_verification_ = enabled; -} - -inline void ClientImpl::enable_server_hostname_verification(bool enabled) { - server_hostname_verification_ = enabled; -} - -inline void ClientImpl::set_server_certificate_verifier( - std::function verifier) { - server_certificate_verifier_ = verifier; -} -#endif - -inline void ClientImpl::set_logger(Logger logger) { - logger_ = std::move(logger); -} - -/* - * SSL Implementation - */ -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -namespace detail { - -template -inline SSL *ssl_new(socket_t sock, SSL_CTX *ctx, std::mutex &ctx_mutex, - U SSL_connect_or_accept, V setup) { - SSL *ssl = nullptr; - { - std::lock_guard guard(ctx_mutex); - ssl = SSL_new(ctx); - } - - if (ssl) { - set_nonblocking(sock, true); - auto bio = BIO_new_socket(static_cast(sock), BIO_NOCLOSE); - BIO_set_nbio(bio, 1); - SSL_set_bio(ssl, bio, bio); - - if (!setup(ssl) || SSL_connect_or_accept(ssl) != 1) { - SSL_shutdown(ssl); - { - std::lock_guard guard(ctx_mutex); - SSL_free(ssl); - } - set_nonblocking(sock, false); - return nullptr; - } - BIO_set_nbio(bio, 0); - set_nonblocking(sock, false); - } - - return ssl; -} - -inline void ssl_delete(std::mutex &ctx_mutex, SSL *ssl, socket_t sock, - bool shutdown_gracefully) { - // sometimes we may want to skip this to try to avoid SIGPIPE if we know - // the remote has closed the network connection - // Note that it is not always possible to avoid SIGPIPE, this is merely a - // best-efforts. - if (shutdown_gracefully) { -#ifdef _WIN32 - SSL_shutdown(ssl); -#else - timeval tv; - tv.tv_sec = 1; - tv.tv_usec = 0; - setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, - reinterpret_cast(&tv), sizeof(tv)); - - auto ret = SSL_shutdown(ssl); - while (ret == 0) { - std::this_thread::sleep_for(std::chrono::milliseconds{100}); - ret = SSL_shutdown(ssl); - } -#endif - } - - std::lock_guard guard(ctx_mutex); - SSL_free(ssl); -} - -template -bool ssl_connect_or_accept_nonblocking(socket_t sock, SSL *ssl, - U ssl_connect_or_accept, - time_t timeout_sec, - time_t timeout_usec) { - auto res = 0; - while ((res = ssl_connect_or_accept(ssl)) != 1) { - auto err = SSL_get_error(ssl, res); - switch (err) { - case SSL_ERROR_WANT_READ: - if (select_read(sock, timeout_sec, timeout_usec) > 0) { - continue; - } - break; - case SSL_ERROR_WANT_WRITE: - if (select_write(sock, timeout_sec, timeout_usec) > 0) { - continue; - } - break; - default: - break; - } - return false; - } - return true; -} - -template -inline bool process_server_socket_ssl( - const std::atomic &svr_sock, SSL *ssl, socket_t sock, - size_t keep_alive_max_count, time_t keep_alive_timeout_sec, - time_t read_timeout_sec, time_t read_timeout_usec, time_t write_timeout_sec, - time_t write_timeout_usec, T callback) { - return process_server_socket_core( - svr_sock, sock, keep_alive_max_count, keep_alive_timeout_sec, - [&](bool close_connection, bool &connection_closed) { - SSLSocketStream strm(sock, ssl, read_timeout_sec, read_timeout_usec, - write_timeout_sec, write_timeout_usec); - return callback(strm, close_connection, connection_closed); - }); -} - -template -inline bool process_client_socket_ssl(SSL *ssl, socket_t sock, - time_t read_timeout_sec, - time_t read_timeout_usec, - time_t write_timeout_sec, - time_t write_timeout_usec, T callback) { - SSLSocketStream strm(sock, ssl, read_timeout_sec, read_timeout_usec, - write_timeout_sec, write_timeout_usec); - return callback(strm); -} - -class SSLInit { - public: - SSLInit() { - OPENSSL_init_ssl( - OPENSSL_INIT_LOAD_SSL_STRINGS | OPENSSL_INIT_LOAD_CRYPTO_STRINGS, NULL); - } -}; - -// SSL socket stream implementation -inline SSLSocketStream::SSLSocketStream(socket_t sock, SSL *ssl, - time_t read_timeout_sec, - time_t read_timeout_usec, - time_t write_timeout_sec, - time_t write_timeout_usec) - : sock_(sock), - ssl_(ssl), - read_timeout_sec_(read_timeout_sec), - read_timeout_usec_(read_timeout_usec), - write_timeout_sec_(write_timeout_sec), - write_timeout_usec_(write_timeout_usec) { - SSL_clear_mode(ssl, SSL_MODE_AUTO_RETRY); -} - -inline SSLSocketStream::~SSLSocketStream() = default; - -inline bool SSLSocketStream::is_readable() const { - return detail::select_read(sock_, read_timeout_sec_, read_timeout_usec_) > 0; -} - -inline bool SSLSocketStream::is_writable() const { - return select_write(sock_, write_timeout_sec_, write_timeout_usec_) > 0 && - is_socket_alive(sock_); -} - -inline ssize_t SSLSocketStream::read(char *ptr, size_t size) { - if (SSL_pending(ssl_) > 0) { - return SSL_read(ssl_, ptr, static_cast(size)); - } else if (is_readable()) { - auto ret = SSL_read(ssl_, ptr, static_cast(size)); - if (ret < 0) { - auto err = SSL_get_error(ssl_, ret); - auto n = 1000; -#ifdef _WIN32 - while (--n >= 0 && (err == SSL_ERROR_WANT_READ || - (err == SSL_ERROR_SYSCALL && - WSAGetLastError() == WSAETIMEDOUT))) { -#else - while (--n >= 0 && err == SSL_ERROR_WANT_READ) { -#endif - if (SSL_pending(ssl_) > 0) { - return SSL_read(ssl_, ptr, static_cast(size)); - } else if (is_readable()) { - std::this_thread::sleep_for(std::chrono::microseconds{10}); - ret = SSL_read(ssl_, ptr, static_cast(size)); - if (ret >= 0) { - return ret; - } - err = SSL_get_error(ssl_, ret); - } else { - return -1; - } - } - } - return ret; - } - return -1; -} - -inline ssize_t SSLSocketStream::write(const char *ptr, size_t size) { - if (is_writable()) { - auto handle_size = static_cast( - std::min(size, (std::numeric_limits::max)())); - - auto ret = SSL_write(ssl_, ptr, static_cast(handle_size)); - if (ret < 0) { - auto err = SSL_get_error(ssl_, ret); - auto n = 1000; -#ifdef _WIN32 - while (--n >= 0 && (err == SSL_ERROR_WANT_WRITE || - (err == SSL_ERROR_SYSCALL && - WSAGetLastError() == WSAETIMEDOUT))) { -#else - while (--n >= 0 && err == SSL_ERROR_WANT_WRITE) { -#endif - if (is_writable()) { - std::this_thread::sleep_for(std::chrono::microseconds{10}); - ret = SSL_write(ssl_, ptr, static_cast(handle_size)); - if (ret >= 0) { - return ret; - } - err = SSL_get_error(ssl_, ret); - } else { - return -1; - } - } - } - return ret; - } - return -1; -} - -inline void SSLSocketStream::get_remote_ip_and_port(std::string &ip, - int &port) const { - detail::get_remote_ip_and_port(sock_, ip, port); -} - -inline void SSLSocketStream::get_local_ip_and_port(std::string &ip, - int &port) const { - detail::get_local_ip_and_port(sock_, ip, port); -} - -inline socket_t SSLSocketStream::socket() const { return sock_; } - -static SSLInit sslinit_; - -} // namespace detail - -// SSL HTTP server implementation -inline SSLServer::SSLServer(const char *cert_path, const char *private_key_path, - const char *client_ca_cert_file_path, - const char *client_ca_cert_dir_path, - const char *private_key_password) { - ctx_ = SSL_CTX_new(TLS_server_method()); - - if (ctx_) { - SSL_CTX_set_options( - ctx_, - SSL_OP_NO_COMPRESSION | SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION); - - SSL_CTX_set_min_proto_version(ctx_, TLS1_2_VERSION); - - if (private_key_password != nullptr && (private_key_password[0] != '\0')) { - SSL_CTX_set_default_passwd_cb_userdata( - ctx_, - reinterpret_cast(const_cast(private_key_password))); - } - - if (SSL_CTX_use_certificate_chain_file(ctx_, cert_path) != 1 || - SSL_CTX_use_PrivateKey_file(ctx_, private_key_path, SSL_FILETYPE_PEM) != - 1 || - SSL_CTX_check_private_key(ctx_) != 1) { - SSL_CTX_free(ctx_); - ctx_ = nullptr; - } else if (client_ca_cert_file_path || client_ca_cert_dir_path) { - SSL_CTX_load_verify_locations(ctx_, client_ca_cert_file_path, - client_ca_cert_dir_path); - - SSL_CTX_set_verify( - ctx_, SSL_VERIFY_PEER | SSL_VERIFY_FAIL_IF_NO_PEER_CERT, nullptr); - } - } -} - -inline SSLServer::SSLServer(X509 *cert, EVP_PKEY *private_key, - X509_STORE *client_ca_cert_store) { - ctx_ = SSL_CTX_new(TLS_server_method()); - - if (ctx_) { - SSL_CTX_set_options( - ctx_, - SSL_OP_NO_COMPRESSION | SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION); - - SSL_CTX_set_min_proto_version(ctx_, TLS1_2_VERSION); - - if (SSL_CTX_use_certificate(ctx_, cert) != 1 || - SSL_CTX_use_PrivateKey(ctx_, private_key) != 1) { - SSL_CTX_free(ctx_); - ctx_ = nullptr; - } else if (client_ca_cert_store) { - SSL_CTX_set_cert_store(ctx_, client_ca_cert_store); - - SSL_CTX_set_verify( - ctx_, SSL_VERIFY_PEER | SSL_VERIFY_FAIL_IF_NO_PEER_CERT, nullptr); - } - } -} - -inline SSLServer::SSLServer( - const std::function &setup_ssl_ctx_callback) { - ctx_ = SSL_CTX_new(TLS_method()); - if (ctx_) { - if (!setup_ssl_ctx_callback(*ctx_)) { - SSL_CTX_free(ctx_); - ctx_ = nullptr; - } - } -} - -inline SSLServer::~SSLServer() { - if (ctx_) { - SSL_CTX_free(ctx_); - } -} - -inline bool SSLServer::is_valid() const { return ctx_; } - -inline SSL_CTX *SSLServer::ssl_context() const { return ctx_; } - -inline void SSLServer::update_certs(X509 *cert, EVP_PKEY *private_key, - X509_STORE *client_ca_cert_store) { - std::lock_guard guard(ctx_mutex_); - - SSL_CTX_use_certificate(ctx_, cert); - SSL_CTX_use_PrivateKey(ctx_, private_key); - - if (client_ca_cert_store != nullptr) { - SSL_CTX_set_cert_store(ctx_, client_ca_cert_store); - } -} - -inline bool SSLServer::process_and_close_socket(socket_t sock) { - auto ssl = detail::ssl_new( - sock, ctx_, ctx_mutex_, - [&](SSL *ssl2) { - return detail::ssl_connect_or_accept_nonblocking( - sock, ssl2, SSL_accept, read_timeout_sec_, read_timeout_usec_); - }, - [](SSL * /*ssl2*/) { return true; }); - - auto ret = false; - if (ssl) { - std::string remote_addr; - int remote_port = 0; - detail::get_remote_ip_and_port(sock, remote_addr, remote_port); - - std::string local_addr; - int local_port = 0; - detail::get_local_ip_and_port(sock, local_addr, local_port); - - ret = detail::process_server_socket_ssl( - svr_sock_, ssl, sock, keep_alive_max_count_, keep_alive_timeout_sec_, - read_timeout_sec_, read_timeout_usec_, write_timeout_sec_, - write_timeout_usec_, - [&](Stream &strm, bool close_connection, bool &connection_closed) { - return process_request(strm, remote_addr, remote_port, local_addr, - local_port, close_connection, - connection_closed, - [&](Request &req) { req.ssl = ssl; }); - }); - - // Shutdown gracefully if the result seemed successful, non-gracefully if - // the connection appeared to be closed. - const bool shutdown_gracefully = ret; - detail::ssl_delete(ctx_mutex_, ssl, sock, shutdown_gracefully); - } - - detail::shutdown_socket(sock); - detail::close_socket(sock); - return ret; -} - -// SSL HTTP client implementation -inline SSLClient::SSLClient(const std::string &host) - : SSLClient(host, 443, std::string(), std::string()) {} - -inline SSLClient::SSLClient(const std::string &host, int port) - : SSLClient(host, port, std::string(), std::string()) {} - -inline SSLClient::SSLClient(const std::string &host, int port, - const std::string &client_cert_path, - const std::string &client_key_path, - const std::string &private_key_password) - : ClientImpl(host, port, client_cert_path, client_key_path) { - ctx_ = SSL_CTX_new(TLS_client_method()); - - SSL_CTX_set_min_proto_version(ctx_, TLS1_2_VERSION); - - detail::split(&host_[0], &host_[host_.size()], '.', - [&](const char *b, const char *e) { - host_components_.emplace_back(b, e); - }); - - if (!client_cert_path.empty() && !client_key_path.empty()) { - if (!private_key_password.empty()) { - SSL_CTX_set_default_passwd_cb_userdata( - ctx_, reinterpret_cast( - const_cast(private_key_password.c_str()))); - } - - if (SSL_CTX_use_certificate_file(ctx_, client_cert_path.c_str(), - SSL_FILETYPE_PEM) != 1 || - SSL_CTX_use_PrivateKey_file(ctx_, client_key_path.c_str(), - SSL_FILETYPE_PEM) != 1) { - SSL_CTX_free(ctx_); - ctx_ = nullptr; - } - } -} - -inline SSLClient::SSLClient(const std::string &host, int port, - X509 *client_cert, EVP_PKEY *client_key, - const std::string &private_key_password) - : ClientImpl(host, port) { - ctx_ = SSL_CTX_new(TLS_client_method()); - - detail::split(&host_[0], &host_[host_.size()], '.', - [&](const char *b, const char *e) { - host_components_.emplace_back(b, e); - }); - - if (client_cert != nullptr && client_key != nullptr) { - if (!private_key_password.empty()) { - SSL_CTX_set_default_passwd_cb_userdata( - ctx_, reinterpret_cast( - const_cast(private_key_password.c_str()))); - } - - if (SSL_CTX_use_certificate(ctx_, client_cert) != 1 || - SSL_CTX_use_PrivateKey(ctx_, client_key) != 1) { - SSL_CTX_free(ctx_); - ctx_ = nullptr; - } - } -} - -inline SSLClient::~SSLClient() { - if (ctx_) { - SSL_CTX_free(ctx_); - } - // Make sure to shut down SSL since shutdown_ssl will resolve to the - // base function rather than the derived function once we get to the - // base class destructor, and won't free the SSL (causing a leak). - shutdown_ssl_impl(socket_, true); -} - -inline bool SSLClient::is_valid() const { return ctx_; } - -inline void SSLClient::set_ca_cert_store(X509_STORE *ca_cert_store) { - if (ca_cert_store) { - if (ctx_) { - if (SSL_CTX_get_cert_store(ctx_) != ca_cert_store) { - // Free memory allocated for old cert and use new store `ca_cert_store` - SSL_CTX_set_cert_store(ctx_, ca_cert_store); - } - } else { - X509_STORE_free(ca_cert_store); - } - } -} - -inline void SSLClient::load_ca_cert_store(const char *ca_cert, - std::size_t size) { - set_ca_cert_store(ClientImpl::create_ca_cert_store(ca_cert, size)); -} - -inline long SSLClient::get_openssl_verify_result() const { - return verify_result_; -} - -inline SSL_CTX *SSLClient::ssl_context() const { return ctx_; } - -inline bool SSLClient::create_and_connect_socket(Socket &socket, Error &error) { - return is_valid() && ClientImpl::create_and_connect_socket(socket, error); -} - -// Assumes that socket_mutex_ is locked and that there are no requests in flight -inline bool SSLClient::connect_with_proxy(Socket &socket, Response &res, - bool &success, Error &error) { - success = true; - Response proxy_res; - if (!detail::process_client_socket( - socket.sock, read_timeout_sec_, read_timeout_usec_, - write_timeout_sec_, write_timeout_usec_, [&](Stream &strm) { - Request req2; - req2.method = "CONNECT"; - req2.path = host_and_port_; - return process_request(strm, req2, proxy_res, false, error); - })) { - // Thread-safe to close everything because we are assuming there are no - // requests in flight - shutdown_ssl(socket, true); - shutdown_socket(socket); - close_socket(socket); - success = false; - return false; - } - - if (proxy_res.status == StatusCode::ProxyAuthenticationRequired_407) { - if (!proxy_digest_auth_username_.empty() && - !proxy_digest_auth_password_.empty()) { - std::map auth; - if (detail::parse_www_authenticate(proxy_res, auth, true)) { - proxy_res = Response(); - if (!detail::process_client_socket( - socket.sock, read_timeout_sec_, read_timeout_usec_, - write_timeout_sec_, write_timeout_usec_, [&](Stream &strm) { - Request req3; - req3.method = "CONNECT"; - req3.path = host_and_port_; - req3.headers.insert(detail::make_digest_authentication_header( - req3, auth, 1, detail::random_string(10), - proxy_digest_auth_username_, proxy_digest_auth_password_, - true)); - return process_request(strm, req3, proxy_res, false, error); - })) { - // Thread-safe to close everything because we are assuming there are - // no requests in flight - shutdown_ssl(socket, true); - shutdown_socket(socket); - close_socket(socket); - success = false; - return false; - } - } - } - } - - // If status code is not 200, proxy request is failed. - // Set error to ProxyConnection and return proxy response - // as the response of the request - if (proxy_res.status != StatusCode::OK_200) { - error = Error::ProxyConnection; - res = std::move(proxy_res); - // Thread-safe to close everything because we are assuming there are - // no requests in flight - shutdown_ssl(socket, true); - shutdown_socket(socket); - close_socket(socket); - return false; - } - - return true; -} - -inline bool SSLClient::load_certs() { - auto ret = true; - - std::call_once(initialize_cert_, [&]() { - std::lock_guard guard(ctx_mutex_); - if (!ca_cert_file_path_.empty()) { - if (!SSL_CTX_load_verify_locations(ctx_, ca_cert_file_path_.c_str(), - nullptr)) { - ret = false; - } - } else if (!ca_cert_dir_path_.empty()) { - if (!SSL_CTX_load_verify_locations(ctx_, nullptr, - ca_cert_dir_path_.c_str())) { - ret = false; - } - } else { - auto loaded = false; -#ifdef _WIN32 - loaded = - detail::load_system_certs_on_windows(SSL_CTX_get_cert_store(ctx_)); -#elif defined(CPPHTTPLIB_USE_CERTS_FROM_MACOSX_KEYCHAIN) && defined(__APPLE__) -#if TARGET_OS_OSX - loaded = detail::load_system_certs_on_macos(SSL_CTX_get_cert_store(ctx_)); -#endif // TARGET_OS_OSX -#endif // _WIN32 - if (!loaded) { - SSL_CTX_set_default_verify_paths(ctx_); - } - } - }); - - return ret; -} - -inline bool SSLClient::initialize_ssl(Socket &socket, Error &error) { - auto ssl = detail::ssl_new( - socket.sock, ctx_, ctx_mutex_, - [&](SSL *ssl2) { - if (server_certificate_verification_) { - if (!load_certs()) { - error = Error::SSLLoadingCerts; - return false; - } - SSL_set_verify(ssl2, SSL_VERIFY_NONE, nullptr); - } - - if (!detail::ssl_connect_or_accept_nonblocking( - socket.sock, ssl2, SSL_connect, connection_timeout_sec_, - connection_timeout_usec_)) { - error = Error::SSLConnection; - return false; - } - - if (server_certificate_verification_) { - if (server_certificate_verifier_) { - if (!server_certificate_verifier_(ssl2)) { - error = Error::SSLServerVerification; - return false; - } - } else { - verify_result_ = SSL_get_verify_result(ssl2); - - if (verify_result_ != X509_V_OK) { - error = Error::SSLServerVerification; - return false; - } - - auto server_cert = SSL_get1_peer_certificate(ssl2); - auto se = detail::scope_exit([&] { X509_free(server_cert); }); - - if (server_cert == nullptr) { - error = Error::SSLServerVerification; - return false; - } - - if (server_hostname_verification_) { - if (!verify_host(server_cert)) { - error = Error::SSLServerHostnameVerification; - return false; - } - } - } - } - - return true; - }, - [&](SSL *ssl2) { -#if defined(OPENSSL_IS_BORINGSSL) - SSL_set_tlsext_host_name(ssl2, host_.c_str()); -#else - // NOTE: Direct call instead of using the OpenSSL macro to suppress - // -Wold-style-cast warning - SSL_ctrl(ssl2, SSL_CTRL_SET_TLSEXT_HOSTNAME, TLSEXT_NAMETYPE_host_name, - static_cast(const_cast(host_.c_str()))); -#endif - return true; - }); - - if (ssl) { - socket.ssl = ssl; - return true; - } - - shutdown_socket(socket); - close_socket(socket); - return false; -} - -inline void SSLClient::shutdown_ssl(Socket &socket, bool shutdown_gracefully) { - shutdown_ssl_impl(socket, shutdown_gracefully); -} - -inline void SSLClient::shutdown_ssl_impl(Socket &socket, - bool shutdown_gracefully) { - if (socket.sock == INVALID_SOCKET) { - assert(socket.ssl == nullptr); - return; - } - if (socket.ssl) { - detail::ssl_delete(ctx_mutex_, socket.ssl, socket.sock, - shutdown_gracefully); - socket.ssl = nullptr; - } - assert(socket.ssl == nullptr); -} - -inline bool SSLClient::process_socket( - const Socket &socket, std::function callback) { - assert(socket.ssl); - return detail::process_client_socket_ssl( - socket.ssl, socket.sock, read_timeout_sec_, read_timeout_usec_, - write_timeout_sec_, write_timeout_usec_, std::move(callback)); -} - -inline bool SSLClient::is_ssl() const { return true; } - -inline bool SSLClient::verify_host(X509 *server_cert) const { - /* Quote from RFC2818 section 3.1 "Server Identity" - - If a subjectAltName extension of type dNSName is present, that MUST - be used as the identity. Otherwise, the (most specific) Common Name - field in the Subject field of the certificate MUST be used. Although - the use of the Common Name is existing practice, it is deprecated and - Certification Authorities are encouraged to use the dNSName instead. - - Matching is performed using the matching rules specified by - [RFC2459]. If more than one identity of a given type is present in - the certificate (e.g., more than one dNSName name, a match in any one - of the set is considered acceptable.) Names may contain the wildcard - character * which is considered to match any single domain name - component or component fragment. E.g., *.a.com matches foo.a.com but - not bar.foo.a.com. f*.com matches foo.com but not bar.com. - - In some cases, the URI is specified as an IP address rather than a - hostname. In this case, the iPAddress subjectAltName must be present - in the certificate and must exactly match the IP in the URI. - - */ - return verify_host_with_subject_alt_name(server_cert) || - verify_host_with_common_name(server_cert); -} - -inline bool SSLClient::verify_host_with_subject_alt_name( - X509 *server_cert) const { - auto ret = false; - - auto type = GEN_DNS; - - struct in6_addr addr6 {}; - struct in_addr addr {}; - size_t addr_len = 0; - -#ifndef __MINGW32__ - if (inet_pton(AF_INET6, host_.c_str(), &addr6)) { - type = GEN_IPADD; - addr_len = sizeof(struct in6_addr); - } else if (inet_pton(AF_INET, host_.c_str(), &addr)) { - type = GEN_IPADD; - addr_len = sizeof(struct in_addr); - } -#endif - - auto alt_names = static_cast( - X509_get_ext_d2i(server_cert, NID_subject_alt_name, nullptr, nullptr)); - - if (alt_names) { - auto dsn_matched = false; - auto ip_matched = false; - - auto count = sk_GENERAL_NAME_num(alt_names); - - for (decltype(count) i = 0; i < count && !dsn_matched; i++) { - auto val = sk_GENERAL_NAME_value(alt_names, i); - if (val->type == type) { - auto name = - reinterpret_cast(ASN1_STRING_get0_data(val->d.ia5)); - auto name_len = static_cast(ASN1_STRING_length(val->d.ia5)); - - switch (type) { - case GEN_DNS: - dsn_matched = check_host_name(name, name_len); - break; - - case GEN_IPADD: - if (!memcmp(&addr6, name, addr_len) || - !memcmp(&addr, name, addr_len)) { - ip_matched = true; - } - break; - } - } - } - - if (dsn_matched || ip_matched) { - ret = true; - } - } - - GENERAL_NAMES_free(const_cast( - reinterpret_cast(alt_names))); - return ret; -} - -inline bool SSLClient::verify_host_with_common_name(X509 *server_cert) const { - const auto subject_name = X509_get_subject_name(server_cert); - - if (subject_name != nullptr) { - char name[BUFSIZ]; - auto name_len = X509_NAME_get_text_by_NID(subject_name, NID_commonName, - name, sizeof(name)); - - if (name_len != -1) { - return check_host_name(name, static_cast(name_len)); - } - } - - return false; -} - -inline bool SSLClient::check_host_name(const char *pattern, - size_t pattern_len) const { - if (host_.size() == pattern_len && host_ == pattern) { - return true; - } - - // Wildcard match - // https://bugs.launchpad.net/ubuntu/+source/firefox-3.0/+bug/376484 - std::vector pattern_components; - detail::split(&pattern[0], &pattern[pattern_len], '.', - [&](const char *b, const char *e) { - pattern_components.emplace_back(b, e); - }); - - if (host_components_.size() != pattern_components.size()) { - return false; - } - - auto itr = pattern_components.begin(); - for (const auto &h : host_components_) { - auto &p = *itr; - if (p != h && p != "*") { - auto partial_match = (p.size() > 0 && p[p.size() - 1] == '*' && - !p.compare(0, p.size() - 1, h)); - if (!partial_match) { - return false; - } - } - ++itr; - } - - return true; -} -#endif - -// Universal client implementation -inline Client::Client(const std::string &scheme_host_port) - : Client(scheme_host_port, std::string(), std::string()) {} - -inline Client::Client(const std::string &scheme_host_port, - const std::string &client_cert_path, - const std::string &client_key_path) { - const static std::regex re( - R"((?:([a-z]+):\/\/)?(?:\[([a-fA-F\d:]+)\]|([^:/?#]+))(?::(\d+))?)"); - - std::smatch m; - if (std::regex_match(scheme_host_port, m, re)) { - auto scheme = m[1].str(); - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - if (!scheme.empty() && (scheme != "http" && scheme != "https")) { -#else - if (!scheme.empty() && scheme != "http") { -#endif -#ifndef CPPHTTPLIB_NO_EXCEPTIONS - std::string msg = "'" + scheme + "' scheme is not supported."; - throw std::invalid_argument(msg); -#endif - return; - } - - auto is_ssl = scheme == "https"; - - auto host = m[2].str(); - if (host.empty()) { - host = m[3].str(); - } - - auto port_str = m[4].str(); - auto port = !port_str.empty() ? std::stoi(port_str) : (is_ssl ? 443 : 80); - - if (is_ssl) { -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT - cli_ = detail::make_unique(host, port, client_cert_path, - client_key_path); - is_ssl_ = is_ssl; -#endif - } else { - cli_ = detail::make_unique(host, port, client_cert_path, - client_key_path); - } - } else { - // NOTE: Update TEST(UniversalClientImplTest, Ipv6LiteralAddress) - // if port param below changes. - cli_ = detail::make_unique(scheme_host_port, 80, - client_cert_path, client_key_path); - } -} // namespace detail - -inline Client::Client(const std::string &host, int port) - : cli_(detail::make_unique(host, port)) {} - -inline Client::Client(const std::string &host, int port, - const std::string &client_cert_path, - const std::string &client_key_path) - : cli_(detail::make_unique(host, port, client_cert_path, - client_key_path)) {} - -inline Client::~Client() = default; - -inline bool Client::is_valid() const { - return cli_ != nullptr && cli_->is_valid(); -} - -inline Result Client::Get(const std::string &path) { return cli_->Get(path); } -inline Result Client::Get(const std::string &path, const Headers &headers) { - return cli_->Get(path, headers); -} -inline Result Client::Get(const std::string &path, Progress progress) { - return cli_->Get(path, std::move(progress)); -} -inline Result Client::Get(const std::string &path, const Headers &headers, - Progress progress) { - return cli_->Get(path, headers, std::move(progress)); -} -inline Result Client::Get(const std::string &path, - ContentReceiver content_receiver) { - return cli_->Get(path, std::move(content_receiver)); -} -inline Result Client::Get(const std::string &path, const Headers &headers, - ContentReceiver content_receiver) { - return cli_->Get(path, headers, std::move(content_receiver)); -} -inline Result Client::Get(const std::string &path, - ContentReceiver content_receiver, Progress progress) { - return cli_->Get(path, std::move(content_receiver), std::move(progress)); -} -inline Result Client::Get(const std::string &path, const Headers &headers, - ContentReceiver content_receiver, Progress progress) { - return cli_->Get(path, headers, std::move(content_receiver), - std::move(progress)); -} -inline Result Client::Get(const std::string &path, - ResponseHandler response_handler, - ContentReceiver content_receiver) { - return cli_->Get(path, std::move(response_handler), - std::move(content_receiver)); -} -inline Result Client::Get(const std::string &path, const Headers &headers, - ResponseHandler response_handler, - ContentReceiver content_receiver) { - return cli_->Get(path, headers, std::move(response_handler), - std::move(content_receiver)); -} -inline Result Client::Get(const std::string &path, - ResponseHandler response_handler, - ContentReceiver content_receiver, Progress progress) { - return cli_->Get(path, std::move(response_handler), - std::move(content_receiver), std::move(progress)); -} -inline Result Client::Get(const std::string &path, const Headers &headers, - ResponseHandler response_handler, - ContentReceiver content_receiver, Progress progress) { - return cli_->Get(path, headers, std::move(response_handler), - std::move(content_receiver), std::move(progress)); -} -inline Result Client::Get(const std::string &path, const Params ¶ms, - const Headers &headers, Progress progress) { - return cli_->Get(path, params, headers, std::move(progress)); -} -inline Result Client::Get(const std::string &path, const Params ¶ms, - const Headers &headers, - ContentReceiver content_receiver, Progress progress) { - return cli_->Get(path, params, headers, std::move(content_receiver), - std::move(progress)); -} -inline Result Client::Get(const std::string &path, const Params ¶ms, - const Headers &headers, - ResponseHandler response_handler, - ContentReceiver content_receiver, Progress progress) { - return cli_->Get(path, params, headers, std::move(response_handler), - std::move(content_receiver), std::move(progress)); -} - -inline Result Client::Head(const std::string &path) { return cli_->Head(path); } -inline Result Client::Head(const std::string &path, const Headers &headers) { - return cli_->Head(path, headers); -} - -inline Result Client::Post(const std::string &path) { return cli_->Post(path); } -inline Result Client::Post(const std::string &path, const Headers &headers) { - return cli_->Post(path, headers); -} -inline Result Client::Post(const std::string &path, const char *body, - size_t content_length, - const std::string &content_type) { - return cli_->Post(path, body, content_length, content_type); -} -inline Result Client::Post(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type) { - return cli_->Post(path, headers, body, content_length, content_type); -} -inline Result Client::Post(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type, Progress progress) { - return cli_->Post(path, headers, body, content_length, content_type, - progress); -} -inline Result Client::Post(const std::string &path, const std::string &body, - const std::string &content_type) { - return cli_->Post(path, body, content_type); -} -inline Result Client::Post(const std::string &path, const std::string &body, - const std::string &content_type, Progress progress) { - return cli_->Post(path, body, content_type, progress); -} -inline Result Client::Post(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type) { - return cli_->Post(path, headers, body, content_type); -} -inline Result Client::Post(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type, Progress progress) { - return cli_->Post(path, headers, body, content_type, progress); -} -inline Result Client::Post(const std::string &path, size_t content_length, - ContentProvider content_provider, - const std::string &content_type) { - return cli_->Post(path, content_length, std::move(content_provider), - content_type); -} -inline Result Client::Post(const std::string &path, - ContentProviderWithoutLength content_provider, - const std::string &content_type) { - return cli_->Post(path, std::move(content_provider), content_type); -} -inline Result Client::Post(const std::string &path, const Headers &headers, - size_t content_length, - ContentProvider content_provider, - const std::string &content_type) { - return cli_->Post(path, headers, content_length, std::move(content_provider), - content_type); -} -inline Result Client::Post(const std::string &path, const Headers &headers, - ContentProviderWithoutLength content_provider, - const std::string &content_type) { - return cli_->Post(path, headers, std::move(content_provider), content_type); -} -inline Result Client::Post(const std::string &path, const Params ¶ms) { - return cli_->Post(path, params); -} -inline Result Client::Post(const std::string &path, const Headers &headers, - const Params ¶ms) { - return cli_->Post(path, headers, params); -} -inline Result Client::Post(const std::string &path, const Headers &headers, - const Params ¶ms, Progress progress) { - return cli_->Post(path, headers, params, progress); -} -inline Result Client::Post(const std::string &path, - const MultipartFormDataItems &items) { - return cli_->Post(path, items); -} -inline Result Client::Post(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items) { - return cli_->Post(path, headers, items); -} -inline Result Client::Post(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const std::string &boundary) { - return cli_->Post(path, headers, items, boundary); -} -inline Result Client::Post( - const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items) { - return cli_->Post(path, headers, items, provider_items); -} -inline Result Client::Put(const std::string &path) { return cli_->Put(path); } -inline Result Client::Put(const std::string &path, const char *body, - size_t content_length, - const std::string &content_type) { - return cli_->Put(path, body, content_length, content_type); -} -inline Result Client::Put(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type) { - return cli_->Put(path, headers, body, content_length, content_type); -} -inline Result Client::Put(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type, Progress progress) { - return cli_->Put(path, headers, body, content_length, content_type, progress); -} -inline Result Client::Put(const std::string &path, const std::string &body, - const std::string &content_type) { - return cli_->Put(path, body, content_type); -} -inline Result Client::Put(const std::string &path, const std::string &body, - const std::string &content_type, Progress progress) { - return cli_->Put(path, body, content_type, progress); -} -inline Result Client::Put(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type) { - return cli_->Put(path, headers, body, content_type); -} -inline Result Client::Put(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type, Progress progress) { - return cli_->Put(path, headers, body, content_type, progress); -} -inline Result Client::Put(const std::string &path, size_t content_length, - ContentProvider content_provider, - const std::string &content_type) { - return cli_->Put(path, content_length, std::move(content_provider), - content_type); -} -inline Result Client::Put(const std::string &path, - ContentProviderWithoutLength content_provider, - const std::string &content_type) { - return cli_->Put(path, std::move(content_provider), content_type); -} -inline Result Client::Put(const std::string &path, const Headers &headers, - size_t content_length, - ContentProvider content_provider, - const std::string &content_type) { - return cli_->Put(path, headers, content_length, std::move(content_provider), - content_type); -} -inline Result Client::Put(const std::string &path, const Headers &headers, - ContentProviderWithoutLength content_provider, - const std::string &content_type) { - return cli_->Put(path, headers, std::move(content_provider), content_type); -} -inline Result Client::Put(const std::string &path, const Params ¶ms) { - return cli_->Put(path, params); -} -inline Result Client::Put(const std::string &path, const Headers &headers, - const Params ¶ms) { - return cli_->Put(path, headers, params); -} -inline Result Client::Put(const std::string &path, const Headers &headers, - const Params ¶ms, Progress progress) { - return cli_->Put(path, headers, params, progress); -} -inline Result Client::Put(const std::string &path, - const MultipartFormDataItems &items) { - return cli_->Put(path, items); -} -inline Result Client::Put(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items) { - return cli_->Put(path, headers, items); -} -inline Result Client::Put(const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const std::string &boundary) { - return cli_->Put(path, headers, items, boundary); -} -inline Result Client::Put( - const std::string &path, const Headers &headers, - const MultipartFormDataItems &items, - const MultipartFormDataProviderItems &provider_items) { - return cli_->Put(path, headers, items, provider_items); -} -inline Result Client::Patch(const std::string &path) { - return cli_->Patch(path); -} -inline Result Client::Patch(const std::string &path, const char *body, - size_t content_length, - const std::string &content_type) { - return cli_->Patch(path, body, content_length, content_type); -} -inline Result Client::Patch(const std::string &path, const char *body, - size_t content_length, - const std::string &content_type, - Progress progress) { - return cli_->Patch(path, body, content_length, content_type, progress); -} -inline Result Client::Patch(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type) { - return cli_->Patch(path, headers, body, content_length, content_type); -} -inline Result Client::Patch(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type, - Progress progress) { - return cli_->Patch(path, headers, body, content_length, content_type, - progress); -} -inline Result Client::Patch(const std::string &path, const std::string &body, - const std::string &content_type) { - return cli_->Patch(path, body, content_type); -} -inline Result Client::Patch(const std::string &path, const std::string &body, - const std::string &content_type, - Progress progress) { - return cli_->Patch(path, body, content_type, progress); -} -inline Result Client::Patch(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type) { - return cli_->Patch(path, headers, body, content_type); -} -inline Result Client::Patch(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type, - Progress progress) { - return cli_->Patch(path, headers, body, content_type, progress); -} -inline Result Client::Patch(const std::string &path, size_t content_length, - ContentProvider content_provider, - const std::string &content_type) { - return cli_->Patch(path, content_length, std::move(content_provider), - content_type); -} -inline Result Client::Patch(const std::string &path, - ContentProviderWithoutLength content_provider, - const std::string &content_type) { - return cli_->Patch(path, std::move(content_provider), content_type); -} -inline Result Client::Patch(const std::string &path, const Headers &headers, - size_t content_length, - ContentProvider content_provider, - const std::string &content_type) { - return cli_->Patch(path, headers, content_length, std::move(content_provider), - content_type); -} -inline Result Client::Patch(const std::string &path, const Headers &headers, - ContentProviderWithoutLength content_provider, - const std::string &content_type) { - return cli_->Patch(path, headers, std::move(content_provider), content_type); -} -inline Result Client::Delete(const std::string &path) { - return cli_->Delete(path); -} -inline Result Client::Delete(const std::string &path, const Headers &headers) { - return cli_->Delete(path, headers); -} -inline Result Client::Delete(const std::string &path, const char *body, - size_t content_length, - const std::string &content_type) { - return cli_->Delete(path, body, content_length, content_type); -} -inline Result Client::Delete(const std::string &path, const char *body, - size_t content_length, - const std::string &content_type, - Progress progress) { - return cli_->Delete(path, body, content_length, content_type, progress); -} -inline Result Client::Delete(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type) { - return cli_->Delete(path, headers, body, content_length, content_type); -} -inline Result Client::Delete(const std::string &path, const Headers &headers, - const char *body, size_t content_length, - const std::string &content_type, - Progress progress) { - return cli_->Delete(path, headers, body, content_length, content_type, - progress); -} -inline Result Client::Delete(const std::string &path, const std::string &body, - const std::string &content_type) { - return cli_->Delete(path, body, content_type); -} -inline Result Client::Delete(const std::string &path, const std::string &body, - const std::string &content_type, - Progress progress) { - return cli_->Delete(path, body, content_type, progress); -} -inline Result Client::Delete(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type) { - return cli_->Delete(path, headers, body, content_type); -} -inline Result Client::Delete(const std::string &path, const Headers &headers, - const std::string &body, - const std::string &content_type, - Progress progress) { - return cli_->Delete(path, headers, body, content_type, progress); -} -inline Result Client::Options(const std::string &path) { - return cli_->Options(path); -} -inline Result Client::Options(const std::string &path, const Headers &headers) { - return cli_->Options(path, headers); -} - -inline bool Client::send(Request &req, Response &res, Error &error) { - return cli_->send(req, res, error); -} - -inline Result Client::send(const Request &req) { return cli_->send(req); } - -inline void Client::stop() { cli_->stop(); } - -inline std::string Client::host() const { return cli_->host(); } - -inline int Client::port() const { return cli_->port(); } - -inline size_t Client::is_socket_open() const { return cli_->is_socket_open(); } - -inline socket_t Client::socket() const { return cli_->socket(); } - -inline void Client::set_hostname_addr_map( - std::map addr_map) { - cli_->set_hostname_addr_map(std::move(addr_map)); -} - -inline void Client::set_default_headers(Headers headers) { - cli_->set_default_headers(std::move(headers)); -} - -inline void Client::set_header_writer( - std::function const &writer) { - cli_->set_header_writer(writer); -} - -inline void Client::set_address_family(int family) { - cli_->set_address_family(family); -} - -inline void Client::set_tcp_nodelay(bool on) { cli_->set_tcp_nodelay(on); } - -inline void Client::set_socket_options(SocketOptions socket_options) { - cli_->set_socket_options(std::move(socket_options)); -} - -inline void Client::set_connection_timeout(time_t sec, time_t usec) { - cli_->set_connection_timeout(sec, usec); -} - -inline void Client::set_read_timeout(time_t sec, time_t usec) { - cli_->set_read_timeout(sec, usec); -} - -inline void Client::set_write_timeout(time_t sec, time_t usec) { - cli_->set_write_timeout(sec, usec); -} - -inline void Client::set_basic_auth(const std::string &username, - const std::string &password) { - cli_->set_basic_auth(username, password); -} -inline void Client::set_bearer_token_auth(const std::string &token) { - cli_->set_bearer_token_auth(token); -} -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -inline void Client::set_digest_auth(const std::string &username, - const std::string &password) { - cli_->set_digest_auth(username, password); -} -#endif - -inline void Client::set_keep_alive(bool on) { cli_->set_keep_alive(on); } -inline void Client::set_follow_location(bool on) { - cli_->set_follow_location(on); -} - -inline void Client::set_url_encode(bool on) { cli_->set_url_encode(on); } - -inline void Client::set_compress(bool on) { cli_->set_compress(on); } - -inline void Client::set_decompress(bool on) { cli_->set_decompress(on); } - -inline void Client::set_interface(const std::string &intf) { - cli_->set_interface(intf); -} - -inline void Client::set_proxy(const std::string &host, int port) { - cli_->set_proxy(host, port); -} -inline void Client::set_proxy_basic_auth(const std::string &username, - const std::string &password) { - cli_->set_proxy_basic_auth(username, password); -} -inline void Client::set_proxy_bearer_token_auth(const std::string &token) { - cli_->set_proxy_bearer_token_auth(token); -} -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -inline void Client::set_proxy_digest_auth(const std::string &username, - const std::string &password) { - cli_->set_proxy_digest_auth(username, password); -} -#endif - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -inline void Client::enable_server_certificate_verification(bool enabled) { - cli_->enable_server_certificate_verification(enabled); -} - -inline void Client::enable_server_hostname_verification(bool enabled) { - cli_->enable_server_hostname_verification(enabled); -} - -inline void Client::set_server_certificate_verifier( - std::function verifier) { - cli_->set_server_certificate_verifier(verifier); -} -#endif - -inline void Client::set_logger(Logger logger) { - cli_->set_logger(std::move(logger)); -} - -#ifdef CPPHTTPLIB_OPENSSL_SUPPORT -inline void Client::set_ca_cert_path(const std::string &ca_cert_file_path, - const std::string &ca_cert_dir_path) { - cli_->set_ca_cert_path(ca_cert_file_path, ca_cert_dir_path); -} - -inline void Client::set_ca_cert_store(X509_STORE *ca_cert_store) { - if (is_ssl_) { - static_cast(*cli_).set_ca_cert_store(ca_cert_store); - } else { - cli_->set_ca_cert_store(ca_cert_store); - } -} - -inline void Client::load_ca_cert_store(const char *ca_cert, std::size_t size) { - set_ca_cert_store(cli_->create_ca_cert_store(ca_cert, size)); -} - -inline long Client::get_openssl_verify_result() const { - if (is_ssl_) { - return static_cast(*cli_).get_openssl_verify_result(); - } - return -1; // NOTE: -1 doesn't match any of X509_V_ERR_??? -} - -inline SSL_CTX *Client::ssl_context() const { - if (is_ssl_) { - return static_cast(*cli_).ssl_context(); - } - return nullptr; -} -#endif - -// ---------------------------------------------------------------------------- - -} // namespace httplib - -#if defined(_WIN32) && defined(CPPHTTPLIB_USE_POLL) -#undef poll -#endif - -#endif // CPPHTTPLIB_HTTPLIB_H diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h index 26cc2aae..ff3bcbc8 100644 --- a/include/miniocpp/rdma.h +++ b/include/miniocpp/rdma.h @@ -40,9 +40,10 @@ #include "credentials.h" #include "error.h" +#include "http.h" #include "nvidia-cufile.h" #include "nvidia-cuobjclient.h" -#include "rdma-httplib.h" +#include "request.h" #include "signer.h" #include "utils.h" @@ -66,14 +67,20 @@ inline constexpr int kRDMAReplyNotImplemented = 501; // Return codes for rdmaPut/rdmaGet inline constexpr ssize_t kRDMANotSupported = -2; +// RDMA control-plane timeouts (seconds). The HTTP exchange carries only +// the token and a few headers — keep them aggressive so a dead NIC surfaces +// fast and the retry path can pick up the failover NIC. +inline constexpr long kRDMAConnectTimeoutSecs = 5; +inline constexpr long kRDMATimeoutSecs = 10; + // Extract the client NIC IP from the 81-char RDMA token. libcuobjclient // 1.2.0+ encodes the source NIC's GID in the last 32 hex chars of the // descriptor as an IPv4-mapped IPv6 suffix ("...ffffAABBCCDD"). Binding -// the outbound HTTP socket to that address (via CURLOPT_INTERFACE / -// httplib::set_interface) keeps the TCP session and the RDMA peer on -// the same NIC, so the server's RDMA_READ back to the client hits the -// same HCA that delivered the HTTP request. Returns empty string if the -// token doesn't follow the expected layout (older client, non-multipath). +// the outbound HTTP socket to that address (via CURLOPT_INTERFACE) keeps +// the TCP session and the RDMA peer on the same NIC, so the server's +// RDMA_READ back to the client hits the same HCA that delivered the HTTP +// request. Returns empty string if the token doesn't follow the expected +// layout (older client, non-multipath). inline static std::string parseClientNICFromToken(const char* token) { if (token == nullptr) return {}; size_t n = strlen(token); @@ -98,6 +105,22 @@ inline static std::string parseClientNICFromToken(const char* token) { // backup NIC when rdma_multipath_enabled=true and a healthy backup exists. inline constexpr int kRDMAMaxAttempts = 2; +// parseRDMAReply maps the server's x-amz-rdma-reply header to a transfer +// outcome. Returns: +// >0 reply code (200/204/206) — caller should treat as success +// 0 reply absent or unparseable — caller should treat as -1 failure +// -2 reply explicitly says 501 (server declined RDMA, fall back to HTTP) +inline static int parseRDMAReply(const std::string& rdma_reply) { + if (rdma_reply.empty() || rdma_reply == "501") { + return static_cast(kRDMANotSupported); + } + try { + return std::stoi(rdma_reply); + } catch (const std::exception&) { + return 0; + } +} + inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, const void* buf, size_t size) { char rdma_token[256]; @@ -146,61 +169,43 @@ inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, sign_headers, query_params, creds.access_key, creds.secret_key, kUnsignedPayload, date); - httplib::Headers headers; - std::list keys = sign_headers.Keys(); - for (const auto& key : keys) { - std::list values = sign_headers.Get(key); - for (const auto& value : values) { - headers.emplace(key, value); - } - } + url.query_string = query_params.ToQueryString(); - std::string path = url.path; - std::string query_string = query_params.ToQueryString(); - std::string full_path = - query_string.empty() ? path : path + "?" + query_string; + minio::http::Request req(minio::http::Method::kPut, url); + req.headers = sign_headers; + req.connect_timeout_secs = kRDMAConnectTimeoutSecs; + req.timeout_secs = kRDMATimeoutSecs; - url.path = ""; - url.query_string = ""; - httplib::Client cli(url.String()); - cli.set_connection_timeout(5); - cli.set_read_timeout(10); // Pin the TCP source address to the same NIC whose GID is embedded in // the RDMA token. Without this, multipath can pick a backup NIC for // the token while the kernel sends HTTP out the primary NIC, and the // server's RDMA_READ has no healthy path back to the token's peer. std::string client_nic = parseClientNICFromToken(token); if (!client_nic.empty()) { - cli.set_interface(client_nic); + req.nic_interface = client_nic; } - auto res = cli.Put(full_path, headers, "", ""); - if (res.error() != httplib::Error::Success) { + minio::http::Response res = req.Execute(); + if (!res.error.empty()) { return -1; } - std::string etag = res->get_header_value("ETag"); - if (res->status == 200 && !etag.empty()) { + std::string etag = res.headers.GetFront("etag"); + if (res.status_code == 200 && !etag.empty()) { sctx->etag = minio::utils::Trim(etag, '"'); return static_cast(size); } - std::string rdma_reply = res->get_header_value(kAmzRDMAReply); - if (rdma_reply.empty() || rdma_reply == "501") { + int reply_code = parseRDMAReply(res.headers.GetFront(kAmzRDMAReply)); + if (reply_code == static_cast(kRDMANotSupported)) { return kRDMANotSupported; } - - try { - int reply_code = std::stoi(rdma_reply); - if (reply_code != kRDMAReplySuccess && reply_code != kRDMAReplyNoContent) { - return -1; - } - } catch (const std::exception&) { + if (reply_code != kRDMAReplySuccess && reply_code != kRDMAReplyNoContent) { return -1; } std::string resp_checksum = - res->get_header_value("x-amz-checksum-crc64nvme"); + res.headers.GetFront("x-amz-checksum-crc64nvme"); if (!resp_checksum.empty()) { sctx->checksum = resp_checksum; } @@ -243,47 +248,47 @@ inline static ssize_t rdmaGet(s3_rdma_client_ctx_t* sctx, const char* token, sign_headers, query_params, creds.access_key, creds.secret_key, kUnsignedPayload, date); - httplib::Headers headers; - std::list hdr_keys = sign_headers.Keys(); - for (const auto& key : hdr_keys) { - std::list values = sign_headers.Get(key); - for (const auto& value : values) { - headers.emplace(key, value); - } - } + minio::http::Request req(minio::http::Method::kGet, url); + req.headers = sign_headers; + req.connect_timeout_secs = kRDMAConnectTimeoutSecs; + req.timeout_secs = kRDMATimeoutSecs; - std::string path = url.path; - url.path = ""; - url.query_string = ""; - httplib::Client cli(url.String()); - cli.set_connection_timeout(5); - cli.set_read_timeout(10); // Pin TCP source to the token's NIC — see rdmaPut above for rationale. std::string client_nic = parseClientNICFromToken(token); if (!client_nic.empty()) { - cli.set_interface(client_nic); + req.nic_interface = client_nic; } - auto res = cli.Get(path, headers); - if (res.error() != httplib::Error::Success) { + minio::http::Response res = req.Execute(); + if (!res.error.empty()) { return -1; } - std::string rdma_reply = res->get_header_value(kAmzRDMAReply); - if (rdma_reply.empty() || rdma_reply == "501") { + int reply_code = parseRDMAReply(res.headers.GetFront(kAmzRDMAReply)); + if (reply_code == static_cast(kRDMANotSupported)) { return kRDMANotSupported; } + if (reply_code != kRDMAReplySuccess && + reply_code != kRDMAReplyPartialContent) { + return -1; + } - try { - int reply_code = std::stoi(rdma_reply); - if (reply_code != kRDMAReplySuccess && - reply_code != kRDMAReplyPartialContent) { + // Trust the server's reported transferred byte count. The protocol uses + // Content-Length: 0 on the HTTP body (the data went over RDMA), and the + // actual transferred size is communicated via x-amz-rdma-bytes-transferred. + // For ranged/partial GETs this can be less than the caller-requested size. + std::string bytes_hdr = res.headers.GetFront(kAmzRDMABytesTransferred); + if (!bytes_hdr.empty()) { + try { + long long n = std::stoll(bytes_hdr); + if (n < 0) return -1; + return static_cast(n); + } catch (const std::exception&) { return -1; } - } catch (const std::exception&) { - return -1; } + // Header absent (older server). Assume full transfer for backward compat. return static_cast(size); } diff --git a/src/http.cc b/src/http.cc index 8af3dfaf..3fe419e9 100644 --- a/src/http.cc +++ b/src/http.cc @@ -364,6 +364,16 @@ Response Request::execute() { } } + if (!nic_interface.empty()) { + request.setOpt(new curlpp::Options::Interface(nic_interface)); + } + if (connect_timeout_secs > 0) { + request.setOpt(new curlpp::Options::ConnectTimeout(connect_timeout_secs)); + } + if (timeout_secs > 0) { + request.setOpt(new curlpp::Options::Timeout(timeout_secs)); + } + utils::CharBuffer charbuf((char*)body.data(), body.size()); std::istream body_stream(&charbuf); From 30a1bb913e2a6c26e4e5fe4d8460eb6d0c3dbc8c Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 21 May 2026 16:00:44 -0700 Subject: [PATCH 18/25] cmake: gate RDMA / GPU Direct Storage behind MINIO_CPP_ENABLE_RDMA=OFF The default build no longer requires libcufile, libcuobjclient, libibverbs, or librdmacm on the host. Consumers who want the RDMA / GPU Direct Storage API surface opt in with: cmake -DMINIO_CPP_ENABLE_RDMA=ON When OFF (default): * The vendored NVIDIA include path and link line are skipped. * GetObjectRDMAArgs / PutObjectRDMAArgs and the Client::GetObject(GetObjectRDMAArgs) / Client::PutObject(PutObjectRDMAArgs) overloads are not declared. * The rdmaclient field on PutObjectArgs / PutObjectApiArgs / UploadPartArgs is omitted from the struct layout. * RDMA-only headers (nvidia-cufile.h, nvidia-cuobjclient.h, rdma.h) are not installed. * The GetPutRDMA and GPUHostDisk examples are not built. When ON, target_compile_definitions(miniocpp PUBLIC MINIO_CPP_RDMA) makes the macro available to downstream consumers so they pick up the matching API surface from the installed headers. Verified clean separation on Linux: with RDMA off the resulting libminiocpp.so has no NDR/cuFile/cuObj/ibverbs deps; with RDMA on it links libcufile, libcuobjclient, libibverbs, librdmacm. --- CMakeLists.txt | 36 ++++++++++++++++++++++++++++------- include/miniocpp/args.h | 12 ++++++++++++ include/miniocpp/baseclient.h | 3 ++- include/miniocpp/client.h | 4 ++++ src/args.cc | 2 ++ src/baseclient.cc | 7 ++++++- src/client.cc | 13 +++++++++++-- 7 files changed, 66 insertions(+), 11 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 2d05240e..f04b1462 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -39,6 +39,12 @@ include("${VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake") option(MINIO_CPP_TEST "Build tests" OFF) option(MINIO_CPP_MAKE_DOC "Build documentation" OFF) +# RDMA / GPU Direct Storage support. OFF by default so consumers without +# NVIDIA cuFile + cuObj + ibverbs + rdmacm do not need those libraries on +# the host. When ON, links against the vendored NVIDIA blobs in +# vendor/cuobj/ and defines MINIO_CPP_RDMA so headers expose the +# GetObjectRDMAArgs / PutObjectRDMAArgs API surface. +option(MINIO_CPP_ENABLE_RDMA "Enable RDMA and GPU Direct Storage support" OFF) set(MINIO_CPP_CFLAGS) set(MINIO_CPP_INCLUDES) @@ -50,13 +56,19 @@ if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC" OR "x${CMAKE_CXX_COMPILER_FRONTEN else() # GCC/Clang/AppleClang/... list(APPEND MINIO_CPP_CFLAGS -Wall -Wextra -Wconversion) - list(APPEND MINIO_CPP_INCLUDES ${CMAKE_SOURCE_DIR}/vendor/cuobj/include) - list(APPEND MINIO_CPP_LIBS "-Bdynamic -L${CMAKE_SOURCE_DIR}/vendor/cuobj/lib -lcufile -lpthread -lnuma -ldl -libverbs -lrdmacm -lrt -lcuobjclient") if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0 AND CMAKE_CXX_COMPILER_VERSION VERSION_LESS 9.0 AND NOT MINGW) list(APPEND MINIO_CPP_LIBS stdc++fs) endif() endif() +if (MINIO_CPP_ENABLE_RDMA) + if (WIN32 OR APPLE) + message(FATAL_ERROR "MINIO_CPP_ENABLE_RDMA is only supported on Linux") + endif() + list(APPEND MINIO_CPP_INCLUDES ${CMAKE_SOURCE_DIR}/vendor/cuobj/include) + list(APPEND MINIO_CPP_LIBS "-Bdynamic -L${CMAKE_SOURCE_DIR}/vendor/cuobj/lib -lcufile -lpthread -lnuma -ldl -libverbs -lrdmacm -lrt -lcuobjclient") +endif() + # Dependencies # ------------ @@ -109,10 +121,7 @@ set(MINIO_CPP_HEADERS include/miniocpp/credentials.h include/miniocpp/error.h include/miniocpp/http.h - include/miniocpp/nvidia-cufile.h - include/miniocpp/nvidia-cuobjclient.h include/miniocpp/providers.h - include/miniocpp/rdma.h include/miniocpp/request.h include/miniocpp/response.h include/miniocpp/select.h @@ -122,6 +131,14 @@ set(MINIO_CPP_HEADERS include/miniocpp/utils.h ) +if (MINIO_CPP_ENABLE_RDMA) + list(APPEND MINIO_CPP_HEADERS + include/miniocpp/nvidia-cufile.h + include/miniocpp/nvidia-cuobjclient.h + include/miniocpp/rdma.h + ) +endif() + option(BUILD_SHARED_LIBS "Build using shared libraries" OFF) IF (BUILD_SHARED_LIBS) @@ -142,6 +159,9 @@ target_include_directories(miniocpp PUBLIC $ ) target_link_libraries(miniocpp PUBLIC ${MINIO_CPP_LIBS}) +if (MINIO_CPP_ENABLE_RDMA) + target_compile_definitions(miniocpp PUBLIC MINIO_CPP_RDMA) +endif() set_target_properties(miniocpp PROPERTIES VERSION "${MINIO_CPP_VERSION_STRING}") set_target_properties(miniocpp PROPERTIES POSITION_INDEPENDENT_CODE ON) @@ -164,8 +184,6 @@ if (MINIO_CPP_TEST) GetObject ListObjects PutObject - GetPutRDMA - GPUHostDisk CopyObject ComposeObject RemoveObjects @@ -208,6 +226,10 @@ if (MINIO_CPP_TEST) GetObjectProgress ) + if (MINIO_CPP_ENABLE_RDMA) + list(APPEND EXAMPLE_APPS GetPutRDMA GPUHostDisk) + endif() + foreach(target ${EXAMPLE_APPS}) add_executable(${target} examples/${target}.cc) target_compile_features(${target} PUBLIC cxx_std_${MINIO_CPP_STD}) diff --git a/include/miniocpp/args.h b/include/miniocpp/args.h index aafa03d4..3d854be0 100644 --- a/include/miniocpp/args.h +++ b/include/miniocpp/args.h @@ -27,7 +27,9 @@ #include "error.h" #include "http.h" +#ifdef MINIO_CPP_RDMA #include "nvidia-cuobjclient.h" +#endif #include "sse.h" #include "types.h" #include "utils.h" @@ -162,7 +164,9 @@ struct PutObjectApiArgs : public PutObjectBaseArgs { utils::Multimap query_params; http::ProgressFunction progressfunc = nullptr; void* progress_userdata = nullptr; +#ifdef MINIO_CPP_RDMA cuObjClient* rdmaclient = nullptr; +#endif std::string checksum_crc64nvme; // CRC64NVME checksum for multipart uploads PutObjectApiArgs() = default; @@ -177,7 +181,9 @@ struct UploadPartArgs : public ObjectWriteArgs { std::string_view data; http::ProgressFunction progressfunc = nullptr; void* progress_userdata = nullptr; +#ifdef MINIO_CPP_RDMA cuObjClient* rdmaclient = nullptr; +#endif std::string checksum_crc64nvme; // CRC64NVME checksum for multipart uploads UploadPartArgs() = default; @@ -225,6 +231,7 @@ struct GetObjectArgs : public ObjectConditionalReadArgs { error::Error Validate() const; }; // struct GetObjectArgs +#ifdef MINIO_CPP_RDMA struct GetObjectRDMAArgs : public GetObjectArgs { char* buf = nullptr; std::optional size; @@ -234,6 +241,7 @@ struct GetObjectRDMAArgs : public GetObjectArgs { error::Error Validate() const; }; // struct GetObjectRDMAArgs +#endif struct ListObjectsArgs : public BucketArgs { std::string delimiter; @@ -336,7 +344,9 @@ struct PutObjectArgs : public PutObjectBaseArgs { std::istream& stream; http::ProgressFunction progressfunc = nullptr; void* progress_userdata = nullptr; +#ifdef MINIO_CPP_RDMA cuObjClient* rdmaclient = nullptr; +#endif std::string checksum_crc64nvme; // CRC64NVME checksum for multipart uploads PutObjectArgs(std::istream& stream, long object_size, long part_size); @@ -345,6 +355,7 @@ struct PutObjectArgs : public PutObjectBaseArgs { error::Error Validate(); }; // struct PutObjectArgs +#ifdef MINIO_CPP_RDMA struct PutObjectRDMAArgs : public PutObjectBaseArgs { char* buf = nullptr; std::optional size; @@ -354,6 +365,7 @@ struct PutObjectRDMAArgs : public PutObjectBaseArgs { error::Error Validate() const; }; // struct PutObjectRDMAArgs +#endif using CopySource = ObjectConditionalReadArgs; diff --git a/include/miniocpp/baseclient.h b/include/miniocpp/baseclient.h index 468847e4..caf91bcf 100644 --- a/include/miniocpp/baseclient.h +++ b/include/miniocpp/baseclient.h @@ -31,9 +31,10 @@ #include "response.h" #include "utils.h" -// RDMA specific includes +#ifdef MINIO_CPP_RDMA #include "nvidia-cuobjclient.h" #include "rdma.h" +#endif #if defined(_WIN32) && defined(GetObject) #pragma push_macro("GetObject") diff --git a/include/miniocpp/client.h b/include/miniocpp/client.h index e9cfce97..60c55f1d 100644 --- a/include/miniocpp/client.h +++ b/include/miniocpp/client.h @@ -111,6 +111,7 @@ class Client : public BaseClient { PutObjectResponse PutObject(PutObjectArgs args, std::string& upload_id, char* buf); +#ifdef MINIO_CPP_RDMA // Process-wide RDMA client, one instance for the whole process, lazily // initialised on first use via std::call_once. Reasons this has to be // process-wide rather than per-Client instance: @@ -123,6 +124,7 @@ class Client : public BaseClient { // under concurrency and silently skip RDMA in favour of HTTP. // See SharedRDMAClient() in client.cc for the definition. static cuObjClient& SharedRDMAClient(); +#endif public: explicit Client(BaseUrl& base_url, creds::Provider* const provider = nullptr); @@ -134,8 +136,10 @@ class Client : public BaseClient { ListObjectsResult ListObjects(ListObjectsArgs args); PutObjectResponse PutObject(PutObjectArgs args); GetObjectResponse GetObject(GetObjectArgs args); +#ifdef MINIO_CPP_RDMA GetObjectResponse GetObject(GetObjectRDMAArgs args); PutObjectResponse PutObject(PutObjectRDMAArgs args); +#endif UploadObjectResponse UploadObject(UploadObjectArgs args); RemoveObjectsResult RemoveObjects(RemoveObjectsArgs args); }; // class Client diff --git a/src/args.cc b/src/args.cc index 3cbeb971..4ff46404 100644 --- a/src/args.cc +++ b/src/args.cc @@ -224,6 +224,7 @@ error::Error DownloadObjectArgs::Validate() const { return error::SUCCESS; } +#ifdef MINIO_CPP_RDMA error::Error GetObjectRDMAArgs::Validate() const { // Validate bucket+object via the ObjectArgs chain so an empty bucket // is rejected here with "bucket name cannot be empty" instead of slipping @@ -258,6 +259,7 @@ error::Error PutObjectRDMAArgs::Validate() const { return error::SUCCESS; } +#endif error::Error GetObjectArgs::Validate() const { if (error::Error err = ObjectConditionalReadArgs::Validate()) { diff --git a/src/baseclient.cc b/src/baseclient.cc index 5d656c6e..45f3b6f3 100644 --- a/src/baseclient.cc +++ b/src/baseclient.cc @@ -43,9 +43,10 @@ #include "miniocpp/types.h" #include "miniocpp/utils.h" -// RDMA specific includes +#ifdef MINIO_CPP_RDMA #include "miniocpp/nvidia-cuobjclient.h" #include "miniocpp/rdma.h" +#endif // We want exactly `minio::s3::BaseClient::GetObject()` symbol and nothing else. #if defined(GetObject) @@ -1371,6 +1372,7 @@ PutObjectResponse BaseClient::PutObject(PutObjectApiArgs args) { return PutObjectResponse(resp); } +#ifdef MINIO_CPP_RDMA if (args.rdmaclient != nullptr && args.rdmaclient->isConnected()) { s3_rdma_client_ctx putCtx = { .provider = provider_, @@ -1392,6 +1394,7 @@ PutObjectResponse BaseClient::PutObject(PutObjectApiArgs args) { // ret < 0 (retries exhausted) or kRDMANotSupported (server declined): // fall through to HTTP path. } +#endif Request req(http::Method::kPut, region, base_url_, args.extra_headers, args.extra_query_params); @@ -1944,6 +1947,7 @@ UploadPartResponse BaseClient::UploadPart(UploadPartArgs args) { return UploadPartResponse(err); } +#ifdef MINIO_CPP_RDMA if (args.rdmaclient != nullptr && args.rdmaclient->isConnected()) { std::string region; if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { @@ -1975,6 +1979,7 @@ UploadPartResponse BaseClient::UploadPart(UploadPartArgs args) { // ret < 0 (retries exhausted) or kRDMANotSupported (server declined): // fall through to HTTP upload part path. } +#endif utils::Multimap query_params; query_params.Add("partNumber", std::to_string(args.part_number)); diff --git a/src/client.cc b/src/client.cc index 965b2262..5d3f9cdb 100644 --- a/src/client.cc +++ b/src/client.cc @@ -39,9 +39,10 @@ #include "miniocpp/types.h" #include "miniocpp/utils.h" -// RDMA specific includes +#ifdef MINIO_CPP_RDMA #include "miniocpp/nvidia-cuobjclient.h" #include "miniocpp/rdma.h" +#endif namespace minio::s3 { @@ -150,6 +151,7 @@ void RemoveObjectsResult::Populate() { } } +#ifdef MINIO_CPP_RDMA // Meyers singleton — thread-safe per C++11 [stmt.dcl]/4 ("If control // enters the declaration concurrently while the variable is being // initialized, the concurrent execution shall wait for completion of the @@ -162,6 +164,7 @@ cuObjClient& Client::SharedRDMAClient() { static cuObjClient client{ops, CUOBJ_PROTO_RDMA_DC_V1}; return client; } +#endif Client::Client(BaseUrl& base_url, creds::Provider* const provider) : BaseClient(base_url, provider) {} @@ -388,6 +391,7 @@ GetObjectResponse Client::GetObject(GetObjectArgs args) { return BaseClient::GetObject(args); } +#ifdef MINIO_CPP_RDMA GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { if (error::Error err = args.Validate()) { return GetObjectResponse(err); @@ -507,6 +511,7 @@ PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { return PutObject(aargs); } +#endif // MINIO_CPP_RDMA PutObjectResponse Client::PutObject(PutObjectArgs args, std::string& upload_id, char* buf) { @@ -906,6 +911,7 @@ PutObjectResponse Client::PutObject(PutObjectArgs args) { "unable to allocate system memory with alignment"); } +#ifdef MINIO_CPP_RDMA // Reuse the process-wide SharedRDMAClient() rather than constructing // per-call; see client.h for the race rationale. `buf` here is the // multipart part buffer, registered once for the whole multipart @@ -918,9 +924,10 @@ PutObjectResponse Client::PutObject(PutObjectArgs args) { return error::make("unable to register RDMA buffer"); } } + args.rdmaclient = &rdma_client; +#endif std::string upload_id; - args.rdmaclient = &rdma_client; PutObjectResponse resp = PutObject(args, upload_id, buf); if (!resp && !upload_id.empty()) { @@ -932,6 +939,7 @@ PutObjectResponse Client::PutObject(PutObjectArgs args) { AbortMultipartUpload(amu_args); } +#ifdef MINIO_CPP_RDMA if (rdma_client.isConnected()) { res = rdma_client.cuMemObjPutDescriptor(buf); if (res) { @@ -939,6 +947,7 @@ PutObjectResponse Client::PutObject(PutObjectArgs args) { return error::make("unable to deregister RDMA buffer"); } } +#endif free(buf); return resp; From e08cae081720315e932aad7a53f672f0a5894d1d Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 21 May 2026 16:05:59 -0700 Subject: [PATCH 19/25] vendor: document NVIDIA cuFile / cuObj license terms MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Adds vendor/cuobj/NOTICE explaining that the vendored cuda.h header, the cuFile and cuObj shared libraries, and the public-facing API headers (nvidia-cufile.h, nvidia-cuobjclient.h) all originate from NVIDIA Corporation and remain subject to NVIDIA's software license agreements — they are not covered by the minio-cpp Apache 2.0 grant. README.md now points to that NOTICE and clarifies that the default build omits the entire RDMA stack, so consumers who do not opt into GPUDirect Storage / RDMA can safely ignore the NVIDIA terms. --- README.md | 22 +++++++++++++++ vendor/cuobj/NOTICE | 69 +++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 91 insertions(+) create mode 100644 vendor/cuobj/NOTICE diff --git a/README.md b/README.md index 2a37312d..c270c230 100644 --- a/README.md +++ b/README.md @@ -163,6 +163,28 @@ int main(int argc, char* argv[]) { } ``` +## RDMA / GPU Direct Storage (optional) + +This SDK has optional support for RDMA-direct S3 PUT/GET against MinIO +servers, including GPUDirect Storage (cuFile) for transfers directly to +and from CUDA device buffers. Build with: + +``` +cmake -DMINIO_CPP_ENABLE_RDMA=ON ... +``` + +This requires NVIDIA cuFile, cuObj client/server, libibverbs, and +librdmacm. Pre-built NVIDIA binaries are vendored under `vendor/cuobj/` +for convenience; see `vendor/cuobj/NOTICE` for the applicable NVIDIA +license terms. The default build (`MINIO_CPP_ENABLE_RDMA=OFF`) omits +the entire RDMA stack and has no dependency on any of those libraries. + ## License This SDK is distributed under the [Apache License, Version 2.0](https://www.apache.org/licenses/LICENSE-2.0), see [LICENSE](https://github.com/minio/minio-cpp/blob/master/LICENSE) for more information. + +The artifacts under `vendor/cuobj/` and the NVIDIA-derived headers +(`include/miniocpp/cuda.h`, `nvidia-cufile.h`, `nvidia-cuobjclient.h`) +are NOT covered by this Apache 2.0 grant — they originate from NVIDIA +Corporation and are subject to NVIDIA's software license agreements. +See [`vendor/cuobj/NOTICE`](vendor/cuobj/NOTICE) for details. diff --git a/vendor/cuobj/NOTICE b/vendor/cuobj/NOTICE new file mode 100644 index 00000000..b4493995 --- /dev/null +++ b/vendor/cuobj/NOTICE @@ -0,0 +1,69 @@ +NVIDIA cuFile and cuObj Redistribution Notice +============================================= + +The artifacts under this directory (vendor/cuobj/) are NOT covered by the +minio-cpp Apache License 2.0. They originate from NVIDIA Corporation and +are redistributed under NVIDIA's software license agreements. + + +What is vendored +---------------- + + vendor/cuobj/include/cuda.h + The CUDA driver API header (cuda.h). Required for type declarations + (CUdeviceptr, CUstream, etc.) that appear in cuFile / cuObj API + signatures. minio-cpp itself does not call any CUDA driver or + runtime symbol. + + vendor/cuobj/lib/libcufile.so.1.18.0 (and SONAME aliases) + vendor/cuobj/lib/libcufile_rdma.so.1.18.0 (and SONAME aliases) + NVIDIA cuFile (GPUDirect Storage) shared libraries, version 1.18.0. + Provides the cuFile* API used by libcuobjclient for RDMA transfers. + + vendor/cuobj/lib/libcuobjclient.so.1.2.0 (and SONAME aliases) + vendor/cuobj/lib/libcuobjserver.so.1.2.0 (and SONAME aliases) + NVIDIA cuObj client / server libraries, "resiliency_v3" (1.2.0). + Provides the cuObjClient C++ class used by minio-cpp to mint and + release RDMA tokens for the S3 RDMA protocol. + +The corresponding public-facing API headers +include/miniocpp/nvidia-cufile.h, include/miniocpp/nvidia-cuobjclient.h +are reproductions of NVIDIA's API surface and are also subject to the +upstream NVIDIA agreements below. + + +Applicable NVIDIA agreements +---------------------------- + +* NVIDIA Software License Agreement (cuda.h, CUDA driver headers): + https://docs.nvidia.com/cuda/eula/index.html + +* NVIDIA cuFile (GPUDirect Storage) SDK License: + https://docs.nvidia.com/gpudirect-storage/api-reference-guide/ + +* NVIDIA cuObjClient redistribution terms apply to the libcuobjclient / + libcuobjserver shared objects. Refer to the cuObj SDK distribution + channel from which these binaries were obtained. + +Each header retains its original NVIDIA copyright notice; see the top of +include/miniocpp/cuda.h for the verbatim statement that ships with +cuda.h. + + +Scope of this notice +-------------------- + +This NOTICE applies ONLY to files under vendor/cuobj/ and to the +NVIDIA-derived headers include/miniocpp/cuda.h, nvidia-cufile.h, and +nvidia-cuobjclient.h. The rest of minio-cpp is licensed under the +Apache License 2.0 — see the top-level LICENSE file. + +The minio-cpp project does not grant any license to the NVIDIA artifacts +above. Use of those artifacts is subject directly to the upstream NVIDIA +agreements; if you redistribute minio-cpp builds that include them, you +are responsible for complying with those terms. + +Building minio-cpp with -DMINIO_CPP_ENABLE_RDMA=OFF (the default) omits +the entire vendor/cuobj/ tree and the NVIDIA-derived headers from the +build, so consumers who do not need GPUDirect Storage / RDMA can ignore +this notice entirely. From 3c9b69471a59fdbff74e39b30a645200f15f6582 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 21 May 2026 16:31:50 -0700 Subject: [PATCH 20/25] vendor: bundle CUDA Toolkit EULA, reference Attachment A redistributables MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Ships the verbatim NVIDIA CUDA Toolkit End User License Agreement as vendor/cuobj/EULA.txt and rewrites the NOTICE to reference it directly, including the §2.6 Attachment A entry that explicitly enumerates the cuFile component (cufile.h, libcufile.so, libcufile_rdma.so) as redistributable. The same EULA covers the broader set of NVIDIA-derived headers and shared libraries vendored under vendor/cuobj/ and reproduced under include/miniocpp/ (cuda.h, nvidia-cufile.h, nvidia-cuobjclient.h). --- vendor/cuobj/EULA.txt | 1712 +++++++++++++++++++++++++++++++++++++++++ vendor/cuobj/NOTICE | 75 +- 2 files changed, 1746 insertions(+), 41 deletions(-) create mode 100644 vendor/cuobj/EULA.txt diff --git a/vendor/cuobj/EULA.txt b/vendor/cuobj/EULA.txt new file mode 100644 index 00000000..358fffa8 --- /dev/null +++ b/vendor/cuobj/EULA.txt @@ -0,0 +1,1712 @@ +End User License Agreement +-------------------------- + +NVIDIA Software License Agreement and CUDA Supplement to +Software License Agreement. + +The CUDA Toolkit End User License Agreement applies to the +NVIDIA CUDA Toolkit, the NVIDIA CUDA Samples, the NVIDIA +Display Driver, NVIDIA Nsight tools (Visual Studio Edition), +and the associated documentation on CUDA APIs, programming +model and development tools. If you do not agree with the +terms and conditions of the license agreement, then do not +download or use the software. + +Last updated: January 12, 2025 + + +Preface +------- + +The Software License Agreement in Chapter 1 and the Supplement +in Chapter 2 contain license terms and conditions that govern +the use of NVIDIA toolkit. By accepting this agreement, you +agree to comply with all the terms and conditions applicable +to the product(s) included herein. + + +NVIDIA Driver + + +Description + +This package contains the operating system driver and +fundamental system software components for NVIDIA GPUs. + + +NVIDIA CUDA Toolkit + + +Description + +The NVIDIA CUDA Toolkit provides command-line and graphical +tools for building, debugging and optimizing the performance +of applications accelerated by NVIDIA GPUs, runtime and math +libraries, and documentation including programming guides, +user manuals, and API references. + + +Default Install Location of CUDA Toolkit + +Windows platform: + +%ProgramFiles%\NVIDIA GPU Computing Toolkit\CUDA\v#.# + +Linux platform: + +/usr/local/cuda-#.# + +Mac platform: + +/Developer/NVIDIA/CUDA-#.# + + +NVIDIA CUDA Samples + + +Description + +CUDA Samples are now located in +https://github.com/nvidia/cuda-samples, which includes +instructions for obtaining, building, and running the samples. +They are no longer included in the CUDA toolkit. + + +NVIDIA Nsight Visual Studio Edition (Windows only) + + +Description + +NVIDIA Nsight Development Platform, Visual Studio Edition is a +development environment integrated into Microsoft Visual +Studio that provides tools for debugging, profiling, analyzing +and optimizing your GPU computing and graphics applications. + + +Default Install Location of Nsight Visual Studio Edition + +Windows platform: + +%ProgramFiles(x86)%\NVIDIA Corporation\Nsight Visual Studio Edition #.# + + +1. License Agreement for NVIDIA Software Development Kits +--------------------------------------------------------- + + +Important Notice—Read before downloading, installing, +copying or using the licensed software: +------------------------------------------------------- + +This license agreement, including exhibits attached +("Agreement”) is a legal agreement between you and NVIDIA +Corporation ("NVIDIA") and governs your use of a NVIDIA +software development kit (“SDK”). + +Each SDK has its own set of software and materials, but here +is a description of the types of items that may be included in +a SDK: source code, header files, APIs, data sets and assets +(examples include images, textures, models, scenes, videos, +native API input/output files), binary software, sample code, +libraries, utility programs, programming code and +documentation. + +This Agreement can be accepted only by an adult of legal age +of majority in the country in which the SDK is used. + +If you are entering into this Agreement on behalf of a company +or other legal entity, you represent that you have the legal +authority to bind the entity to this Agreement, in which case +“you” will mean the entity you represent. + +If you don’t have the required age or authority to accept +this Agreement, or if you don’t accept all the terms and +conditions of this Agreement, do not download, install or use +the SDK. + +You agree to use the SDK only for purposes that are permitted +by (a) this Agreement, and (b) any applicable law, regulation +or generally accepted practices or guidelines in the relevant +jurisdictions. + + +1.1. License + + +1.1.1. License Grant + +Subject to the terms of this Agreement, NVIDIA hereby grants +you a non-exclusive, non-transferable license, without the +right to sublicense (except as expressly provided in this +Agreement) to: + + 1. Install and use the SDK, + + 2. Modify and create derivative works of sample source code + delivered in the SDK, and + + 3. Distribute those portions of the SDK that are identified + in this Agreement as distributable, as incorporated in + object code format into a software application that meets + the distribution requirements indicated in this Agreement. + + +1.1.2. Distribution Requirements + +These are the distribution requirements for you to exercise +the distribution grant: + + 1. Your application must have material additional + functionality, beyond the included portions of the SDK. + + 2. The distributable portions of the SDK shall only be + accessed by your application. + + 3. The following notice shall be included in modifications + and derivative works of sample source code distributed: + “This software contains source code provided by NVIDIA + Corporation.” + + 4. Unless a developer tool is identified in this Agreement + as distributable, it is delivered for your internal use + only. + + 5. The terms under which you distribute your application + must be consistent with the terms of this Agreement, + including (without limitation) terms relating to the + license grant and license restrictions and protection of + NVIDIA’s intellectual property rights. Additionally, you + agree that you will protect the privacy, security and + legal rights of your application users. + + 6. You agree to notify NVIDIA in writing of any known or + suspected distribution or use of the SDK not in compliance + with the requirements of this Agreement, and to enforce + the terms of your agreements with respect to distributed + SDK. + + +1.1.3. Authorized Users + +You may allow employees and contractors of your entity or of +your subsidiary(ies) to access and use the SDK from your +secure network to perform work on your behalf. + +If you are an academic institution you may allow users +enrolled or employed by the academic institution to access and +use the SDK from your secure network. + +You are responsible for the compliance with the terms of this +Agreement by your authorized users. If you become aware that +your authorized users didn’t follow the terms of this +Agreement, you agree to take reasonable steps to resolve the +non-compliance and prevent new occurrences. + + +1.1.4. Pre-Release SDK + +The SDK versions identified as alpha, beta, preview or +otherwise as pre-release, may not be fully functional, may +contain errors or design flaws, and may have reduced or +different security, privacy, accessibility, availability, and +reliability standards relative to commercial versions of +NVIDIA software and materials. Use of a pre-release SDK may +result in unexpected results, loss of data, project delays or +other unpredictable damage or loss. + +You may use a pre-release SDK at your own risk, understanding +that pre-release SDKs are not intended for use in production +or business-critical systems. + +NVIDIA may choose not to make available a commercial version +of any pre-release SDK. NVIDIA may also choose to abandon +development and terminate the availability of a pre-release +SDK at any time without liability. + + +1.1.5. Updates + +NVIDIA may, at its option, make available patches, workarounds +or other updates to this SDK. Unless the updates are provided +with their separate governing terms, they are deemed part of +the SDK licensed to you as provided in this Agreement. You +agree that the form and content of the SDK that NVIDIA +provides may change without prior notice to you. While NVIDIA +generally maintains compatibility between versions, NVIDIA may +in some cases make changes that introduce incompatibilities in +future versions of the SDK. + + +1.1.6. Components Under Other Licenses + +The SDK may come bundled with, or otherwise include or be +distributed with, NVIDIA or third-party components with +separate legal notices or terms as may be described in +proprietary notices accompanying the SDK. If and to the extent +there is a conflict between the terms in this Agreement and +the license terms associated with the component, the license +terms associated with the components control only to the +extent necessary to resolve the conflict. + +Subject to the other terms of this Agreement, you may use the +SDK to develop and test applications released under Open +Source Initiative (OSI) approved open source software +licenses. + + +1.1.7. Reservation of Rights + +NVIDIA reserves all rights, title, and interest in and to the +SDK, not expressly granted to you under this Agreement. + + +1.2. Limitations + +The following license limitations apply to your use of the +SDK: + + 1. You may not reverse engineer, decompile or disassemble, + or remove copyright or other proprietary notices from any + portion of the SDK or copies of the SDK. + + 2. Except as expressly provided in this Agreement, you may + not copy, sell, rent, sublicense, transfer, distribute, + modify, or create derivative works of any portion of the + SDK. For clarity, you may not distribute or sublicense the + SDK as a stand-alone product. + + 3. Unless you have an agreement with NVIDIA for this + purpose, you may not indicate that an application created + with the SDK is sponsored or endorsed by NVIDIA. + + 4. You may not bypass, disable, or circumvent any + encryption, security, digital rights management or + authentication mechanism in the SDK. + + 5. You may not use the SDK in any manner that would cause it + to become subject to an open source software license. As + examples, licenses that require as a condition of use, + modification, and/or distribution that the SDK be: + + a. Disclosed or distributed in source code form; + + b. Licensed for the purpose of making derivative works; + or + + c. Redistributable at no charge. + + 6. You acknowledge that the SDK as delivered is not tested + or certified by NVIDIA for use in connection with the + design, construction, maintenance, and/or operation of any + system where the use or failure of such system could + result in a situation that threatens the safety of human + life or results in catastrophic damages (each, a "Critical + Application"). Examples of Critical Applications include + use in avionics, navigation, autonomous vehicle + applications, ai solutions for automotive products, + military, medical, life support or other life critical + applications. NVIDIA shall not be liable to you or any + third party, in whole or in part, for any claims or + damages arising from such uses. You are solely responsible + for ensuring that any product or service developed with + the SDK as a whole includes sufficient features to comply + with all applicable legal and regulatory standards and + requirements. + + 7. You agree to defend, indemnify and hold harmless NVIDIA + and its affiliates, and their respective employees, + contractors, agents, officers and directors, from and + against any and all claims, damages, obligations, losses, + liabilities, costs or debt, fines, restitutions and + expenses (including but not limited to attorney’s fees + and costs incident to establishing the right of + indemnification) arising out of or related to products or + services that use the SDK in or for Critical Applications, + and for use of the SDK outside of the scope of this + Agreement or not in compliance with its terms. + + 8. You may not reverse engineer, decompile or disassemble + any portion of the output generated using SDK elements for + the purpose of translating such output artifacts to target + a non-NVIDIA platform. + + +1.3. Ownership + + 1. NVIDIA or its licensors hold all rights, title and + interest in and to the SDK and its modifications and + derivative works, including their respective intellectual + property rights, subject to your rights under Section + 1.3.2. This SDK may include software and materials from + NVIDIA’s licensors, and these licensors are intended + third party beneficiaries that may enforce this Agreement + with respect to their intellectual property rights. + + 2. You hold all rights, title and interest in and to your + applications and your derivative works of the sample + source code delivered in the SDK, including their + respective intellectual property rights, subject to + NVIDIA’s rights under Section 1.3.1. + + 3. You may, but don’t have to, provide to NVIDIA + suggestions, feature requests or other feedback regarding + the SDK, including possible enhancements or modifications + to the SDK. For any feedback that you voluntarily provide, + you hereby grant NVIDIA and its affiliates a perpetual, + non-exclusive, worldwide, irrevocable license to use, + reproduce, modify, license, sublicense (through multiple + tiers of sublicensees), and distribute (through multiple + tiers of distributors) it without the payment of any + royalties or fees to you. NVIDIA will use feedback at its + choice. NVIDIA is constantly looking for ways to improve + its products, so you may send feedback to NVIDIA through + the developer portal at https://developer.nvidia.com. + + +1.4. No Warranties + +THE SDK IS PROVIDED BY NVIDIA “AS IS” AND “WITH ALL +FAULTS.” TO THE MAXIMUM EXTENT PERMITTED BY LAW, NVIDIA AND +ITS AFFILIATES EXPRESSLY DISCLAIM ALL WARRANTIES OF ANY KIND +OR NATURE, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, +BUT NOT LIMITED TO, ANY WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE, TITLE, NON-INFRINGEMENT, OR THE +ABSENCE OF ANY DEFECTS THEREIN, WHETHER LATENT OR PATENT. NO +WARRANTY IS MADE ON THE BASIS OF TRADE USAGE, COURSE OF +DEALING OR COURSE OF TRADE. + + +1.5. Limitation of Liability + +TO THE MAXIMUM EXTENT PERMITTED BY LAW, NVIDIA AND ITS +AFFILIATES SHALL NOT BE LIABLE FOR ANY (I) SPECIAL, INCIDENTAL, +PUNITIVE OR CONSEQUENTIAL DAMAGES, OR (II) DAMAGES FOR (A) ANY +LOST PROFITS, LOSS OF USE, LOSS OF DATA OR LOSS OF GOODWILL, +OR THE COSTS OF PROCURING SUBSTITUTE PRODUCTS, ARISING OUT OF +OR IN CONNECTION WITH THIS AGREEMENT OR THE USE OR PERFORMANCE +OF THE SDK, WHETHER SUCH LIABILITY ARISES FROM ANY CLAIM BASED +UPON BREACH OF CONTRACT, BREACH OF WARRANTY, TORT (INCLUDING +NEGLIGENCE), PRODUCT LIABILITY OR ANY OTHER CAUSE OF ACTION OR +THEORY OF LIABILITY. IN NO EVENT WILL NVIDIA’S AND ITS AFFILIATES +TOTAL CUMULATIVE LIABILITY UNDER OR ARISING OUT OF THIS +AGREEMENT EXCEED US$10.00. THE NATURE OF THE LIABILITY OR THE +NUMBER OF CLAIMS OR SUITS SHALL NOT ENLARGE OR EXTEND THIS +LIMIT. + +These exclusions and limitations of liability shall apply +regardless if NVIDIA or its affiliates have been advised of +the possibility of such damages, and regardless of whether a +remedy fails its essential purpose. These exclusions and +limitations of liability form an essential basis of the +bargain between the parties, and, absent any of these +exclusions or limitations of liability, the provisions of this +Agreement, including, without limitation, the economic terms, +would be substantially different. + + +1.6. Termination + + 1. This Agreement will continue to apply until terminated by + either you or NVIDIA as described below. + + 2. If you want to terminate this Agreement, you may do so by + stopping to use the SDK. + + 3. NVIDIA may, at any time, terminate this Agreement if: + + a. (i) you fail to comply with any term of this + Agreement and the non-compliance is not fixed within + thirty (30) days following notice from NVIDIA (or + immediately if you violate NVIDIA’s intellectual + property rights); + + b. (ii) you commence or participate in any legal + proceeding against NVIDIA with respect to the SDK; or + + c. (iii) NVIDIA decides to no longer provide the SDK in + a country or, in NVIDIA’s sole discretion, the + continued use of it is no longer commercially viable. + + 4. Upon any termination of this Agreement, you agree to + promptly discontinue use of the SDK and destroy all copies + in your possession or control. Your prior distributions in + accordance with this Agreement are not affected by the + termination of this Agreement. Upon written request, you + will certify in writing that you have complied with your + commitments under this section. Upon any termination of + this Agreement all provisions survive except for the + license grant provisions. + + +1.7. General + +If you wish to assign this Agreement or your rights and +obligations, including by merger, consolidation, dissolution +or operation of law, contact NVIDIA to ask for permission. Any +attempted assignment not approved by NVIDIA in writing shall +be void and of no effect. NVIDIA may assign, delegate or +transfer this Agreement and its rights and obligations, and if +to a non-affiliate you will be notified. + +You agree to cooperate with NVIDIA and provide reasonably +requested information to verify your compliance with this +Agreement. + +This Agreement will be governed in all respects by the laws of +the United States and of the State of Delaware, without regard to the +conflicts of laws principles. The United Nations Convention on +Contracts for the International Sale of Goods is specifically +disclaimed. You agree to all terms of this Agreement in the +English language. + +The state or federal courts residing in Santa Clara County, +California shall have exclusive jurisdiction over any dispute +or claim arising out of this Agreement. Notwithstanding this, +you agree that NVIDIA shall still be allowed to apply for +injunctive remedies or an equivalent type of urgent legal +relief in any jurisdiction. + +If any court of competent jurisdiction determines that any +provision of this Agreement is illegal, invalid or +unenforceable, such provision will be construed as limited to +the extent necessary to be consistent with and fully +enforceable under the law and the remaining provisions will +remain in full force and effect. Unless otherwise specified, +remedies are cumulative. + +Each party acknowledges and agrees that the other is an +independent contractor in the performance of this Agreement. + +The SDK has been developed entirely at private expense and is +“commercial items” consisting of “commercial computer +software” and “commercial computer software +documentation” provided with RESTRICTED RIGHTS. Use, +duplication or disclosure by the U.S. Government or a U.S. +Government subcontractor is subject to the restrictions in +this Agreement pursuant to DFARS 227.7202-3(a) or as set forth +in subparagraphs (c)(1) and (2) of the Commercial Computer +Software - Restricted Rights clause at FAR 52.227-19, as +applicable. Contractor/manufacturer is NVIDIA, 2788 San Tomas +Expressway, Santa Clara, CA 95051. + +The SDK is subject to United States export laws and +regulations. You agree that you will not ship, transfer or +export the SDK into any country, or use the SDK in any manner, +prohibited by the United States Bureau of Industry and +Security or economic sanctions regulations administered by the +U.S. Department of Treasury’s Office of Foreign Assets +Control (OFAC), or any applicable export laws, restrictions or +regulations. These laws include restrictions on destinations, +end users and end use. By accepting this Agreement, you +confirm that you are not located in a country currently +embargoed by the U.S. or otherwise prohibited from receiving +the SDK under U.S. law. + +Any notice delivered by NVIDIA to you under this Agreement +will be delivered via mail, email or fax. You agree that any +notices that NVIDIA sends you electronically will satisfy any +legal communication requirements. Please direct your legal +notices or other correspondence to NVIDIA Corporation, 2788 +San Tomas Expressway, Santa Clara, California 95051, United +States of America, Attention: Legal Department. + +This Agreement and any exhibits incorporated into this +Agreement constitute the entire agreement of the parties with +respect to the subject matter of this Agreement and supersede +all prior negotiations or documentation exchanged between the +parties relating to this SDK license. Any additional and/or +conflicting terms on documents issued by you are null, void, +and invalid. Any amendment or waiver under this Agreement +shall be in writing and signed by representatives of both +parties. + + +2. CUDA Toolkit Supplement to Software License Agreement for +NVIDIA Software Development Kits +------------------------------------------------------------ + +The terms in this supplement govern your use of the NVIDIA +CUDA Toolkit SDK under the terms of your license agreement +(“Agreement”) as modified by this supplement. Capitalized +terms used but not defined below have the meaning assigned to +them in the Agreement. + +This supplement is an exhibit to the Agreement and is +incorporated as an integral part of the Agreement. In the +event of conflict between the terms in this supplement and the +terms in the Agreement, the terms in this supplement govern. + + +2.1. License Scope + +The SDK is licensed for you to develop applications only for +use in systems with NVIDIA GPUs. + + +2.2. Distribution + +The portions of the SDK that are distributable under the +Agreement are listed in Attachment A. + + +2.3. Operating Systems + +Those portions of the SDK designed exclusively for use on the +Linux or FreeBSD operating systems, or other operating systems +derived from the source code to these operating systems, may +be copied and redistributed for use in accordance with this +Agreement, provided that the object code files are not +modified in any way (except for unzipping of compressed +files). + + +2.4. Audio and Video Encoders and Decoders + +You acknowledge and agree that it is your sole responsibility +to obtain any additional third-party licenses required to +make, have made, use, have used, sell, import, and offer for +sale your products or services that include or incorporate any +third-party software and content relating to audio and/or +video encoders and decoders from, including but not limited +to, Microsoft, Thomson, Fraunhofer IIS, Sisvel S.p.A., +MPEG-LA, and Coding Technologies. NVIDIA does not grant to you +under this Agreement any necessary patent or other rights with +respect to any audio and/or video encoders and decoders. + + +2.5. Licensing + +If the distribution terms in this Agreement are not suitable +for your organization, or for any questions regarding this +Agreement, please contact NVIDIA at +nvidia-compute-license-questions@nvidia.com. + + +2.6. Attachment A + +The following CUDA Toolkit files may be distributed with +applications developed by you, including certain +variations of these files that have version number or +architecture specific information embedded in the file name - +as an example only, for release version 9.0 of the 64-bit +Windows software, the file cudart64_90.dll is redistributable. + +Component + +CUDA Runtime + +Windows + +cudart.dll, cudart_static.lib, cudadevrt.lib + +Mac OSX + +libcudart.dylib, libcudart_static.a, libcudadevrt.a + +Linux + +libcudart.so, libcudart_static.a, libcudadevrt.a + +Android + +libcudart.so, libcudart_static.a, libcudadevrt.a + +Component + +CUDA FFT Library + +Windows + +cufft.dll, cufftw.dll, cufft.lib, cufftw.lib + +Mac OSX + +libcufft.dylib, libcufft_static.a, libcufftw.dylib, +libcufftw_static.a + +Linux + +libcufft.so, libcufft_static.a, libcufftw.so, +libcufftw_static.a + +Android + +libcufft.so, libcufft_static.a, libcufftw.so, +libcufftw_static.a + +Component + +CUDA BLAS Library + +Windows + +cublas.dll, cublasLt.dll + +Mac OSX + +libcublas.dylib, libcublasLt.dylib, libcublas_static.a, +libcublasLt_static.a + +Linux + +libcublas.so, libcublasLt.so, libcublas_static.a, +libcublasLt_static.a + +Android + +libcublas.so, libcublasLt.so, libcublas_static.a, +libcublasLt_static.a + +Component + +NVIDIA "Drop-in" BLAS Library + +Windows + +nvblas.dll + +Mac OSX + +libnvblas.dylib + +Linux + +libnvblas.so + +Component + +CUDA Sparse Matrix Library + +Windows + +cusparse.dll, cusparse.lib + +Mac OSX + +libcusparse.dylib, libcusparse_static.a + +Linux + +libcusparse.so, libcusparse_static.a + +Android + +libcusparse.so, libcusparse_static.a + +Component + +CUDA Linear Solver Library + +Windows + +cusolver.dll, cusolver.lib + +Mac OSX + +libcusolver.dylib, libcusolver_static.a + +Linux + +libcusolver.so, libcusolver_static.a + +Android + +libcusolver.so, libcusolver_static.a + +Component + +CUDA Random Number Generation Library + +Windows + +curand.dll, curand.lib + +Mac OSX + +libcurand.dylib, libcurand_static.a + +Linux + +libcurand.so, libcurand_static.a + +Android + +libcurand.so, libcurand_static.a + +Component + +NVIDIA Performance Primitives Library + +Windows + +nppc.dll, nppc.lib, nppial.dll, nppial.lib, nppicc.dll, +nppicc.lib, nppicom.dll, nppicom.lib, nppidei.dll, +nppidei.lib, nppif.dll, nppif.lib, nppig.dll, nppig.lib, +nppim.dll, nppim.lib, nppist.dll, nppist.lib, nppisu.dll, +nppisu.lib, nppitc.dll, nppitc.lib, npps.dll, npps.lib + +Mac OSX + +libnppc.dylib, libnppc_static.a, libnppial.dylib, +libnppial_static.a, libnppicc.dylib, libnppicc_static.a, +libnppicom.dylib, libnppicom_static.a, libnppidei.dylib, +libnppidei_static.a, libnppif.dylib, libnppif_static.a, +libnppig.dylib, libnppig_static.a, libnppim.dylib, +libnppisu_static.a, libnppitc.dylib, libnppitc_static.a, +libnpps.dylib, libnpps_static.a + +Linux + +libnppc.so, libnppc_static.a, libnppial.so, +libnppial_static.a, libnppicc.so, libnppicc_static.a, +libnppicom.so, libnppicom_static.a, libnppidei.so, +libnppidei_static.a, libnppif.so, libnppif_static.a +libnppig.so, libnppig_static.a, libnppim.so, +libnppim_static.a, libnppist.so, libnppist_static.a, +libnppisu.so, libnppisu_static.a, libnppitc.so +libnppitc_static.a, libnpps.so, libnpps_static.a + +Android + +libnppc.so, libnppc_static.a, libnppial.so, +libnppial_static.a, libnppicc.so, libnppicc_static.a, +libnppicom.so, libnppicom_static.a, libnppidei.so, +libnppidei_static.a, libnppif.so, libnppif_static.a +libnppig.so, libnppig_static.a, libnppim.so, +libnppim_static.a, libnppist.so, libnppist_static.a, +libnppisu.so, libnppisu_static.a, libnppitc.so +libnppitc_static.a, libnpps.so, libnpps_static.a + +Component + +NVIDIA JPEG Library + +Windows + +nvjpeg.lib, nvjpeg.dll + +Linux + +libnvjpeg.so, libnvjpeg_static.a + +Component + +Internal common library required for statically linking to +cuBLAS, cuSPARSE, cuFFT, cuRAND, nvJPEG and NPP + +Mac OSX + +libculibos.a + +Linux + +libculibos.a + +Component + +NVIDIA Runtime Compilation Library and Header + +All + +nvrtc.h + +Windows + +nvrtc.dll, nvrtc-builtins.dll + +Mac OSX + +libnvrtc.dylib, libnvrtc-builtins.dylib + +Linux + +libnvrtc.so, libnvrtc-builtins.so, libnvrtc_static.a, libnvrtx-builtins_static.a + +Component + +NVIDIA Optimizing Compiler Library + +Windows + +nvvm.dll + +Mac OSX + +libnvvm.dylib + +Linux + +libnvvm.so + +Component + +NVIDIA JIT Linking Library + +Windows + +libnvJitLink.dll, libnvJitLink.lib + +Linux + +libnvJitLink.so, libnvJitLink_static.a + +Component + +NVIDIA Common Device Math Functions Library + +Windows + +libdevice.10.bc + +Mac OSX + +libdevice.10.bc + +Linux + +libdevice.10.bc + +Component + +CUDA Occupancy Calculation Header Library + +All + +cuda_occupancy.h + +Component + +CUDA Floating Point Type Headers + +All + +cuda_fp16.h, cuda_fp16.hpp, cuda_bf16.h, cuda_bf16.hpp, cuda_fp8.h, cuda_fp8.hpp, cuda_fp6.h, cuda_fp6.hpp, cuda_fp4.h, cuda_fp4.hpp + +Component + +CUDA Headers for Runtime Compilation + +All + +crt/host_defines.h, cuComplex.h, cuda_awbarrier_helpers.h, cuda_awbarrier_primitives.h, cuda_awbarrier.h, cuda_pipeline_helpers.h, ccuda_pipeline_primitives.h, ccuda_pipeline.h, cuda_runtime_api.h, cuda.h, cuda/std/tuple, cuda/std/type_traits, cuda/std/type_traits, cuda/std/utility, device_types.h, vector_functions.h, vector_types.h + +Component + +CUDA Profiling Tools Interface (CUPTI) Library + +Windows + +cupti.dll + +Mac OSX + +libcupti.dylib + +Linux + +libcupti.so + +Component + +NVIDIA Tools Extension Library + +Windows + +nvToolsExt.dll, nvToolsExt.lib + +Mac OSX + +libnvToolsExt.dylib + +Linux + +libnvToolsExt.so + +Component + +NVIDIA CUDA Driver Libraries + +Linux + +libcuda.so, libnvidia-ptxjitcompiler.so, libnvptxcompiler_static.a + +Component + +NVIDIA CUDA File IO Libraries and Header + +All + +cufile.h + +Linux + +libcufile.so, libcufile_rdma.so, libcufile_static.a, +libcufile_rdma_static.a + +In addition to the rights above, for parties that are +developing software intended solely for use on Jetson +development kits or Jetson modules, and running Linux for +Tegra software, the following shall apply: + + * The SDK may be distributed in its entirety, as provided by + NVIDIA, and without separation of its components, for you + and/or your licensees to create software development kits + for use only on the Jetson platform and running Linux for + Tegra software. + + +2.7. Attachment B + + +Additional Licensing Obligations + +The following third party components included in the SOFTWARE +are licensed to Licensee pursuant to the following terms and +conditions: + + 1. Licensee's use of the GDB third party component is + subject to the terms and conditions of GNU GPL v3: + + This product includes copyrighted third-party software licensed + under the terms of the GNU General Public License v3 ("GPL v3"). + All third-party software packages are copyright by their respective + authors. GPL v3 terms and conditions are hereby incorporated into + the Agreement by this reference: http://www.gnu.org/licenses/gpl.txt + + Consistent with these licensing requirements, the software + listed below is provided under the terms of the specified + open source software licenses. To obtain source code for + software provided under licenses that require + redistribution of source code, including the GNU General + Public License (GPL) and GNU Lesser General Public License + (LGPL), contact oss-requests@nvidia.com. This offer is + valid for a period of three (3) years from the date of the + distribution of this product by NVIDIA CORPORATION. + + Component License + CUDA-GDB GPL v3 + + 2. Licensee represents and warrants that any and all third + party licensing and/or royalty payment obligations in + connection with Licensee's use of the H.264 video codecs + are solely the responsibility of Licensee. + + 3. Licensee's use of the Thrust library is subject to the + terms and conditions of the Apache License Version 2.0. + All third-party software packages are copyright by their + respective authors. Apache License Version 2.0 terms and + conditions are hereby incorporated into the Agreement by + this reference. + http://www.apache.org/licenses/LICENSE-2.0.html + + In addition, Licensee acknowledges the following notice: + Thrust includes source code from the Boost Iterator, + Tuple, System, and Random Number libraries. + + Boost Software License - Version 1.0 - August 17th, 2003 + . . . . + + Permission is hereby granted, free of charge, to any person or + organization obtaining a copy of the software and accompanying + documentation covered by this license (the "Software") to use, + reproduce, display, distribute, execute, and transmit the Software, + and to prepare derivative works of the Software, and to permit + third-parties to whom the Software is furnished to do so, all + subject to the following: + + The copyright notices in the Software and this entire statement, + including the above license grant, this restriction and the following + disclaimer, must be included in all copies of the Software, in whole + or in part, and all derivative works of the Software, unless such + copies or derivative works are solely in the form of machine-executable + object code generated by a source language processor. + + THE SOFTWARE IS 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, TITLE AND + NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR + ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE FOR ANY DAMAGES OR + OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE, ARISING + FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR + OTHER DEALINGS IN THE SOFTWARE. + + 4. Licensee's use of the LLVM third party component is + subject to the following terms and conditions: + + ====================================================== + LLVM Release License + ====================================================== + University of Illinois/NCSA + Open Source License + + Copyright (c) 2003-2010 University of Illinois at Urbana-Champaign. + All rights reserved. + + Developed by: + + LLVM Team + + University of Illinois at Urbana-Champaign + + http://llvm.org + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to + deal with the Software without restriction, including without limitation the + rights to use, copy, modify, merge, publish, distribute, sublicense, and/or + sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + * Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimers. + + * Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimers in the + documentation and/or other materials provided with the distribution. + + * Neither the names of the LLVM Team, University of Illinois at Urbana- + Champaign, nor the names of its contributors may be used to endorse or + promote products derived from this Software without specific prior + written permission. + + THE SOFTWARE IS 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 CONTRIBUTORS 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 SOFTWARE OR THE USE OR OTHER + DEALINGS WITH THE SOFTWARE. + + 5. Licensee's use of the PCRE third party component is + subject to the following terms and conditions: + + ------------ + PCRE LICENCE + ------------ + PCRE is a library of functions to support regular expressions whose syntax + and semantics are as close as possible to those of the Perl 5 language. + Release 8 of PCRE is distributed under the terms of the "BSD" licence, as + specified below. The documentation for PCRE, supplied in the "doc" + directory, is distributed under the same terms as the software itself. The + basic library functions are written in C and are freestanding. Also + included in the distribution is a set of C++ wrapper functions, and a just- + in-time compiler that can be used to optimize pattern matching. These are + both optional features that can be omitted when the library is built. + + THE BASIC LIBRARY FUNCTIONS + --------------------------- + Written by: Philip Hazel + Email local part: ph10 + Email domain: cam.ac.uk + University of Cambridge Computing Service, + Cambridge, England. + Copyright (c) 1997-2012 University of Cambridge + All rights reserved. + + PCRE JUST-IN-TIME COMPILATION SUPPORT + ------------------------------------- + Written by: Zoltan Herczeg + Email local part: hzmester + Emain domain: freemail.hu + Copyright(c) 2010-2012 Zoltan Herczeg + All rights reserved. + + STACK-LESS JUST-IN-TIME COMPILER + -------------------------------- + Written by: Zoltan Herczeg + Email local part: hzmester + Emain domain: freemail.hu + Copyright(c) 2009-2012 Zoltan Herczeg + All rights reserved. + + THE C++ WRAPPER FUNCTIONS + ------------------------- + Contributed by: Google Inc. + Copyright (c) 2007-2012, Google Inc. + All rights reserved. + + THE "BSD" LICENCE + ----------------- + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + + * Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + * Neither the name of the University of Cambridge nor the name of Google + Inc. nor the names of their contributors may be used to endorse or + promote products derived from this software without specific prior + written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. + + 6. Some of the cuBLAS library routines were written by or + derived from code written by Vasily Volkov and are subject + to the Modified Berkeley Software Distribution License as + follows: + + Copyright (c) 2007-2009, Regents of the University of California + + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are + met: + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above + copyright notice, this list of conditions and the following + disclaimer in the documentation and/or other materials provided + with the distribution. + * Neither the name of the University of California, Berkeley nor + the names of its contributors may be used to endorse or promote + products derived from this software without specific prior + written permission. + + THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR + IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, + INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, + STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING + IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. + + 7. Some of the cuBLAS library routines were written by or + derived from code written by Davide Barbieri and are + subject to the Modified Berkeley Software Distribution + License as follows: + + Copyright (c) 2008-2009 Davide Barbieri @ University of Rome Tor Vergata. + + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are + met: + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above + copyright notice, this list of conditions and the following + disclaimer in the documentation and/or other materials provided + with the distribution. + * The name of the author may not be used to endorse or promote + products derived from this software without specific prior + written permission. + + THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR + IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, + INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, + STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING + IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. + + 8. Some of the cuBLAS library routines were derived from + code developed by the University of Tennessee and are + subject to the Modified Berkeley Software Distribution + License as follows: + + Copyright (c) 2010 The University of Tennessee. + + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are + met: + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above + copyright notice, this list of conditions and the following + disclaimer listed in this license in the documentation and/or + other materials provided with the distribution. + * Neither the name of the copyright holders nor the names of its + contributors may be used to endorse or promote products derived + from this software without specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + 9. Some of the cuBLAS library routines were written by or + derived from code written by Jonathan Hogg and are subject + to the Modified Berkeley Software Distribution License as + follows: + + Copyright (c) 2012, The Science and Technology Facilities Council (STFC). + + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are + met: + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above + copyright notice, this list of conditions and the following + disclaimer in the documentation and/or other materials provided + with the distribution. + * Neither the name of the STFC nor the names of its contributors + may be used to endorse or promote products derived from this + software without specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE STFC BE + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR + BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, + WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE + OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN + IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + 10. Some of the cuBLAS library routines were written by or + derived from code written by Ahmad M. Abdelfattah, David + Keyes, and Hatem Ltaief, and are subject to the Apache + License, Version 2.0, as follows: + + -- (C) Copyright 2013 King Abdullah University of Science and Technology + Authors: + Ahmad Abdelfattah (ahmad.ahmad@kaust.edu.sa) + David Keyes (david.keyes@kaust.edu.sa) + Hatem Ltaief (hatem.ltaief@kaust.edu.sa) + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + * Neither the name of the King Abdullah University of Science and + Technology nor the names of its contributors may be used to endorse + or promote products derived from this software without specific prior + written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE + + 11. Some of the cuSPARSE library routines were written by or + derived from code written by Li-Wen Chang and are subject + to the NCSA Open Source License as follows: + + Copyright (c) 2012, University of Illinois. + + All rights reserved. + + Developed by: IMPACT Group, University of Illinois, http://impact.crhc.illinois.edu + + Permission is hereby granted, free of charge, to any person obtaining + a copy of this software and associated documentation files (the + "Software"), to deal with the Software without restriction, including + without limitation the rights to use, copy, modify, merge, publish, + distribute, sublicense, and/or sell copies of the Software, and to + permit persons to whom the Software is furnished to do so, subject to + the following conditions: + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above + copyright notice, this list of conditions and the following + disclaimers in the documentation and/or other materials provided + with the distribution. + * Neither the names of IMPACT Group, University of Illinois, nor + the names of its contributors may be used to endorse or promote + products derived from this Software without specific prior + written permission. + + THE SOFTWARE IS 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 CONTRIBUTORS 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 SOFTWARE OR THE USE OR OTHER DEALINGS WITH THE + SOFTWARE. + + 12. Some of the cuRAND library routines were written by or + derived from code written by Mutsuo Saito and Makoto + Matsumoto and are subject to the following license: + + Copyright (c) 2009, 2010 Mutsuo Saito, Makoto Matsumoto and Hiroshima + University. All rights reserved. + + Copyright (c) 2011 Mutsuo Saito, Makoto Matsumoto, Hiroshima + University and University of Tokyo. All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are + met: + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above + copyright notice, this list of conditions and the following + disclaimer in the documentation and/or other materials provided + with the distribution. + * Neither the name of the Hiroshima University nor the names of + its contributors may be used to endorse or promote products + derived from this software without specific prior written + permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + 13. Some of the cuRAND library routines were derived from + code developed by D. E. Shaw Research and are subject to + the following license: + + Copyright 2010-2011, D. E. Shaw Research. + + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are + met: + * Redistributions of source code must retain the above copyright + notice, this list of conditions, and the following disclaimer. + * Redistributions in binary form must reproduce the above + copyright notice, this list of conditions, and the following + disclaimer in the documentation and/or other materials provided + with the distribution. + * Neither the name of D. E. Shaw Research nor the names of its + contributors may be used to endorse or promote products derived + from this software without specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + 14. Some of the Math library routines were written by or + derived from code developed by Norbert Juffa and are + subject to the following license: + + Copyright (c) 2015-2017, Norbert Juffa + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + 1. Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + 2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + 15. Licensee's use of the lz4 third party component is + subject to the following terms and conditions: + + Copyright (C) 2011-2013, Yann Collet. + BSD 2-Clause License (http://www.opensource.org/licenses/bsd-license.php) + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are + met: + + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above + copyright notice, this list of conditions and the following disclaimer + in the documentation and/or other materials provided with the + distribution. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + 16. The NPP library uses code from the Boost Math Toolkit, + and is subject to the following license: + + Boost Software License - Version 1.0 - August 17th, 2003 + . . . . + + Permission is hereby granted, free of charge, to any person or + organization obtaining a copy of the software and accompanying + documentation covered by this license (the "Software") to use, + reproduce, display, distribute, execute, and transmit the Software, + and to prepare derivative works of the Software, and to permit + third-parties to whom the Software is furnished to do so, all + subject to the following: + + The copyright notices in the Software and this entire statement, + including the above license grant, this restriction and the following + disclaimer, must be included in all copies of the Software, in whole + or in part, and all derivative works of the Software, unless such + copies or derivative works are solely in the form of machine-executable + object code generated by a source language processor. + + THE SOFTWARE IS 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, TITLE AND + NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR + ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE FOR ANY DAMAGES OR + OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE, ARISING + FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR + OTHER DEALINGS IN THE SOFTWARE. + + 17. Portions of the Nsight Eclipse Edition is subject to the + following license: + + The Eclipse Foundation makes available all content in this plug-in + ("Content"). Unless otherwise indicated below, the Content is provided + to you under the terms and conditions of the Eclipse Public License + Version 1.0 ("EPL"). A copy of the EPL is available at http:// + www.eclipse.org/legal/epl-v10.html. For purposes of the EPL, "Program" + will mean the Content. + + If you did not receive this Content directly from the Eclipse + Foundation, the Content is being redistributed by another party + ("Redistributor") and different terms and conditions may apply to your + use of any object code in the Content. Check the Redistributor's + license that was provided with the Content. If no such license exists, + contact the Redistributor. Unless otherwise indicated below, the terms + and conditions of the EPL still apply to any source code in the + Content and such source code may be obtained at http://www.eclipse.org. + + 18. Some of the cuBLAS library routines uses code from + OpenAI, which is subject to the following license: + + License URL + https://github.com/openai/openai-gemm/blob/master/LICENSE + + License Text + The MIT License + + Copyright (c) 2016 OpenAI (http://openai.com), 2016 Google Inc. + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to deal + in the Software without restriction, including without limitation the rights + to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + copies of the Software, and to permit persons to whom the Software is + 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 Software. + + THE SOFTWARE IS 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 SOFTWARE OR THE USE OR OTHER DEALINGS IN + THE SOFTWARE. + + 19. Licensee's use of the Visual Studio Setup Configuration + Samples is subject to the following license: + + The MIT License (MIT) + Copyright (C) Microsoft Corporation. All rights reserved. + + Permission is hereby granted, free of charge, to any person + obtaining a copy of this software and associated documentation + files (the "Software"), to deal in the Software without restriction, + including without limitation the rights to use, copy, modify, merge, + publish, distribute, sublicense, and/or sell copies of the Software, + and to permit persons to whom the Software is 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 Software. + + THE SOFTWARE IS 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 SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + 20. Licensee's use of linmath.h header for CPU functions for + GL vector/matrix operations from lunarG is subject to the + Apache License Version 2.0. + + 21. The DX12-CUDA sample uses the d3dx12.h header, which is + subject to the MIT license. + + 22. Components of the driver and compiler used for binary management, including + nvFatBin, nvcc, and cuobjdump, use the Zstandard library which is subject to + the following license: + + BSD License + + For Zstandard software + + Copyright (c) Meta Platforms, Inc. and affiliates. All rights reserved. + + Redistribution and use in source and binary forms, with or without modification, + are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + + * Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + + * Neither the name Facebook, nor Meta, nor the names of its contributors may + be used to endorse or promote products derived from this software without + specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND + ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY + DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, + BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, + OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, + WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY + OF SUCH DAMAGE. + + + 23. Portions of support for math operations on 128-bit floating-point data type in compiler + were derived from SLEEF library which is subject to the following license: + + Boost Software License - Version 1.0 - August 17th, 2003 + + Permission is hereby granted, free of charge, to any person or organization + obtaining a copy of the software and accompanying documentation covered by + this license (the "Software") to use, reproduce, display, distribute, + execute, and transmit the Software, and to prepare derivative works of the + Software, and to permit third-parties to whom the Software is furnished to + do so, all subject to the following: + + The copyright notices in the Software and this entire statement, including + the above license grant, this restriction and the following disclaimer, + must be included in all copies of the Software, in whole or in part, and + all derivative works of the Software, unless such copies or derivative + works are solely in the form of machine-executable object code generated by + a source language processor. + + THE SOFTWARE IS 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, TITLE AND NON-INFRINGEMENT. IN NO EVENT + SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE + FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE, + ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + DEALINGS IN THE SOFTWARE. + + 24. Portions of support for math operations on 128-bit floating-point data type + in compiler were derived from SoftFloat library which is subject to the following license: + + The SoftFloat package was written by me, John R. Hauser. Release 3 of SoftFloat + was a completely new implementation supplanting earlier releases. The project to + create Release 3 (now through 3e) was done in the employ of the University of + California, Berkeley, within the Department of Electrical Engineering and + Computer Sciences, first for the Parallel Computing Laboratory (Par Lab) and + then for the ASPIRE Lab. The work was officially overseen by Prof. Krste + Asanovic, with funding provided by these sources: + + Par Lab: Microsoft (Award #024263), Intel (Award #024894), and U.C. Discovery + (Award #DIG07-10227), with additional support from Par Lab affiliates Nokia, + NVIDIA, Oracle, and Samsung. + ASPIRE Lab: DARPA PERFECT program (Award #HR0011-12-2-0016), with additional + support from ASPIRE industrial sponsor Intel and ASPIRE affiliates Google, Nokia, + NVIDIA, Oracle, and Samsung. + The following applies to the whole of SoftFloat Release 3e as well as to each + source file individually. + + Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018 The Regents of the + University of California. All rights reserved. + + Redistribution and use in source and binary forms, with or without modification, + are permitted provided that the following conditions are met: + + Redistributions in binary form must reproduce the above copyright notice, this + list of conditions, and the following disclaimer in the documentation and/or + other materials provided with the distribution. + + Neither the name of the University nor the names of its contributors may be used + to endorse or promote products derived from this software without specific prior + written permission. + + THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY EXPRESS + OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF + MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE DISCLAIMED. IN NO EVENT + SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR + BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING + IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + SUCH DAMAGE. +----------------- diff --git a/vendor/cuobj/NOTICE b/vendor/cuobj/NOTICE index b4493995..a75c433a 100644 --- a/vendor/cuobj/NOTICE +++ b/vendor/cuobj/NOTICE @@ -1,69 +1,62 @@ -NVIDIA cuFile and cuObj Redistribution Notice -============================================= +NVIDIA CUDA Toolkit Components Redistribution Notice +==================================================== -The artifacts under this directory (vendor/cuobj/) are NOT covered by the -minio-cpp Apache License 2.0. They originate from NVIDIA Corporation and -are redistributed under NVIDIA's software license agreements. +The artifacts under this directory (vendor/cuobj/) and the NVIDIA-derived +headers under include/miniocpp/ (cuda.h, nvidia-cufile.h, +nvidia-cuobjclient.h) are NOT covered by the minio-cpp Apache License +2.0. They originate from NVIDIA Corporation and are redistributed under +the NVIDIA CUDA Toolkit End User License Agreement. + +A verbatim copy of that agreement is included in this directory as +EULA.txt. By building or distributing minio-cpp with +-DMINIO_CPP_ENABLE_RDMA=ON you accept that EULA for the components +listed below. What is vendored ---------------- - vendor/cuobj/include/cuda.h - The CUDA driver API header (cuda.h). Required for type declarations - (CUdeviceptr, CUstream, etc.) that appear in cuFile / cuObj API - signatures. minio-cpp itself does not call any CUDA driver or - runtime symbol. - - vendor/cuobj/lib/libcufile.so.1.18.0 (and SONAME aliases) + vendor/cuobj/lib/libcufile.so.1.18.0 (and SONAME aliases) vendor/cuobj/lib/libcufile_rdma.so.1.18.0 (and SONAME aliases) NVIDIA cuFile (GPUDirect Storage) shared libraries, version 1.18.0. Provides the cuFile* API used by libcuobjclient for RDMA transfers. vendor/cuobj/lib/libcuobjclient.so.1.2.0 (and SONAME aliases) vendor/cuobj/lib/libcuobjserver.so.1.2.0 (and SONAME aliases) - NVIDIA cuObj client / server libraries, "resiliency_v3" (1.2.0). + NVIDIA cuObjClient / cuObjServer libraries, "resiliency_v3" (1.2.0). Provides the cuObjClient C++ class used by minio-cpp to mint and release RDMA tokens for the S3 RDMA protocol. -The corresponding public-facing API headers -include/miniocpp/nvidia-cufile.h, include/miniocpp/nvidia-cuobjclient.h -are reproductions of NVIDIA's API surface and are also subject to the -upstream NVIDIA agreements below. - - -Applicable NVIDIA agreements ----------------------------- - -* NVIDIA Software License Agreement (cuda.h, CUDA driver headers): - https://docs.nvidia.com/cuda/eula/index.html + vendor/cuobj/include/cuda.h + include/miniocpp/cuda.h + The CUDA driver API header, required for type declarations + (CUdeviceptr, CUstream, etc.) that appear in cuFile / cuObj API + signatures. minio-cpp itself does not call any CUDA driver or + runtime symbol. -* NVIDIA cuFile (GPUDirect Storage) SDK License: - https://docs.nvidia.com/gpudirect-storage/api-reference-guide/ + include/miniocpp/nvidia-cufile.h + include/miniocpp/nvidia-cuobjclient.h + Public-facing API headers for the cuFile and cuObj libraries. -* NVIDIA cuObjClient redistribution terms apply to the libcuobjclient / - libcuobjserver shared objects. Refer to the cuObj SDK distribution - channel from which these binaries were obtained. -Each header retains its original NVIDIA copyright notice; see the top of -include/miniocpp/cuda.h for the verbatim statement that ships with -cuda.h. +Per the CUDA Toolkit EULA Attachment A (see EULA.txt §2.6), the cuFile +component, including cufile.h, libcufile.so, and libcufile_rdma.so, is +explicitly redistributable. The remaining components are distributed +under the same EULA's general terms. Scope of this notice -------------------- -This NOTICE applies ONLY to files under vendor/cuobj/ and to the -NVIDIA-derived headers include/miniocpp/cuda.h, nvidia-cufile.h, and -nvidia-cuobjclient.h. The rest of minio-cpp is licensed under the -Apache License 2.0 — see the top-level LICENSE file. - -The minio-cpp project does not grant any license to the NVIDIA artifacts -above. Use of those artifacts is subject directly to the upstream NVIDIA -agreements; if you redistribute minio-cpp builds that include them, you -are responsible for complying with those terms. +This NOTICE and the accompanying EULA.txt apply ONLY to files under +vendor/cuobj/ and to the NVIDIA-derived headers include/miniocpp/cuda.h, +nvidia-cufile.h, and nvidia-cuobjclient.h. The rest of minio-cpp is +licensed under the Apache License 2.0 — see the top-level LICENSE file. Building minio-cpp with -DMINIO_CPP_ENABLE_RDMA=OFF (the default) omits the entire vendor/cuobj/ tree and the NVIDIA-derived headers from the build, so consumers who do not need GPUDirect Storage / RDMA can ignore this notice entirely. + +For questions about the EULA terms, contact NVIDIA at +nvidia-compute-license-questions@nvidia.com (per EULA.txt §2.5). From c275017693ff37674c57b81028e81b73b913e048 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 21 May 2026 18:25:15 -0700 Subject: [PATCH 21/25] vendor: scrub sample IP from cuobj.json to placeholder Replaces the literal 192.168.1.1 sample under rdma_dev_addr_list with placeholder. Operators must substitute their local NIC IPv4 before use. --- vendor/cuobj/cuobj.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/vendor/cuobj/cuobj.json b/vendor/cuobj/cuobj.json index b6320fef..fac2bdcd 100644 --- a/vendor/cuobj/cuobj.json +++ b/vendor/cuobj/cuobj.json @@ -23,7 +23,8 @@ "rdma_peer_type": "dmabuf", // client-side rdma addr list for user-space file-systems(e.g ["10.0.1.0", "10.0.2.0"]) - "rdma_dev_addr_list": ["192.168.1.1"], + // Replace with your local NIC IPv4 before use. + "rdma_dev_addr_list": [""], //32-bit dc key value in hex //"rdma_dc_key": "0xffeeddcc", //To enable/disable different rdma OPs use the below bit map From b8d958a558496d9f12a5d5f8530c94225b4f84fc Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 21 May 2026 18:45:10 -0700 Subject: [PATCH 22/25] vendor: ground NOTICE in verbatim Attachment A entries; clarify Apache 2.0 compatibility MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Re-grounds vendor/cuobj/NOTICE on the actual CUDA Toolkit EULA §2.6 Attachment A entries that authorize redistribution of the vendored files: * "NVIDIA CUDA File IO Libraries and Header" covers cufile.h, libcufile.so, libcufile_rdma.so (plus static variants). * "Accelerated CUDA Libraries for Object Storage" covers libcuobjclient.so, libcuobjserver.so, and the cuObj headers (cuobjclient.h, cuobjrdma.h, cuobjrdmaparam.h, cuobjserver.h, cuobjtelem.h). * "CUDA Headers for Runtime Compilation" covers cuda.h. Also adds a section explaining why redistribution inside minio-cpp's Apache 2.0 SDK does not violate EULA §1.2(5): Apache 2.0 is permissive, not copyleft, and §4 of Apache 2.0 expressly permits shipping the licensed work alongside components carrying different license terms. The NVIDIA artifacts remain governed exclusively by EULA.txt; the Apache 2.0 grant covers only minio-cpp's own source. --- vendor/cuobj/NOTICE | 60 ++++++++++++++++++++++++++++++++++++--------- 1 file changed, 49 insertions(+), 11 deletions(-) diff --git a/vendor/cuobj/NOTICE b/vendor/cuobj/NOTICE index a75c433a..719ec4ae 100644 --- a/vendor/cuobj/NOTICE +++ b/vendor/cuobj/NOTICE @@ -13,36 +13,74 @@ EULA.txt. By building or distributing minio-cpp with listed below. +Coverage under CUDA Toolkit EULA §2.6 Attachment A +-------------------------------------------------- + +The EULA's §2.6 Attachment A enumerates components that may be +distributed with applications developed by you. The cuFile and cuObj +components we vendor here all appear in that enumeration: + + Component: NVIDIA CUDA File IO Libraries and Header + All: cufile.h + Linux: libcufile.so, libcufile_rdma.so, libcufile_static.a, + libcufile_rdma_static.a + + Component: Accelerated CUDA Libraries for Object Storage + All: libcuobjclient.so, libcuobjserver.so, cuobjclient.h, + cuobjrdma.h, cuobjrdmaparam.h, cuobjserver.h, cuobjtelem.h + + Component: CUDA Headers for Runtime Compilation + All: cuda.h, cuda_runtime_api.h, ... + +(See EULA.txt for the complete and authoritative list.) + + What is vendored ---------------- vendor/cuobj/lib/libcufile.so.1.18.0 (and SONAME aliases) vendor/cuobj/lib/libcufile_rdma.so.1.18.0 (and SONAME aliases) - NVIDIA cuFile (GPUDirect Storage) shared libraries, version 1.18.0. - Provides the cuFile* API used by libcuobjclient for RDMA transfers. + NVIDIA cuFile (GPUDirect Storage) shared libraries, v1.18.0. + Covered by Attachment A entry "NVIDIA CUDA File IO Libraries + and Header". vendor/cuobj/lib/libcuobjclient.so.1.2.0 (and SONAME aliases) vendor/cuobj/lib/libcuobjserver.so.1.2.0 (and SONAME aliases) - NVIDIA cuObjClient / cuObjServer libraries, "resiliency_v3" (1.2.0). - Provides the cuObjClient C++ class used by minio-cpp to mint and - release RDMA tokens for the S3 RDMA protocol. + NVIDIA cuObjClient / cuObjServer libraries, v1.2.0. + Covered by Attachment A entry "Accelerated CUDA Libraries for + Object Storage". vendor/cuobj/include/cuda.h include/miniocpp/cuda.h The CUDA driver API header, required for type declarations (CUdeviceptr, CUstream, etc.) that appear in cuFile / cuObj API - signatures. minio-cpp itself does not call any CUDA driver or - runtime symbol. + signatures. Covered by Attachment A entry "CUDA Headers for + Runtime Compilation". minio-cpp itself does not call any CUDA + driver or runtime symbol. include/miniocpp/nvidia-cufile.h include/miniocpp/nvidia-cuobjclient.h Public-facing API headers for the cuFile and cuObj libraries. + Covered by the cuFile and Object Storage Attachment A entries + above. + + +Compatibility with the minio-cpp Apache 2.0 license +--------------------------------------------------- +Apache License 2.0 is a permissive license. It does not impose any of +the restrictions that the CUDA EULA §1.2(5) reserves against: it does +not require source disclosure of linked binary components, it does not +require derivative licensing of linked components, and it does not +require linked binary components to be redistributable at no charge. +Apache 2.0 §4 expressly permits distributing the licensed work alongside +components that carry "additional or different license terms". -Per the CUDA Toolkit EULA Attachment A (see EULA.txt §2.6), the cuFile -component, including cufile.h, libcufile.so, and libcufile_rdma.so, is -explicitly redistributable. The remaining components are distributed -under the same EULA's general terms. +Accordingly, shipping the NVIDIA artifacts under this directory inside +minio-cpp does NOT subject those artifacts to Apache 2.0; they remain +governed exclusively by EULA.txt. The Apache 2.0 grant in the top-level +LICENSE applies only to minio-cpp's own source code and does not extend +to anything in vendor/cuobj/ or the NVIDIA-derived headers listed above. Scope of this notice From f95d83bb90afed482e139d7a8ff8add08b9aeec9 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 21 May 2026 21:19:44 -0700 Subject: [PATCH 23/25] api: unify PutObjectArgs/GetObjectArgs (drop RDMA-specific overloads) + add C ABI MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit The RDMA path is now selected transparently by populating the new buf/size fields on PutObjectArgs / GetObjectArgs. The dedicated PutObjectRDMAArgs / GetObjectRDMAArgs structs and their corresponding Client::PutObject / Client::GetObject overloads are deleted. API change summary: PutObjectArgs + char* buf = nullptr (RDMA / direct-buffer path) + std::optional size (required when buf is set) ~ std::istream* stream (was: std::istream&) GetObjectArgs + char* buf = nullptr (RDMA / direct-buffer path) + std::optional size (required when buf is set) Validate() on both now requires exactly one of (stream|datafunc, buf). Deleted: struct PutObjectRDMAArgs, struct GetObjectRDMAArgs, Client::PutObject(PutObjectRDMAArgs), Client::GetObject(GetObjectRDMAArgs). Behaviour preserved: the previous RDMA-specific method bodies are folded inline into the unified Client::PutObject / Client::GetObject as a buf-mode branch. When buf is set, the SDK still tries RDMA via SharedRDMAClient() and falls back to a single-shot HTTP upload / streamed HTTP-into-buf download on RDMA decline. Source-compat note: the PutObjectArgs constructor still takes std::istream& (now stored as a pointer internally). Callers that assigned to the .stream field directly need to pass a pointer (&my_stream). Also adds include/miniocpp/c_api.h + src/c_api.cc — a stable extern "C" ABI exporting miniocpp_client_new/free, miniocpp_put_object, miniocpp_get_object (both unified — buf!=NULL ⇒ RDMA, else callback streaming), miniocpp_alloc_aligned/free_aligned, miniocpp_rdma_available, miniocpp_last_error. Symbols carry visibility("default") and gated under MINIO_CPP_ENABLE_RDMA. This is the shared base that minio-go and minio-py language bindings will dlopen against instead of vendoring per-language C++ glue. --- CMakeLists.txt | 2 + examples/GetPutRDMA.cc | 4 +- include/miniocpp/args.h | 37 +++---- include/miniocpp/c_api.h | 112 ++++++++++++++++++++ include/miniocpp/client.h | 4 - src/args.cc | 60 ++++------- src/c_api.cc | 216 ++++++++++++++++++++++++++++++++++++++ src/client.cc | 204 +++++++++++++++++------------------ 8 files changed, 459 insertions(+), 180 deletions(-) create mode 100644 include/miniocpp/c_api.h create mode 100644 src/c_api.cc diff --git a/CMakeLists.txt b/CMakeLists.txt index f04b1462..fd137669 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -133,10 +133,12 @@ set(MINIO_CPP_HEADERS if (MINIO_CPP_ENABLE_RDMA) list(APPEND MINIO_CPP_HEADERS + include/miniocpp/c_api.h include/miniocpp/nvidia-cufile.h include/miniocpp/nvidia-cuobjclient.h include/miniocpp/rdma.h ) + list(APPEND MINIO_CPP_SOURCES src/c_api.cc) endif() option(BUILD_SHARED_LIBS "Build using shared libraries" OFF) diff --git a/examples/GetPutRDMA.cc b/examples/GetPutRDMA.cc index 29246af0..870ba6d3 100644 --- a/examples/GetPutRDMA.cc +++ b/examples/GetPutRDMA.cc @@ -168,7 +168,7 @@ int main(int argc, char *argv[]) { memset(bufptr, 'A', bufsize); } - minio::s3::PutObjectRDMAArgs pargs; + minio::s3::PutObjectArgs pargs; pargs.buf = bufptr; pargs.size = bufsize; pargs.bucket = "my-bucket"; @@ -183,7 +183,7 @@ int main(int argc, char *argv[]) { << std::endl; } - minio::s3::GetObjectRDMAArgs args; + minio::s3::GetObjectArgs args; if (gpu_enabled) { cuda.cuMemsetD8(dptr, 'U', bufsize); cuda.cuCtxSynchronize(); diff --git a/include/miniocpp/args.h b/include/miniocpp/args.h index 3d854be0..99a5c3a0 100644 --- a/include/miniocpp/args.h +++ b/include/miniocpp/args.h @@ -220,8 +220,13 @@ struct DownloadObjectArgs : public ObjectReadArgs { }; // struct DownloadObjectArgs struct GetObjectArgs : public ObjectConditionalReadArgs { + // Exactly one of (datafunc, buf) must be set; Validate() enforces. + // When buf is set, the call attempts RDMA and falls back to streaming + // the HTTP body into the same buffer on RDMA decline. http::DataFunction datafunc; void* userdata = nullptr; + char* buf = nullptr; + std::optional size; http::ProgressFunction progressfunc = nullptr; void* progress_userdata = nullptr; @@ -231,18 +236,6 @@ struct GetObjectArgs : public ObjectConditionalReadArgs { error::Error Validate() const; }; // struct GetObjectArgs -#ifdef MINIO_CPP_RDMA -struct GetObjectRDMAArgs : public GetObjectArgs { - char* buf = nullptr; - std::optional size; - - GetObjectRDMAArgs() = default; - ~GetObjectRDMAArgs() = default; - - error::Error Validate() const; -}; // struct GetObjectRDMAArgs -#endif - struct ListObjectsArgs : public BucketArgs { std::string delimiter; bool use_url_encoding_type = true; @@ -341,7 +334,12 @@ struct ListObjectVersionsArgs : public ListObjectsCommonArgs { }; // struct ListObjectVersionsArgs struct PutObjectArgs : public PutObjectBaseArgs { - std::istream& stream; + // Exactly one of (stream, buf) must be set; Validate() enforces. + // When buf is set, the call attempts RDMA and falls back to a + // streaming HTTP upload from the same buffer on RDMA decline. + std::istream* stream = nullptr; + char* buf = nullptr; + std::optional size; http::ProgressFunction progressfunc = nullptr; void* progress_userdata = nullptr; #ifdef MINIO_CPP_RDMA @@ -349,24 +347,13 @@ struct PutObjectArgs : public PutObjectBaseArgs { #endif std::string checksum_crc64nvme; // CRC64NVME checksum for multipart uploads + PutObjectArgs() = default; PutObjectArgs(std::istream& stream, long object_size, long part_size); ~PutObjectArgs() = default; error::Error Validate(); }; // struct PutObjectArgs -#ifdef MINIO_CPP_RDMA -struct PutObjectRDMAArgs : public PutObjectBaseArgs { - char* buf = nullptr; - std::optional size; - - PutObjectRDMAArgs() = default; - ~PutObjectRDMAArgs() = default; - - error::Error Validate() const; -}; // struct PutObjectRDMAArgs -#endif - using CopySource = ObjectConditionalReadArgs; struct CopyObjectArgs : public ObjectWriteArgs { diff --git a/include/miniocpp/c_api.h b/include/miniocpp/c_api.h new file mode 100644 index 00000000..f983ba4b --- /dev/null +++ b/include/miniocpp/c_api.h @@ -0,0 +1,112 @@ +// MinIO C++ Library for Amazon S3 Compatible Cloud Storage +// Copyright 2022-2026 MinIO, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// SPDX-License-Identifier: Apache-2.0 +// +// Stable C ABI for libminiocpp. Provided so language bindings (minio-go, +// minio-py, etc.) can call a single shared library instead of vendoring +// per-language C++ glue. The API is intentionally minimal: one constructor, +// one destructor, two object-IO functions, an aligned-buffer allocator pair, +// and an error accessor. Both put and get are unified — passing `buf` selects +// the RDMA / direct-buffer path, omitting it selects callback-streaming. + +#ifndef MINIO_CPP_C_API_H_INCLUDED +#define MINIO_CPP_C_API_H_INCLUDED + +#ifdef MINIO_CPP_RDMA + +#include +#include // ssize_t + +#ifdef __cplusplus +extern "C" { +#endif + +#if defined(__GNUC__) || defined(__clang__) +#define MINIOCPP_API __attribute__((visibility("default"))) +#else +#define MINIOCPP_API +#endif + +typedef struct miniocpp_client miniocpp_client; + +// Error codes returned by miniocpp_put_object / miniocpp_get_object. +// >=0 indicates success and is the byte count actually transferred. +#define MINIOCPP_ERR_GENERIC (-1) // error; call miniocpp_last_error() +#define MINIOCPP_ERR_RDMA_DECLINED (-2) +#define MINIOCPP_ERR_INVALID_ARG (-3) + +// Streaming-source callback (PUT). Called repeatedly to fill `buf` with up to +// `size` bytes. Return the number of bytes written, 0 on EOF, or a negative +// value to abort the upload. +typedef ssize_t (*miniocpp_read_cb)(void* userdata, char* buf, size_t size); + +// Streaming-sink callback (GET). Called repeatedly with the next chunk. +// Return the number of bytes consumed (must equal `size` to continue), or a +// negative value to abort the download. +typedef ssize_t (*miniocpp_write_cb)(void* userdata, const char* buf, + size_t size); + +// Construct a client. region/session_token may be NULL/"". +// Returned pointer is owned by the caller; release with miniocpp_client_free. +MINIOCPP_API miniocpp_client* miniocpp_client_new(const char* endpoint, + const char* region, + const char* access_key, + const char* secret_key, + const char* session_token, + int use_https); + +MINIOCPP_API void miniocpp_client_free(miniocpp_client* client); + +// PUT. When `buf` is non-NULL, attempts RDMA with HTTP-from-buf fallback; +// `read_cb` is ignored. When `buf` is NULL, streams from `read_cb`. +// Writes the resulting ETag (max 63 chars + NUL) into etag_out if non-NULL. +// Writes the CRC64NVME checksum (base64, ~32 chars) into checksum_out if +// non-NULL. Returns bytes transferred on success, or one of MINIOCPP_ERR_*. +MINIOCPP_API ssize_t miniocpp_put_object(miniocpp_client* client, + const char* bucket, + const char* object, + void* buf, size_t size, + miniocpp_read_cb read_cb, + void* userdata, + char etag_out[64], + char checksum_out[64]); + +// GET. When `buf` is non-NULL, attempts RDMA into the caller's buffer with +// HTTP-into-buf fallback; `write_cb` is ignored. When `buf` is NULL, streams +// the body through `write_cb`. Returns bytes transferred or MINIOCPP_ERR_*. +MINIOCPP_API ssize_t miniocpp_get_object(miniocpp_client* client, + const char* bucket, + const char* object, + void* buf, size_t size, + miniocpp_write_cb write_cb, + void* userdata); + +// Page-aligned host allocator suitable for RDMA registration. Caller must +// release with miniocpp_free_aligned. Returns NULL on allocation failure. +MINIOCPP_API void* miniocpp_alloc_aligned(size_t size); +MINIOCPP_API void miniocpp_free_aligned(void* ptr); + +// Returns 1 if the process-wide cuObjClient is currently connected to a +// cuObjServer (i.e. an RDMA transfer is likely to succeed), 0 otherwise. +// Safe to call before any IO. Does not require an existing miniocpp_client. +MINIOCPP_API int miniocpp_rdma_available(void); + +// Thread-local last-error message from the most recent failing call on the +// calling thread. Returns NULL when no error has been recorded. The returned +// pointer is owned by the library and stable until the next failing call on +// this thread. +MINIOCPP_API const char* miniocpp_last_error(void); + +#ifdef __cplusplus +} // extern "C" +#endif + +#endif // MINIO_CPP_RDMA +#endif // MINIO_CPP_C_API_H_INCLUDED diff --git a/include/miniocpp/client.h b/include/miniocpp/client.h index 60c55f1d..563f1542 100644 --- a/include/miniocpp/client.h +++ b/include/miniocpp/client.h @@ -136,10 +136,6 @@ class Client : public BaseClient { ListObjectsResult ListObjects(ListObjectsArgs args); PutObjectResponse PutObject(PutObjectArgs args); GetObjectResponse GetObject(GetObjectArgs args); -#ifdef MINIO_CPP_RDMA - GetObjectResponse GetObject(GetObjectRDMAArgs args); - PutObjectResponse PutObject(PutObjectRDMAArgs args); -#endif UploadObjectResponse UploadObject(UploadObjectArgs args); RemoveObjectsResult RemoveObjects(RemoveObjectsArgs args); }; // class Client diff --git a/src/args.cc b/src/args.cc index 4ff46404..e8d06599 100644 --- a/src/args.cc +++ b/src/args.cc @@ -224,49 +224,18 @@ error::Error DownloadObjectArgs::Validate() const { return error::SUCCESS; } -#ifdef MINIO_CPP_RDMA -error::Error GetObjectRDMAArgs::Validate() const { - // Validate bucket+object via the ObjectArgs chain so an empty bucket - // is rejected here with "bucket name cannot be empty" instead of slipping - // through to the HTTP fallback in Client::GetObject(GetObjectRDMAArgs). - // We deliberately skip GetObjectArgs::Validate() because it requires - // datafunc, which the RDMA path does not use (writes go straight to buf). - if (error::Error err = ObjectArgs::Validate()) { - return err; - } - if (!this->buf) { - return error::Error("buffer must be set"); - } - if (!this->size.has_value()) { - return error::Error("size must be set"); - } - - return error::SUCCESS; -} - -error::Error PutObjectRDMAArgs::Validate() const { - // See GetObjectRDMAArgs::Validate() for rationale on calling ObjectArgs - // directly instead of a more specific parent. - if (error::Error err = ObjectArgs::Validate()) { - return err; - } - if (!this->buf) { - return error::Error("buffer must be set"); - } - if (!this->size.has_value()) { - return error::Error("size must be set"); - } - - return error::SUCCESS; -} -#endif - error::Error GetObjectArgs::Validate() const { if (error::Error err = ObjectConditionalReadArgs::Validate()) { return err; } - if (datafunc == nullptr) { - return error::Error("data callback must be set"); + const bool has_datafunc = (datafunc != nullptr); + const bool has_buf = (buf != nullptr); + if (has_datafunc == has_buf) { + return error::Error( + "exactly one of datafunc or buf must be set"); + } + if (has_buf && !size.has_value()) { + return error::Error("size must be set when buf is set"); } return error::SUCCESS; @@ -333,13 +302,24 @@ ListObjectVersionsArgs& ListObjectVersionsArgs::operator=( PutObjectArgs::PutObjectArgs(std::istream& istream, long object_size, long part_size) - : stream(istream) { + : stream(&istream) { this->object_size = object_size; this->part_size = part_size; } error::Error PutObjectArgs::Validate() { if (error::Error err = ObjectArgs::Validate()) return err; + const bool has_stream = (stream != nullptr); + const bool has_buf = (buf != nullptr); + if (has_stream == has_buf) { + return error::Error("exactly one of stream or buf must be set"); + } + if (has_buf) { + if (!size.has_value()) { + return error::Error("size must be set when buf is set"); + } + if (object_size < 0) object_size = static_cast(*size); + } return utils::CalcPartInfo(object_size, part_size, part_count); } diff --git a/src/c_api.cc b/src/c_api.cc new file mode 100644 index 00000000..10b209f9 --- /dev/null +++ b/src/c_api.cc @@ -0,0 +1,216 @@ +// MinIO C++ Library for Amazon S3 Compatible Cloud Storage +// Copyright 2022-2026 MinIO, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// SPDX-License-Identifier: Apache-2.0 + +#ifdef MINIO_CPP_RDMA + +#include "miniocpp/c_api.h" + +#include +#include +#include +#include +#include +#include +#include +#include + +#include "miniocpp/args.h" +#include "miniocpp/client.h" +#include "miniocpp/credentials.h" +#include "miniocpp/http.h" +#include "miniocpp/nvidia-cuobjclient.h" +#include "miniocpp/providers.h" +#include "miniocpp/response.h" + +namespace { + +thread_local std::string g_last_error; + +void SetLastError(const std::string& msg) { g_last_error = msg; } + +// Adapter so a miniocpp_read_cb can drive a std::istream-based upload. +class ReadCbStreamBuf : public std::streambuf { + public: + ReadCbStreamBuf(miniocpp_read_cb cb, void* userdata) + : cb_(cb), userdata_(userdata) {} + + protected: + int_type underflow() override { + if (cb_ == nullptr) return traits_type::eof(); + ssize_t n = cb_(userdata_, buf_, sizeof(buf_)); + if (n <= 0) return traits_type::eof(); + setg(buf_, buf_, buf_ + n); + return traits_type::to_int_type(buf_[0]); + } + + private: + miniocpp_read_cb cb_; + void* userdata_; + char buf_[64 * 1024]; +}; + +struct ClientHolder { + minio::s3::BaseUrl base_url; + std::unique_ptr provider; + std::unique_ptr client; +}; + +} // namespace + +extern "C" { + +miniocpp_client* miniocpp_client_new(const char* endpoint, const char* region, + const char* access_key, + const char* secret_key, + const char* session_token, + int use_https) { + if (endpoint == nullptr || access_key == nullptr || secret_key == nullptr) { + SetLastError("endpoint, access_key, and secret_key are required"); + return nullptr; + } + try { + auto holder = std::make_unique(); + holder->base_url = minio::s3::BaseUrl(endpoint, use_https != 0, + region != nullptr ? region : ""); + holder->provider = std::make_unique( + access_key, secret_key, + session_token != nullptr ? session_token : ""); + holder->client = std::make_unique(holder->base_url, + holder->provider.get()); + return reinterpret_cast(holder.release()); + } catch (const std::exception& e) { + SetLastError(std::string("client construction failed: ") + e.what()); + return nullptr; + } +} + +void miniocpp_client_free(miniocpp_client* c) { + delete reinterpret_cast(c); +} + +ssize_t miniocpp_put_object(miniocpp_client* c, const char* bucket, + const char* object, void* buf, size_t size, + miniocpp_read_cb read_cb, void* userdata, + char etag_out[64], char checksum_out[64]) { + if (c == nullptr || bucket == nullptr || object == nullptr) { + SetLastError("client, bucket, object are required"); + return MINIOCPP_ERR_INVALID_ARG; + } + if (buf == nullptr && read_cb == nullptr) { + SetLastError("either buf or read_cb must be provided"); + return MINIOCPP_ERR_INVALID_ARG; + } + auto* holder = reinterpret_cast(c); + + minio::s3::PutObjectArgs args; + args.bucket = bucket; + args.object = object; + args.region = holder->base_url.region; + + std::unique_ptr sbuf; + std::unique_ptr sis; + if (buf != nullptr) { + args.buf = static_cast(buf); + args.size = size; + args.object_size = static_cast(size); + args.part_size = 16 * 1024 * 1024L; + } else { + sbuf = std::make_unique(read_cb, userdata); + sis = std::make_unique(sbuf.get()); + args.stream = sis.get(); + args.object_size = static_cast(size); + args.part_size = 16 * 1024 * 1024L; + } + + minio::s3::PutObjectResponse resp = holder->client->PutObject(args); + if (!resp) { + SetLastError(resp.Error().String()); + return MINIOCPP_ERR_GENERIC; + } + if (etag_out != nullptr) { + std::strncpy(etag_out, resp.etag.c_str(), 63); + etag_out[63] = '\0'; + } + if (checksum_out != nullptr) { + std::strncpy(checksum_out, resp.checksum_crc64nvme.c_str(), 63); + checksum_out[63] = '\0'; + } + return static_cast(size); +} + +ssize_t miniocpp_get_object(miniocpp_client* c, const char* bucket, + const char* object, void* buf, size_t size, + miniocpp_write_cb write_cb, void* userdata) { + if (c == nullptr || bucket == nullptr || object == nullptr) { + SetLastError("client, bucket, object are required"); + return MINIOCPP_ERR_INVALID_ARG; + } + if (buf == nullptr && write_cb == nullptr) { + SetLastError("either buf or write_cb must be provided"); + return MINIOCPP_ERR_INVALID_ARG; + } + auto* holder = reinterpret_cast(c); + + minio::s3::GetObjectArgs args; + args.bucket = bucket; + args.object = object; + args.region = holder->base_url.region; + + ssize_t bytes_seen = 0; + + if (buf != nullptr) { + args.buf = static_cast(buf); + args.size = size; + } else { + args.datafunc = [write_cb, userdata, &bytes_seen]( + minio::http::DataFunctionArgs a) -> bool { + ssize_t n = write_cb(userdata, a.datachunk.data(), a.datachunk.size()); + if (n < 0 || static_cast(n) != a.datachunk.size()) return false; + bytes_seen += n; + return true; + }; + } + + minio::s3::GetObjectResponse resp = holder->client->GetObject(args); + if (!resp) { + SetLastError(resp.Error().String()); + return MINIOCPP_ERR_GENERIC; + } + return buf != nullptr ? static_cast(size) : bytes_seen; +} + +void* miniocpp_alloc_aligned(size_t size) { + void* p = nullptr; + if (posix_memalign(&p, static_cast(getpagesize()), size) != 0) { + return nullptr; + } + return p; +} + +void miniocpp_free_aligned(void* p) { std::free(p); } + +int miniocpp_rdma_available(void) { + try { + CUObjIOOps ops{}; + cuObjClient probe(ops, CUOBJ_PROTO_RDMA_DC_V1); + return probe.isConnected() ? 1 : 0; + } catch (...) { + return 0; + } +} + +const char* miniocpp_last_error(void) { + return g_last_error.empty() ? nullptr : g_last_error.c_str(); +} + +} // extern "C" + +#endif // MINIO_CPP_RDMA diff --git a/src/client.cc b/src/client.cc index 5d3f9cdb..83491e41 100644 --- a/src/client.cc +++ b/src/client.cc @@ -388,130 +388,66 @@ ComposeObjectResponse Client::ComposeObject(ComposeObjectArgs args, } GetObjectResponse Client::GetObject(GetObjectArgs args) { - return BaseClient::GetObject(args); -} - -#ifdef MINIO_CPP_RDMA -GetObjectResponse Client::GetObject(GetObjectRDMAArgs args) { if (error::Error err = args.Validate()) { return GetObjectResponse(err); } - std::string region; - if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { - region = resp.region; - } else { - return GetObjectResponse(resp); - } - - const size_t size = *args.size; - - // Use the process-wide SharedRDMAClient() (per-process cuObjClient avoids - // the concurrent-ctor heap corruption we hit when each call built its - // own). Buffer registration is still per-call — keeping PutDescriptor - // in the PutRetry path is required by libcuobjclient to release - // per-transfer multipath slot state; caching the registration made - // throughput collapse. - cuObjClient& rdma_client = SharedRDMAClient(); - bool use_rdma = (rdma_client.cuMemObjGetDescriptor(args.buf, size) == 0); - - if (use_rdma) { - s3_rdma_client_ctx getCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .url = base_url_, - .region = region, - .op = CUOBJ_GET, - }; - - ssize_t ret = rdmaGetWithRetry(&rdma_client, &getCtx, args.buf, size); - rdma_client.cuMemObjPutDescriptor(args.buf); - - if (ret > 0) { - GetObjectResponse resp; - resp.etag = getCtx.etag; - return resp; +#ifdef MINIO_CPP_RDMA + if (args.buf != nullptr) { + std::string region; + if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { + region = resp.region; + } else { + return GetObjectResponse(resp); } - // ret < 0 (retries exhausted) or kRDMANotSupported (server declined): - // fall through to HTTP path. - } - // HTTP fallback path. Propagate the region resolved above onto targs so the - // fallback request is signed against the bucket's actual region instead of - // re-paying a GetRegion() roundtrip (and so a non-default region is honored - // when GET falls back). bucket/object were already being copied; matches - // the PutObject(PutObjectRDMAArgs) fallback below. - GetObjectArgs targs; - std::stringstream ss(std::ios_base::in | std::ios_base::out); - ss.rdbuf()->pubsetbuf(args.buf, size); + const size_t size = *args.size; - targs.bucket = args.bucket; - targs.object = args.object; - targs.region = region; - targs.datafunc = [&ss = ss](minio::http::DataFunctionArgs args) -> bool { - ss << args.datachunk; - return true; - }; + // Process-wide cuObjClient — see client.h for the race rationale. + cuObjClient& rdma_client = SharedRDMAClient(); + bool use_rdma = (rdma_client.cuMemObjGetDescriptor(args.buf, size) == 0); - return BaseClient::GetObject(targs); -} + if (use_rdma) { + s3_rdma_client_ctx getCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .url = base_url_, + .region = region, + .op = CUOBJ_GET, + }; -PutObjectResponse Client::PutObject(PutObjectRDMAArgs args) { - if (error::Error err = args.Validate()) { - return PutObjectResponse(err); - } + ssize_t ret = rdmaGetWithRetry(&rdma_client, &getCtx, args.buf, size); + rdma_client.cuMemObjPutDescriptor(args.buf); - std::string region; - if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { - region = resp.region; - } else { - return PutObjectResponse(resp); - } + if (ret > 0) { + GetObjectResponse resp; + resp.etag = getCtx.etag; + return resp; + } + // ret < 0 (retries exhausted) or kRDMANotSupported (server declined): + // fall through to HTTP-into-buffer path below. + } - const size_t size = *args.size; + // HTTP fallback: stream the body into the caller's buffer. + GetObjectArgs targs; + std::stringstream ss(std::ios_base::in | std::ios_base::out); + ss.rdbuf()->pubsetbuf(args.buf, size); - // See GetObject(GetObjectRDMAArgs) for rationale. - cuObjClient& rdma_client = SharedRDMAClient(); - bool use_rdma = (rdma_client.cuMemObjGetDescriptor(args.buf, size) == 0); - - if (use_rdma) { - s3_rdma_client_ctx putCtx = { - .provider = provider_, - .bucket = args.bucket, - .object = args.object, - .url = base_url_, - .region = region, - .op = CUOBJ_PUT, + targs.bucket = args.bucket; + targs.object = args.object; + targs.region = region; + targs.datafunc = [&ss = ss](minio::http::DataFunctionArgs args) -> bool { + ss << args.datachunk; + return true; }; - ssize_t ret = rdmaPutWithRetry(&rdma_client, &putCtx, args.buf, size); - rdma_client.cuMemObjPutDescriptor(args.buf); - - if (ret > 0) { - PutObjectResponse resp; - resp.etag = putCtx.etag; - return resp; - } - // ret < 0 (retries exhausted) or kRDMANotSupported (server declined): - // fall through to HTTP path. + return BaseClient::GetObject(targs); } +#endif - // HTTP fallback path. We must propagate bucket/object/region onto the - // PutObjectArgs — without them utils::CheckBucketName() rejects the call - // with "bucket name cannot be empty" before a single byte is sent. - std::stringstream ss(std::ios_base::in | std::ios_base::out); - ss.rdbuf()->pubsetbuf(args.buf, size); - - minio::s3::PutObjectArgs aargs(ss, static_cast(size), - 16 * 1024 * 1024UL); - aargs.bucket = args.bucket; - aargs.object = args.object; - aargs.region = region; - - return PutObject(aargs); + return BaseClient::GetObject(args); } -#endif // MINIO_CPP_RDMA PutObjectResponse Client::PutObject(PutObjectArgs args, std::string& upload_id, char* buf) { @@ -546,7 +482,7 @@ PutObjectResponse Client::PutObject(PutObjectArgs args, std::string& upload_id, } if (error::Error err = - utils::ReadPart(args.stream, buf, part_size, bytes_read)) { + utils::ReadPart(*args.stream, buf, part_size, bytes_read)) { return PutObjectResponse(err); } @@ -569,7 +505,7 @@ PutObjectResponse Client::PutObject(PutObjectArgs args, std::string& upload_id, } size_t n = 0; - if (error::Error err = utils::ReadPart(args.stream, b, size, n)) { + if (error::Error err = utils::ReadPart(*args.stream, b, size, n)) { return PutObjectResponse(err); } @@ -902,6 +838,56 @@ PutObjectResponse Client::PutObject(PutObjectArgs args) { "SSE operation must be performed over a secure connection"); } +#ifdef MINIO_CPP_RDMA + // Direct-buffer mode (was PutObject(PutObjectRDMAArgs)): caller supplied + // a pre-allocated, page-aligned buffer. Try RDMA, fall back to a single + // HTTP upload from the same buffer if RDMA declines. + if (args.buf != nullptr) { + std::string region; + if (GetRegionResponse resp = GetRegion(args.bucket, args.region)) { + region = resp.region; + } else { + return PutObjectResponse(resp); + } + + const size_t size = *args.size; + + cuObjClient& rdma_client = SharedRDMAClient(); + bool use_rdma = (rdma_client.cuMemObjGetDescriptor(args.buf, size) == 0); + + if (use_rdma) { + s3_rdma_client_ctx putCtx = { + .provider = provider_, + .bucket = args.bucket, + .object = args.object, + .url = base_url_, + .region = region, + .op = CUOBJ_PUT, + }; + + ssize_t ret = rdmaPutWithRetry(&rdma_client, &putCtx, args.buf, size); + rdma_client.cuMemObjPutDescriptor(args.buf); + + if (ret > 0) { + PutObjectResponse resp; + resp.etag = putCtx.etag; + return resp; + } + // ret < 0 / kRDMANotSupported: fall through to HTTP-from-buffer. + } + + // HTTP fallback from the same buffer (single-shot, not multipart). + std::stringstream ss(std::ios_base::in | std::ios_base::out); + ss.rdbuf()->pubsetbuf(args.buf, size); + + PutObjectArgs http_args(ss, static_cast(size), 16 * 1024 * 1024L); + http_args.bucket = args.bucket; + http_args.object = args.object; + http_args.region = region; + return PutObject(http_args); + } +#endif + char* buf; int res = posix_memalign( (void**)&buf, getpagesize(), From 509a723b8ebedbe880072b6b7187739a4ce9534d Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Fri, 22 May 2026 01:30:29 -0700 Subject: [PATCH 24/25] examples: switch GetPutRDMA to libcudart + primary CUDA context MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Switches the GPU-buffer demo from libcuda's driver API (cuCtxCreate + cuMemAlloc) to libcudart's runtime API (cudaSetDevice + cudaMalloc), via dlopen so the SDK build itself still has no cudart link-time dependency. cudaMalloc runs cudart's static initialization, retrieves the device's primary context, and registers the allocation with cudart's internal P2P bookkeeping — none of which cuMemAlloc on a fresh cuCtxCreate'd context does. This is the idiomatic pattern for GPUDirect Storage / RDMA workloads regardless of whether it ultimately unblocks any specific end-to-end RDMA flow. --- .github/workflows/linters.yml | 6 +- CMakeLists.txt | 4 +- examples/GPUHostDisk.cc | 12 ++-- examples/GetPutRDMA.cc | 106 +++++++++++++++++----------------- include/miniocpp/c_api.h | 18 ++---- include/miniocpp/http.h | 4 +- include/miniocpp/rdma.h | 6 +- src/args.cc | 3 +- src/baseclient.cc | 8 +-- src/c_api.cc | 17 +++--- 10 files changed, 88 insertions(+), 96 deletions(-) diff --git a/.github/workflows/linters.yml b/.github/workflows/linters.yml index 6355becc..ced057bf 100644 --- a/.github/workflows/linters.yml +++ b/.github/workflows/linters.yml @@ -33,8 +33,8 @@ jobs: - name: Install dependencies run: | - sudo apt -qy install clang-format-18 - clang-format-18 --version + sudo apt -qy install clang-format-20 + clang-format-20 --version - name: Version Check shell: bash @@ -44,4 +44,4 @@ jobs: - name: Coding Style Check shell: bash working-directory: minio-cpp - run: CLANG_FORMAT=clang-format-18 ./check-style.sh + run: CLANG_FORMAT=clang-format-20 ./check-style.sh diff --git a/CMakeLists.txt b/CMakeLists.txt index fd137669..eaf6b0ff 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -35,7 +35,9 @@ project(miniocpp include(GNUInstallDirs) include(CheckIncludeFiles) include(CMakePackageConfigHelpers) -include("${VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake") +if(NOT DEFINED CMAKE_TOOLCHAIN_FILE AND DEFINED ENV{VCPKG_ROOT}) + include("$ENV{VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake") +endif() option(MINIO_CPP_TEST "Build tests" OFF) option(MINIO_CPP_MAKE_DOC "Build documentation" OFF) diff --git a/examples/GPUHostDisk.cc b/examples/GPUHostDisk.cc index 596dcf23..eeef6b97 100644 --- a/examples/GPUHostDisk.cc +++ b/examples/GPUHostDisk.cc @@ -49,12 +49,12 @@ struct Cuda { lib = dlopen("libcuda.so.1", RTLD_LAZY | RTLD_GLOBAL); if (lib == nullptr) lib = dlopen("libcuda.so", RTLD_LAZY | RTLD_GLOBAL); if (lib == nullptr) return false; -#define SYM(name, versioned) \ - do { \ - void *s = dlsym(lib, versioned); \ - if (s == nullptr) s = dlsym(lib, #name); \ - if (s == nullptr) return false; \ - name = reinterpret_cast(s); \ +#define SYM(name, versioned) \ + do { \ + void *s = dlsym(lib, versioned); \ + if (s == nullptr) s = dlsym(lib, #name); \ + if (s == nullptr) return false; \ + name = reinterpret_cast(s); \ } while (0) SYM(cuInit, "cuInit"); SYM(cuDeviceGet, "cuDeviceGet"); diff --git a/examples/GetPutRDMA.cc b/examples/GetPutRDMA.cc index 870ba6d3..ee92f0ed 100644 --- a/examples/GetPutRDMA.cc +++ b/examples/GetPutRDMA.cc @@ -54,45 +54,47 @@ // transitively via . namespace { +// Use libcudart (CUDA Runtime API) rather than libcuda (driver API). +// cudaMalloc implicitly warms the runtime, retrieves the primary context, +// and performs the cudart-side P2P / GPUDirect RDMA initialization that +// the pure driver API path (cuCtxCreate + cuMemAlloc) skips. struct Cuda { void *lib = nullptr; - CUresult (*cuInit)(unsigned); - CUresult (*cuDeviceGet)(CUdevice *, int); - CUresult (*cuCtxCreate)(CUcontext *, unsigned, CUdevice); - CUresult (*cuCtxDestroy)(CUcontext); - CUresult (*cuMemAlloc)(CUdeviceptr *, size_t); - CUresult (*cuMemFree)(CUdeviceptr); - CUresult (*cuMemsetD8)(CUdeviceptr, unsigned char, size_t); - CUresult (*cuMemcpyDtoH)(void *, CUdeviceptr, size_t); - CUresult (*cuCtxSynchronize)(); + // signature: returns int cudaError_t (0 == cudaSuccess) + int (*cudaSetDevice)(int); + int (*cudaMalloc)(void **, size_t); + int (*cudaFree)(void *); + int (*cudaMemset)(void *, int, size_t); + int (*cudaMemcpy)(void *, const void *, size_t, + int); // kind=cudaMemcpyDeviceToHost=2 + int (*cudaDeviceSynchronize)(); + int (*cudaDeviceFlushGPUDirectRDMAWrites)(int target, int scope); bool load() { - lib = dlopen("libcuda.so.1", RTLD_LAZY | RTLD_GLOBAL); - if (lib == nullptr) lib = dlopen("libcuda.so", RTLD_LAZY | RTLD_GLOBAL); + lib = dlopen("libcudart.so.13", RTLD_LAZY | RTLD_GLOBAL); + if (lib == nullptr) + lib = dlopen("libcudart.so.12", RTLD_LAZY | RTLD_GLOBAL); + if (lib == nullptr) lib = dlopen("libcudart.so", RTLD_LAZY | RTLD_GLOBAL); if (lib == nullptr) { - std::cerr << "dlopen libcuda.so failed: " << dlerror() << std::endl; + std::cerr << "dlopen libcudart.so failed: " << dlerror() << std::endl; return false; } -#define SYM(name, versioned) \ - do { \ - void *s = dlsym(lib, versioned); \ - if (s == nullptr) s = dlsym(lib, #name); \ - if (s == nullptr) { \ - std::cerr << "dlsym " << versioned << " failed: " \ - << dlerror() << std::endl; \ - return false; \ - } \ - name = reinterpret_cast(s); \ +#define SYM(name, optional) \ + do { \ + void *s = dlsym(lib, #name); \ + if (s == nullptr && !(optional)) { \ + std::cerr << "dlsym " #name " failed: " << dlerror() << std::endl; \ + return false; \ + } \ + name = reinterpret_cast(s); \ } while (0) - SYM(cuInit, "cuInit"); - SYM(cuDeviceGet, "cuDeviceGet"); - SYM(cuCtxCreate, "cuCtxCreate_v2"); - SYM(cuCtxDestroy, "cuCtxDestroy_v2"); - SYM(cuMemAlloc, "cuMemAlloc_v2"); - SYM(cuMemFree, "cuMemFree_v2"); - SYM(cuMemsetD8, "cuMemsetD8_v2"); - SYM(cuMemcpyDtoH, "cuMemcpyDtoH_v2"); - SYM(cuCtxSynchronize, "cuCtxSynchronize"); + SYM(cudaSetDevice, false); + SYM(cudaMalloc, false); + SYM(cudaFree, false); + SYM(cudaMemset, false); + SYM(cudaMemcpy, false); + SYM(cudaDeviceSynchronize, false); + SYM(cudaDeviceFlushGPUDirectRDMAWrites, true); // available since CUDA 11.3 #undef SYM return true; } @@ -111,8 +113,9 @@ int main(int argc, char *argv[]) { bool gpu_enabled = false; if (argc <= 1) { - printf("usage: %s [size] [gpu]\n", - argv[0]); + printf( + "usage: %s [size] [gpu]\n", + argv[0]); exit(1); } @@ -129,33 +132,28 @@ int main(int argc, char *argv[]) { std::cout << bufsize << " " << std::endl; Cuda cuda; - CUcontext cu_ctx = nullptr; if (gpu_enabled) { if (!cuda.load()) { - std::cerr << "CUDA driver (libcuda.so) unavailable — install NVIDIA " - "driver or omit 'gpu'" + std::cerr << "CUDA runtime (libcudart.so) unavailable — install CUDA " + "Toolkit or omit 'gpu'" << std::endl; exit(1); } - if (cuda.cuInit(0) != 0) { - std::cerr << "cuInit failed" << std::endl; + if (cuda.cudaSetDevice(0) != 0) { + std::cerr << "cudaSetDevice failed" << std::endl; exit(1); } - CUdevice dev = 0; - if (cuda.cuDeviceGet(&dev, 0) != 0) { - std::cerr << "cuDeviceGet failed" << std::endl; + void *dptr_void = nullptr; + if (cuda.cudaMalloc(&dptr_void, bufsize) != 0) { + std::cerr << "cudaMalloc failed" << std::endl; exit(1); } - if (cuda.cuCtxCreate(&cu_ctx, 0, dev) != 0) { - std::cerr << "cuCtxCreate failed" << std::endl; + dptr = reinterpret_cast(dptr_void); + if (cuda.cudaMemset(dptr_void, 'A', bufsize) != 0) { + std::cerr << "cudaMemset failed" << std::endl; exit(1); } - if (cuda.cuMemAlloc(&dptr, bufsize) != 0) { - std::cerr << "cuMemAlloc failed" << std::endl; - exit(1); - } - cuda.cuMemsetD8(dptr, 'A', bufsize); - cuda.cuCtxSynchronize(); + cuda.cudaDeviceSynchronize(); bufptr = reinterpret_cast(dptr); std::cout << "GPU enabled" << std::endl; } else { @@ -185,8 +183,8 @@ int main(int argc, char *argv[]) { minio::s3::GetObjectArgs args; if (gpu_enabled) { - cuda.cuMemsetD8(dptr, 'U', bufsize); - cuda.cuCtxSynchronize(); + cuda.cudaMemset(reinterpret_cast(dptr), 'U', bufsize); + cuda.cudaDeviceSynchronize(); } args.buf = bufptr; args.size = bufsize; @@ -203,7 +201,8 @@ int main(int argc, char *argv[]) { char *hostptr = (char *)malloc(bufsize); if (gpu_enabled) { - cuda.cuMemcpyDtoH(hostptr, dptr, bufsize); + cuda.cudaMemcpy(hostptr, reinterpret_cast(dptr), bufsize, + 2); // cudaMemcpyDeviceToHost=2 } else { memcpy(hostptr, bufptr, bufsize); } @@ -219,8 +218,7 @@ int main(int argc, char *argv[]) { free(hostptr); if (gpu_enabled) { - cuda.cuMemFree(dptr); - cuda.cuCtxDestroy(cu_ctx); + cuda.cudaFree(reinterpret_cast(dptr)); } else { free(bufptr); } diff --git a/include/miniocpp/c_api.h b/include/miniocpp/c_api.h index f983ba4b..b2c02853 100644 --- a/include/miniocpp/c_api.h +++ b/include/miniocpp/c_api.h @@ -55,12 +55,9 @@ typedef ssize_t (*miniocpp_write_cb)(void* userdata, const char* buf, // Construct a client. region/session_token may be NULL/"". // Returned pointer is owned by the caller; release with miniocpp_client_free. -MINIOCPP_API miniocpp_client* miniocpp_client_new(const char* endpoint, - const char* region, - const char* access_key, - const char* secret_key, - const char* session_token, - int use_https); +MINIOCPP_API miniocpp_client* miniocpp_client_new( + const char* endpoint, const char* region, const char* access_key, + const char* secret_key, const char* session_token, int use_https); MINIOCPP_API void miniocpp_client_free(miniocpp_client* client); @@ -70,20 +67,17 @@ MINIOCPP_API void miniocpp_client_free(miniocpp_client* client); // Writes the CRC64NVME checksum (base64, ~32 chars) into checksum_out if // non-NULL. Returns bytes transferred on success, or one of MINIOCPP_ERR_*. MINIOCPP_API ssize_t miniocpp_put_object(miniocpp_client* client, - const char* bucket, - const char* object, + const char* bucket, const char* object, void* buf, size_t size, miniocpp_read_cb read_cb, - void* userdata, - char etag_out[64], + void* userdata, char etag_out[64], char checksum_out[64]); // GET. When `buf` is non-NULL, attempts RDMA into the caller's buffer with // HTTP-into-buf fallback; `write_cb` is ignored. When `buf` is NULL, streams // the body through `write_cb`. Returns bytes transferred or MINIOCPP_ERR_*. MINIOCPP_API ssize_t miniocpp_get_object(miniocpp_client* client, - const char* bucket, - const char* object, + const char* bucket, const char* object, void* buf, size_t size, miniocpp_write_cb write_cb, void* userdata); diff --git a/include/miniocpp/http.h b/include/miniocpp/http.h index 91c0f24a..4596ed08 100644 --- a/include/miniocpp/http.h +++ b/include/miniocpp/http.h @@ -53,9 +53,9 @@ struct Url { host(std::move(host)), port(port), path(std::move(path)), - query_string(std::move(query_string)){}; + query_string(std::move(query_string)) {}; explicit Url(bool https, std::string host, unsigned int port) - : https(https), host(std::move(host)), port(port){}; + : https(https), host(std::move(host)), port(port) {}; ~Url() = default; diff --git a/include/miniocpp/rdma.h b/include/miniocpp/rdma.h index ff3bcbc8..3101b19a 100644 --- a/include/miniocpp/rdma.h +++ b/include/miniocpp/rdma.h @@ -89,7 +89,8 @@ inline static std::string parseClientNICFromToken(const char* token) { for (int i = 0; i < 20; ++i) { if (tail[i] != '0') return {}; } - if (tail[20] != 'f' || tail[21] != 'f' || tail[22] != 'f' || tail[23] != 'f') { + if (tail[20] != 'f' || tail[21] != 'f' || tail[22] != 'f' || + tail[23] != 'f') { return {}; } unsigned int a, b, c, d; @@ -204,8 +205,7 @@ inline static ssize_t rdmaPut(s3_rdma_client_ctx_t* sctx, const char* token, return -1; } - std::string resp_checksum = - res.headers.GetFront("x-amz-checksum-crc64nvme"); + std::string resp_checksum = res.headers.GetFront("x-amz-checksum-crc64nvme"); if (!resp_checksum.empty()) { sctx->checksum = resp_checksum; } diff --git a/src/args.cc b/src/args.cc index e8d06599..cf2af4a7 100644 --- a/src/args.cc +++ b/src/args.cc @@ -231,8 +231,7 @@ error::Error GetObjectArgs::Validate() const { const bool has_datafunc = (datafunc != nullptr); const bool has_buf = (buf != nullptr); if (has_datafunc == has_buf) { - return error::Error( - "exactly one of datafunc or buf must be set"); + return error::Error("exactly one of datafunc or buf must be set"); } if (has_buf && !size.has_value()) { return error::Error("size must be set when buf is set"); diff --git a/src/baseclient.cc b/src/baseclient.cc index 45f3b6f3..3c2e2ed9 100644 --- a/src/baseclient.cc +++ b/src/baseclient.cc @@ -1383,8 +1383,8 @@ PutObjectResponse BaseClient::PutObject(PutObjectApiArgs args) { .op = CUOBJ_PUT, }; - ssize_t ret = rdmaPutWithRetry(args.rdmaclient, &putCtx, args.buf, - args.size); + ssize_t ret = + rdmaPutWithRetry(args.rdmaclient, &putCtx, args.buf, args.size); if (ret > 0) { PutObjectResponse resp; resp.etag = putCtx.etag; @@ -1968,8 +1968,8 @@ UploadPartResponse BaseClient::UploadPart(UploadPartArgs args) { .checksum = args.checksum_crc64nvme, }; - ssize_t ret = rdmaPutWithRetry(args.rdmaclient, &putCtx, args.buf, - args.part_size); + ssize_t ret = + rdmaPutWithRetry(args.rdmaclient, &putCtx, args.buf, args.part_size); if (ret > 0) { UploadPartResponse resp; resp.etag = putCtx.etag; diff --git a/src/c_api.cc b/src/c_api.cc index 10b209f9..dff64e06 100644 --- a/src/c_api.cc +++ b/src/c_api.cc @@ -13,6 +13,8 @@ #include "miniocpp/c_api.h" +#include + #include #include #include @@ -20,7 +22,6 @@ #include #include #include -#include #include "miniocpp/args.h" #include "miniocpp/client.h" @@ -70,8 +71,7 @@ extern "C" { miniocpp_client* miniocpp_client_new(const char* endpoint, const char* region, const char* access_key, const char* secret_key, - const char* session_token, - int use_https) { + const char* session_token, int use_https) { if (endpoint == nullptr || access_key == nullptr || secret_key == nullptr) { SetLastError("endpoint, access_key, and secret_key are required"); return nullptr; @@ -81,10 +81,9 @@ miniocpp_client* miniocpp_client_new(const char* endpoint, const char* region, holder->base_url = minio::s3::BaseUrl(endpoint, use_https != 0, region != nullptr ? region : ""); holder->provider = std::make_unique( - access_key, secret_key, - session_token != nullptr ? session_token : ""); - holder->client = std::make_unique(holder->base_url, - holder->provider.get()); + access_key, secret_key, session_token != nullptr ? session_token : ""); + holder->client = std::make_unique( + holder->base_url, holder->provider.get()); return reinterpret_cast(holder.release()); } catch (const std::exception& e) { SetLastError(std::string("client construction failed: ") + e.what()); @@ -170,8 +169,8 @@ ssize_t miniocpp_get_object(miniocpp_client* c, const char* bucket, args.buf = static_cast(buf); args.size = size; } else { - args.datafunc = [write_cb, userdata, &bytes_seen]( - minio::http::DataFunctionArgs a) -> bool { + args.datafunc = [write_cb, userdata, + &bytes_seen](minio::http::DataFunctionArgs a) -> bool { ssize_t n = write_cb(userdata, a.datachunk.data(), a.datachunk.size()); if (n < 0 || static_cast(n) != a.datachunk.size()) return false; bytes_seen += n; From 2074462b962415466a6e427924604a4fb1b9b725 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Mon, 25 May 2026 19:56:55 -0700 Subject: [PATCH 25/25] ci: Linux arm64 build matrix + per-arch RDMA libs + AIStor switch - Adds Linux/arm64 (ubuntu-24.04-arm) to the existing CI matrix alongside Linux/amd64, parametrized via matrix.config.arch. - Splits vendor/cuobj/lib/ into x86_64/ and aarch64/ subdirs and adds the aarch64 cuFile / cuObjClient / cuObjServer libraries (cuObject resiliency_v3, version 1.2.0 / cuFile 1.18.0). - CMake selects the right per-arch subdir from CMAKE_SYSTEM_PROCESSOR and verifies the cuObj client .so is present before linking. configure.sh drops the hardcoded -L flag. - New workflow .github/workflows/ci-rdma.yml builds miniocpp with MINIO_CPP_ENABLE_RDMA=ON on Linux amd64 and arm64. Build-only, no server / no tests. - Linux CI downloads the AIStor binary from dl.min.io/aistor/minio/release/linux-${arch}/ and passes the MINIO_LICENSE secret as an env var so the free-tier license activates at runtime. macOS and Windows continue to use community minio. --- .github/aistor-free-license.jwt | 1 + .github/workflows/ci-rdma.yml | 67 ++++++++++++++++++ .github/workflows/ci.yml | 14 +++- CMakeLists.txt | 13 +++- configure.sh | 2 +- examples/PutObject.cc | 1 - src/client.cc | 35 +++++++-- vendor/cuobj/lib/aarch64/libcufile.so | 1 + vendor/cuobj/lib/{ => aarch64}/libcufile.so.0 | 0 vendor/cuobj/lib/aarch64/libcufile.so.1.18.0 | Bin 0 -> 3383712 bytes vendor/cuobj/lib/aarch64/libcufile_rdma.so | 1 + .../lib/{ => aarch64}/libcufile_rdma.so.1 | 0 .../lib/aarch64/libcufile_rdma.so.1.18.0 | Bin 0 -> 139440 bytes vendor/cuobj/lib/aarch64/libcuobjclient.so | 1 + .../lib/{ => aarch64}/libcuobjclient.so.1 | 0 .../cuobj/lib/aarch64/libcuobjclient.so.1.2.0 | Bin 0 -> 441280 bytes vendor/cuobj/lib/aarch64/libcuobjserver.so | 1 + .../lib/{ => aarch64}/libcuobjserver.so.1 | 0 .../cuobj/lib/aarch64/libcuobjserver.so.1.2.0 | Bin 0 -> 795448 bytes vendor/cuobj/lib/{ => x86_64}/libcufile.so | 0 .../{libcufile.so.1 => x86_64/libcufile.so.0} | 0 vendor/cuobj/lib/x86_64/libcufile.so.1 | 1 + .../lib/{ => x86_64}/libcufile.so.1.18.0 | Bin .../cuobj/lib/{ => x86_64}/libcufile_rdma.so | 0 vendor/cuobj/lib/x86_64/libcufile_rdma.so.1 | 1 + .../lib/{ => x86_64}/libcufile_rdma.so.1.18.0 | Bin .../cuobj/lib/{ => x86_64}/libcuobjclient.so | 0 vendor/cuobj/lib/x86_64/libcuobjclient.so.1 | 1 + .../lib/{ => x86_64}/libcuobjclient.so.1.2.0 | Bin .../cuobj/lib/{ => x86_64}/libcuobjserver.so | 0 vendor/cuobj/lib/x86_64/libcuobjserver.so.1 | 1 + .../lib/{ => x86_64}/libcuobjserver.so.1.2.0 | Bin 32 files changed, 129 insertions(+), 12 deletions(-) create mode 100644 .github/aistor-free-license.jwt create mode 100644 .github/workflows/ci-rdma.yml create mode 120000 vendor/cuobj/lib/aarch64/libcufile.so rename vendor/cuobj/lib/{ => aarch64}/libcufile.so.0 (100%) create mode 100644 vendor/cuobj/lib/aarch64/libcufile.so.1.18.0 create mode 120000 vendor/cuobj/lib/aarch64/libcufile_rdma.so rename vendor/cuobj/lib/{ => aarch64}/libcufile_rdma.so.1 (100%) create mode 100644 vendor/cuobj/lib/aarch64/libcufile_rdma.so.1.18.0 create mode 120000 vendor/cuobj/lib/aarch64/libcuobjclient.so rename vendor/cuobj/lib/{ => aarch64}/libcuobjclient.so.1 (100%) create mode 100755 vendor/cuobj/lib/aarch64/libcuobjclient.so.1.2.0 create mode 120000 vendor/cuobj/lib/aarch64/libcuobjserver.so rename vendor/cuobj/lib/{ => aarch64}/libcuobjserver.so.1 (100%) create mode 100755 vendor/cuobj/lib/aarch64/libcuobjserver.so.1.2.0 rename vendor/cuobj/lib/{ => x86_64}/libcufile.so (100%) rename vendor/cuobj/lib/{libcufile.so.1 => x86_64/libcufile.so.0} (100%) create mode 120000 vendor/cuobj/lib/x86_64/libcufile.so.1 rename vendor/cuobj/lib/{ => x86_64}/libcufile.so.1.18.0 (100%) rename vendor/cuobj/lib/{ => x86_64}/libcufile_rdma.so (100%) create mode 120000 vendor/cuobj/lib/x86_64/libcufile_rdma.so.1 rename vendor/cuobj/lib/{ => x86_64}/libcufile_rdma.so.1.18.0 (100%) rename vendor/cuobj/lib/{ => x86_64}/libcuobjclient.so (100%) create mode 120000 vendor/cuobj/lib/x86_64/libcuobjclient.so.1 rename vendor/cuobj/lib/{ => x86_64}/libcuobjclient.so.1.2.0 (100%) rename vendor/cuobj/lib/{ => x86_64}/libcuobjserver.so (100%) create mode 120000 vendor/cuobj/lib/x86_64/libcuobjserver.so.1 rename vendor/cuobj/lib/{ => x86_64}/libcuobjserver.so.1.2.0 (100%) diff --git a/.github/aistor-free-license.jwt b/.github/aistor-free-license.jwt new file mode 100644 index 00000000..8e712168 --- /dev/null +++ b/.github/aistor-free-license.jwt @@ -0,0 +1 @@ +eyJhbGciOiJFUzM4NCIsInR5cCI6IkpXVCJ9.eyJhaWQiOjAsImNhcCI6MCwiaWF0IjoxLjc3NjAzODc4MDk2OTk4NjY0OGU5LCJpc3MiOiJzdWJuZXRAbWluLmlvIiwibGlkIjoiNDgzNzc4MmQtNjNiZi00NDIxLWFlNWYtMTYwOTEyOTFiY2M3Iiwib3JnIjoiIiwicGxhbiI6IkZSRUUiLCJzdWIiOiJlY28rcGxheUBtaW4uaW8iLCJ0cmlhbCI6ZmFsc2V9.Rt75WVubPqdI08pJLBrgL0nzvseNDE_Og3i45GkM1vnykLpBLFjDYjsiJF4dygvmLlpeodLRD_s2wkdcLHS_hBZ6vsQxfA06JQGu3L_KkfiaUEWw43oo4MI9cUmVll48 diff --git a/.github/workflows/ci-rdma.yml b/.github/workflows/ci-rdma.yml new file mode 100644 index 00000000..e700297a --- /dev/null +++ b/.github/workflows/ci-rdma.yml @@ -0,0 +1,67 @@ +name: MinIO C++ Cmake (RDMA) + +on: + push: + branches: [ main ] + pull_request: + branches: [ main ] + +concurrency: + group: ${{ github.workflow }}-${{ github.head_ref }} + cancel-in-progress: true + +permissions: + contents: read + +jobs: + build: + strategy: + fail-fast: false + matrix: + config: + - { + name: "Ubuntu_RDMA_GCC_amd64", + os: ubuntu-latest, + arch: "amd64", + build_type: "Release", + } + - { + name: "Ubuntu_RDMA_GCC_arm64", + os: ubuntu-24.04-arm, + arch: "arm64", + build_type: "Release", + } + + name: ${{ matrix.config.name }} + runs-on: ${{ matrix.config.os }} + + steps: + - name: Checkout minio-cpp + uses: actions/checkout@v4 + with: + path: "minio-cpp" + + - name: Checkout vcpkg + uses: actions/checkout@v4 + with: + repository: microsoft/vcpkg + path: "vcpkg" + + - name: Install dependencies + run: | + sudo apt-get -qy update + sudo apt-get -qy install cmake libibverbs-dev librdmacm-dev libnuma-dev + cmake --version + + - name: Configure and Build + shell: bash + run: | + ./vcpkg/bootstrap-vcpkg.sh + cd minio-cpp + ../vcpkg/vcpkg install + cmake . -B ./build \ + -DCMAKE_BUILD_TYPE=${{matrix.config.build_type}} \ + -DCMAKE_TOOLCHAIN_FILE=../vcpkg/scripts/buildsystems/vcpkg.cmake \ + -DMINIO_CPP_TEST:BOOL=ON \ + -DMINIO_CPP_ENABLE_RDMA:BOOL=ON + cmake --build ./build --config ${{matrix.config.build_type}} -j 4 diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 0408efd3..4cc4db3e 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -24,6 +24,15 @@ jobs: - { name: "Ubuntu_Latest_GCC", os: ubuntu-latest, + arch: "amd64", + build_type: "Release", + cc: "gcc", + cxx: "g++" + } + - { + name: "Ubuntu_Latest_GCC_arm64", + os: ubuntu-24.04-arm, + arch: "arm64", build_type: "Release", cc: "gcc", cxx: "g++" @@ -66,11 +75,9 @@ jobs: - name: Install dependencies if Ubuntu if: startsWith(matrix.config.name, 'Ubuntu_Latest_GCC') run: | - wget --quiet -O - https://apt.llvm.org/llvm-snapshot.gpg.key | sudo apt-key add - - echo 'deb http://apt.llvm.org/focal/ llvm-toolchain-focal-18 main' | sudo tee -a /etc/apt/sources.list sudo apt-get -qy update sudo apt-get -qy install cmake - wget --quiet https://dl.min.io/server/minio/release/linux-amd64/minio + wget --quiet https://dl.min.io/aistor/minio/release/linux-${{ matrix.config.arch }}/minio chmod +x minio cmake --version ./minio --version @@ -107,6 +114,7 @@ jobs: cp ./minio-cpp/tests/public.crt ./minio-cpp/tests/private.key ~/.minio/certs/ sudo cp ./minio-cpp/tests/public.crt /usr/local/share/ca-certificates/ sudo update-ca-certificates + export MINIO_LICENSE=$(cat ./minio-cpp/.github/aistor-free-license.jwt) MINIO_CI_CD=true ./minio server /tmp/test-xl/{1...4}/ & sleep 10 diff --git a/CMakeLists.txt b/CMakeLists.txt index eaf6b0ff..97f3f818 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -67,8 +67,19 @@ if (MINIO_CPP_ENABLE_RDMA) if (WIN32 OR APPLE) message(FATAL_ERROR "MINIO_CPP_ENABLE_RDMA is only supported on Linux") endif() + if (CMAKE_SYSTEM_PROCESSOR MATCHES "^(x86_64|AMD64|amd64)$") + set(MINIO_CPP_RDMA_ARCH "x86_64") + elseif (CMAKE_SYSTEM_PROCESSOR MATCHES "^(aarch64|arm64)$") + set(MINIO_CPP_RDMA_ARCH "aarch64") + else() + message(FATAL_ERROR "MINIO_CPP_ENABLE_RDMA: unsupported CMAKE_SYSTEM_PROCESSOR '${CMAKE_SYSTEM_PROCESSOR}'") + endif() + set(MINIO_CPP_RDMA_LIBDIR "${CMAKE_SOURCE_DIR}/vendor/cuobj/lib/${MINIO_CPP_RDMA_ARCH}") + if (NOT EXISTS "${MINIO_CPP_RDMA_LIBDIR}/libcuobjclient.so") + message(FATAL_ERROR "MINIO_CPP_ENABLE_RDMA: ${MINIO_CPP_RDMA_ARCH} cuObj client libs not vendored at ${MINIO_CPP_RDMA_LIBDIR}") + endif() list(APPEND MINIO_CPP_INCLUDES ${CMAKE_SOURCE_DIR}/vendor/cuobj/include) - list(APPEND MINIO_CPP_LIBS "-Bdynamic -L${CMAKE_SOURCE_DIR}/vendor/cuobj/lib -lcufile -lpthread -lnuma -ldl -libverbs -lrdmacm -lrt -lcuobjclient") + list(APPEND MINIO_CPP_LIBS "-Bdynamic -L${MINIO_CPP_RDMA_LIBDIR} -lcufile -lpthread -lnuma -ldl -libverbs -lrdmacm -lrt -lcuobjclient") endif() # Dependencies diff --git a/configure.sh b/configure.sh index ba395901..3e7289a3 100755 --- a/configure.sh +++ b/configure.sh @@ -3,7 +3,7 @@ set -x SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)" -BUILD_OPTIONS="-DCMAKE_EXPORT_COMPILE_COMMANDS=ON -DBUILD_SHARED_LIBS=ON -DCMAKE_SHARED_LINKER_FLAGS=-L${SCRIPT_DIR}/vendor/cuobj/lib/" +BUILD_OPTIONS="-DCMAKE_EXPORT_COMPILE_COMMANDS=ON -DBUILD_SHARED_LIBS=ON" if [ -n "$VCPKG_ROOT" ]; then BUILD_OPTIONS="${BUILD_OPTIONS} -DVCPKG_ROOT=${VCPKG_ROOT}" diff --git a/examples/PutObject.cc b/examples/PutObject.cc index 9423b88e..e3e481b4 100644 --- a/examples/PutObject.cc +++ b/examples/PutObject.cc @@ -20,7 +20,6 @@ #include #include #include -#include #include #include diff --git a/src/client.cc b/src/client.cc index 83491e41..e60277c8 100644 --- a/src/client.cc +++ b/src/client.cc @@ -17,7 +17,11 @@ #include "miniocpp/client.h" +#ifdef _MSC_VER +#include +#else #include +#endif #include #include @@ -46,6 +50,25 @@ namespace minio::s3 { +namespace { + +#ifdef _MSC_VER +inline size_t GetPageSize() { return 4096; } +inline int AlignedAlloc(void** out, size_t alignment, size_t size) { + *out = _aligned_malloc(size, alignment); + return *out ? 0 : -1; +} +inline void AlignedFree(void* p) { _aligned_free(p); } +#else +inline size_t GetPageSize() { return static_cast(getpagesize()); } +inline int AlignedAlloc(void** out, size_t alignment, size_t size) { + return posix_memalign(out, alignment, size); +} +inline void AlignedFree(void* p) { free(p); } +#endif + +} // namespace + ListObjectsResult::ListObjectsResult(error::Error err) : failed_(true) { this->resp_.contents.push_back(Item(std::move(err))); this->itr_ = resp_.contents.begin(); @@ -889,9 +912,9 @@ PutObjectResponse Client::PutObject(PutObjectArgs args) { #endif char* buf; - int res = posix_memalign( - (void**)&buf, getpagesize(), - (args.part_count > 0) ? args.part_size : args.part_size + 1); + int res = + AlignedAlloc((void**)&buf, GetPageSize(), + (args.part_count > 0) ? args.part_size : args.part_size + 1); if (res) { return error::make( "unable to allocate system memory with alignment"); @@ -906,7 +929,7 @@ PutObjectResponse Client::PutObject(PutObjectArgs args) { if (rdma_client.isConnected()) { res = rdma_client.cuMemObjGetDescriptor(buf, args.part_size); if (res) { - free(buf); + AlignedFree(buf); return error::make("unable to register RDMA buffer"); } } @@ -929,13 +952,13 @@ PutObjectResponse Client::PutObject(PutObjectArgs args) { if (rdma_client.isConnected()) { res = rdma_client.cuMemObjPutDescriptor(buf); if (res) { - free(buf); + AlignedFree(buf); return error::make("unable to deregister RDMA buffer"); } } #endif - free(buf); + AlignedFree(buf); return resp; } diff --git a/vendor/cuobj/lib/aarch64/libcufile.so b/vendor/cuobj/lib/aarch64/libcufile.so new file mode 120000 index 00000000..8f90c7f0 --- /dev/null +++ b/vendor/cuobj/lib/aarch64/libcufile.so @@ -0,0 +1 @@ +libcufile.so.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcufile.so.0 b/vendor/cuobj/lib/aarch64/libcufile.so.0 similarity index 100% rename from vendor/cuobj/lib/libcufile.so.0 rename to vendor/cuobj/lib/aarch64/libcufile.so.0 diff --git a/vendor/cuobj/lib/aarch64/libcufile.so.1.18.0 b/vendor/cuobj/lib/aarch64/libcufile.so.1.18.0 new file mode 100644 index 0000000000000000000000000000000000000000..e54a90ce498cf192c59cc340c3bd85464aedcd26 GIT binary patch literal 3383712 zcmeF4349yH)xb9=h7b_9fdB#mm|H&LD4fdS#3q-B4Hzg$vMgI7vLz(hk%5A^4Fw_y z1aS)pV8W$B0CN-sgd%Qnlo~=ooOMgervhyal=gcw@2!sKUB`ApOZ%&mwY2}8ef#Fk zn{#Jp˱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 <+L% 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
    5$cpN~S=*N;1$rr`rC8`G=6@NzY_#4ju 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�E79i&IMRU zo?vxZTW)-vIk#ZOnB+j8w#NV7EM#})xd6+Nb2;!k^{H!ye`{h#B!cGx2*1YGg~xwL ze!|H~3c=G42-P<#x2XenmEA>r_3F8p=r^_8q+>3UzuSmaa2`bs0mGW|jK&5*nZ zKOf)<=4n)qN0AjhjZOQ&BaeuW#-!IX-|!G=x{pok?AY}7mlVI7Kd8>04{(O$-0HMH z=oIqT*tCOu?bx)EJjB<*vFQmaD`oz*(npL<-ypB3vFQfUBF3iw5DnWm%pdfOXc1%6 zRieRpKMOA9Sk48}|AY@PTl4nL==MDPg8R=sEaOc$2+i z$D}pHvv>=h4{(n10bdgc!|dYId2jI+eLjG zDQA^m&L@!JQz`4rs@ze*@4P_!sBAN!sZF2B@!B-Lg*7D^cTuMHh0xA%=F?Qp7Hm4x z&R=wnFVj2;?|yZdSN7_VHhzINKF=>ZV~Sc8pV_Z3P_`5JrtDm$A4yv66=FP7p>No7JX5xRVs7>R3ES`L z^K!@Q@7T`HhF|&LKali82RK($a^FIbw+_ws$`Jdsdl~Kn#|QiM);Ddv=a!Y3`ijrW zo6Ag}z3k6#ZQc^jTQSaiRy{O!(V5TspHG<-?jp_5!SoCNV~imO@&2d8c^%%0`TcVr zdmmev$BV+iPV{9r48#Mxr7;41aIas^fAdW{#=8yvDdu~PtoO<#4s$hQwKgz|-&enr zGw(c~rtzTOoyfc6GU8j>5NNd#w0vk5)3>r7NZ+&H840Zq>4N-mpYTMR{8jCPT(GpV zLXVFx(R#Zc+T`J|HYqzGjkm@FOq-lfn>3c7WBAqx=At*U2I&F5*;C$&!t!>?(|I?S zo4kKS-YHq*AZw7Jk~NL5r1{|yt)KGSemL!G+w$*6=FEF8qAj0T4V4Ps9;#E`nB%EN^67JB~Fajf~$XA=ArPrx(S4 z=lJb$H)$9PjLS;2o$0JR?*5#4lBdo4IwLuUeq~Ed zR^rk>d+!=qpH$7aWy{7wWYc}frepkXZ$8Ydn+WKDQt#W%rN||3pW#ugHEki@RPtQz zf1`RYz5yRCr(DZf`xX!R&PROb09!|7u9ZJl?z~T1KGQM;S@ad}n=M~4^{r*yKpAb^ z$a>F_em~pxzJ~TT_}|=>zsvvKY2@?^%-#3IgH9L^#)hYPu*Jjt{T-g(n?yO@=37n% zZ=9iWQ2*H4&K30$ym%0C-XfjasarpQP4&Z@*c6gMv~`8$fw|5QQywELS@RpG40|J& z-(3N|=QR#RQfTA7lB!`g$%eOVKXK2~4#^xen9zT4vQo%t?nT=d=l z?C5NGmhVP=uc~)^?3g|H-r}(D#Y?$O_lEUhy*J-Wk8jfZRQhZ3fmw5U3|&%7tDQ;KJ@(=I*T#Wr?Hmt zk@m;WCbawGf3%!5a~SKuC-`RSGWW+%_$PG6D%u~PW$51i_;S9bv4ipdvp>FAd5*yU zPkzDu@%>3pI>t5W{qciTPM*(F9@yF{b7ooZCch~E%O6CWihfuf@Z&SiDaUWqAXt2Utufb9HqNiH0*ti`%*NwZ_67}h-(-Ab`_%eg9DFZM8SBh@IY%ynNBQ=}m8@mK zhf#6i2kH1R#zqfco8D`$d}LcXjQj1Ho#3AOMbmoTYu^N)SNePHbyj1NemfU=l4-Ac z>wvtojK||Y6c6aE#yEbDA+$?9Wzv819-mAh@3iOZQtIu<4(B`KEsgp1g?3{wK0cZL zyqnEC+b)HS!R𝔴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⁣y?PvSAcr>CBE%8J+Y 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

    >^5Yx&%<}#q^>^n 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

    9b77sz;#)VC*wkNpMohZ> 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%0DJJpJc>{&%DQERo+y^S^~taWKJ;Q}1H8 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�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

    mk$lm*hba^2u4@>x&}f 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ŨooJn-K|f1cw}5VomV&{uP0RcgRROI! z=^{T-w4A-lX^F^GF~U0qG{p?)cOdena%NWnU?_;=VgQz@u~A8V9>PG(SRk$f^~MZEqrG7=M1!Cj5sKkaJp(ILFr}7L0A-+!orjdf$C~4ls$8*RqwVq`Ivka_-}2UhwfKiekI=|1NN6LMF(ylkZ2GvR-x~@4}~FtG!M-p)nq#%jRsnPKg~&Z$(d}`A=+dNbF%I zFT{6B{R+0TjOT79v%S#9TlUF=NMZ^;$T=`VQ}>qxF0<_S`T)=b#7^e`)WJFsllTXt zc*%6W%m->H5aR-reiwBb_L|O`2+}YY#DxJsJuKzL+D|-SI(;#|y`JUu008UH1C3UzTx%ng_O5JJRAW0w>2-6@I1;z zNtc_LWII!aUh{|HDF0A@2kXbi**5U+^=ek%uzSIHmmMq60{;sY^&GzDptjW1D^Zoq5z zH&~R~0mLgYl*A*S@y6F;BB>#!cZvEGfNx?TiK~$$1}j|>&Pa`0M_1_i4=06rWbs=>%~9~$4Z5VOE-+{AJO%yM(;+h1tuK532)E) zg)(l%q2xv%6dpzE2=j=5Mn?+6!g1{}a(ohbD#r0y1&+@PIpnH2P83GSQ9F7I6SCEf zyctW#HaFudNH((1yaH)WZivL=-)oq0Hn}mCaV8br1^1oK%NXVP2y6!EDj&HvGB=&V z-*GaB2X;_KlXl)t&})CQ9g!pqv?E=Bl-wo^vMW=Y$3}&T@-JNHTLvd;|HZE&(=;Z4 zXCX~LNScnIS7n;+uaG9@Do9fa6sD=5t$@Bl=ooF`qzNHeOoYPZO0g_wc7a?I<`6m+Rx|GQ}4wfqP56r0Xi8}1VU3_%xc$z zJ$2L;kY9H^NRi&45Tv3QdB{a$#u?Uo&LLZ1#%6RwFM=b6%?viiD3bKD zt&t_Kq`4$DC#1+;@Pyt8X$|-fB;5Z-jH}G@IOI`zMi%}RUSZph=3vluKBhT6spvL8Y?3Db^sl5D8FpjtFU&rfz&kN6CjQtHC-sXAqxRf9x6Z-#k(y% zWEh+eBdHC^k5~us|BnGYYqkRU@%BPAQ22Fp2r zja7%1*?2q(QK4#od3r%?NO@0OinV>!Y~{TL$M`GoXi>|{b}vEuw>w1s20Sc_>pE5C z@L4P-oKg8L5@ipIa24A`S-*F&^WqG{sC5Ct`%lJW2p&dQRyGcA$?AwBZ4wtYPI3~S z)*r-ygcGUZlen&Ns$++A&ZeJBO_F7e_uB4QJt=z^$s@@u51ETil2wh5*+1d~#(>QM z#z^Aw3j1mMd;Co${!lu z4@OGlFZtN#$DnJTIFx!ejkvNWMI}5U3%(94wsB; zT~+EWi!-Zn3!GE<^P*goP6mwTkW7%xNagHm+`Z0_Yp~gga*6EDy@=jh({3(yq?32b# zoMqHLY~9!bXFMR*=MjOrakT$1vR9gL7B`CL33?&em$cG$fp6dA+nhb_k${JhR6h|z zIAd~Bx}pPa0HqL|dKv1(I1IiQkE`9e7S?Aow7k>oGrS>4mt_AH)vdG7qv&UgCuQfp z@B6!@;SchZ>^y&ju1`&Tii)RY&zzLsixsEi!3b# zP2H^Ml-2lRL37NgC>(Oq9?&3lKadZ{&^C9G6?q{idm&N+e)SS)dr6nXX?mrQQ)vPA zI&!YU0 za|{F6lCLrV1`x!2DY}eeD!xT0t>R&lxnG(1dN^JQx~U}oDu8Yz3lpzd?0543DhfGU zO8v;!0I-3ea=A8luoX2AIX!>zCA|W`!Sf^?rKHv&=cehtq;CK?bDpGy_)k+*5_0xk zkDh?3NJ2}f45OC690rFeq!R$$0+8Rn(0+P@ zE<(nFHZ`E1*M6F|_49Qz0Luwtz7$>M?Ptk3?WYAk{1Wf;0KG~UmaJxpwV&yjdy~kI z1Mn?D<#J=~=aF2$7&zAwg{dg%Xr69AV?KgT#j>aiKr@0WNDA6do7Na-uZY!nsR4`t0cG#@)}LXRPnEsNYcfN%FECbEonUs6M9xA_(P{Wsz`;P;eDKtpNS zEQcW6fVl&@T&sbK7S|%s$d^ruRra$Oj(ZTHPb-b>Em)3Xaf7_lmeH(&WQJW~AJquSE#CaziGlKq=Z}=g$2K3D)%LnofT1=r2zK z4vU5&-s)FHi|lH2z^-E#@@XNHJC9^KbiOO6GjE-gqD}Ua7(0E2rnl8}vW<@M3%!Oi zKTAOO!C=Q-p2ufmH4HDg&dN#n)JC2C&%<)nd0wr*aeUtN>39Ga80!StArp zUx76vCyID`WD2@eBfRSoxHI+1`y>9qK`mMOwEdI4cxa10VgJK)4A^8;+D&}bt8vLj zX6kXe%{LLArBCGlBpdE*eG320n=tTGm;qhD2zP%P|D)<Qaji0_(l5AmCb@1}1Bc$E0=+TDrx9@>2aim&Zp&3gs~ z)^?Z<|Ac86U-@Rl6?bwBgbl-+)b`>uKv1@!S{qphp--^Bwnj8`geRpOYNw2LPNi*3 zUGGsCDR5HulAF8apHVZX7{w)y`z}20>fM;kjdP?mxo7V~6Nwj3$bCEq9#1^3`^{9q zBI1d-tJZ^(AfBlE7Ctg1iQ-9hmp%uNzHK1Gty3SKs8Fi7eZGb#Sv+}eH6*MgHNwIx zaIgFml*&nLaE**O9#D|oYzM}NJH)v>rNCW|^6TJ5n0~{3^%>~qk;-_P4A&Sj{c~k> zEQ|7xgXq^k;m>{Vq_f;oGPEl~j5n|V70C$+jOK|ub zs6Cxh)7f!{jTM+`4Oiyv4RPGc><#!Enn62^mcug?#_upUL6Pn9ftkeMX$j%rzjt^SM1QGeY$uGN8sYWa4ccF(Wcx5_^6(?MkKE5f%jwcq zBe-c=82!}!v>4o-HH{moHH{+j4evI*7G0)jB6nAxL)^@yAJJ*zmTR4y>(tEVka$do zdskz)sY^G#({eUJY@6~mQ1qf0r0CkBtLjpq!Rqu zV5umP>=)Lv8A#o1jo{XCT@OC7-Waf3mNWwHCznQ|OU(Npt6-33Kio z)v#6rxcU4)fLTo3SPkHQ>GKlji`l{iKA}<8B|u3-k%x|FNHYLNY5;dzYk;O*4$Y*? zDXMjAOc!|UWRVk6r54v;2E==qbOa*ON`u?Uml}YZK4}ngFZzP%l-Q0iS_C8_k%uM__>e&e17k3 z^gUe$>oRxlX6E>G!G zf_Ut}`GDxcy8yUJlFs7@D#XBC8s3ZTLGP@jbK*G#@}6J`JCuwrSggfZcx*v=mUZ!Z z2WA2gR+4m{XYe1v)dm3IX#fv8_z&PAj97I^(g2=-paIf|b<%!b3_uV42JmPENdr2` zWqdnl>Tn*F;D;yW+=%eCIkZ@7JUu}tn=%beejuG>)(a0+D38)ein|}&ujJ4oH_uuq z&$Lf|Ih|y3zZv6}w<@Ux{=jwFkVA_BJei?l+(LdlotCtTOV5qF^0nYTm_v))JjbD8 z+(LdUoff%yyhC|u8cExsQFZwvhZeb~#JJ1LQe%EgCx#+8fL)$>ze=02smxcY$!Mq? z*w#tV4RLK0b+KKg-H4*(Sa&(i|Ew)s48Sf`bq)aB*nd7?i&FSshrdd7_+*TZd!Uft zc|HpyB;F7A>fxja?(nEt>~WX>(3-6>G7$zacdo~~L-2I`rw&<(k4U`Bf#GmL#rGQfL6u6TppsRQqx%W~)nRtrb#n9|ZyNRd7-GXg#r)r>A)OxxYh|F6}Lz{w}lvqqMJh2DsO!!qZzfVg9OAg-2If& zrif>R5&ixR;O2_%$PM~Z`=VnQBU;u1@anWr5bU_z%^$AuxH7utB`iVJIW7le<2XDV z?{Z|^k!QTfjhCC49N7R9$IbikF8BDyOMv5Y`&Ycn?e+2EcHFI~7sn5wd!Sp^+M2fr zOMSrX?u2q#) za8KA7fy({sZ@Ok=(2R!&!Y?Sr2p9QSSq#U?wSxLXb zyk3fp8`tz$g6wkeF2)zAtgr6Z3P|Gv91UPSt16r8kc_z_(o+)=32 z7WVsoiM2Ql!2Oz!a~|coAyjtO!eA?xt(Ws473MU&LwsqjP!hzs5glK&;0pxrlYXBw zCFdtI`u>9u`KEOHoI&{y{d<%}*;S(aaAu{PZbbK^BFe6j&kgr5Rv?xB+guqLf0+r~ z)2P;mSm0$}W4`FHG!pJ`)S=$UkpTX!-x+Rr^n=IYJD2gV4(9$xU&eK*2>wW9a5tn6 zuATzP-|DL7=14zy>?nXg(=uKNf)!n;Vs5_l-aQ1yR=TZo7o{$0z6XAM@81Z(uZhe6 zcUS5hvZdfaY;?XEOH5JBxa0Etrl~Xi+9yDr6#?9iSuVg&;|=|h#;0`}xldDq^}D5C z$2(9x87DR1x)^{iWa1HKVoZHRvDK7@%B`Kg~fO`+wvFiNjm0n!U*0yl~3C`ui?(HV_Y z0{4sR{P2A;yed$CGMefXaSv%ZP4_>1t&I^k&j$AsQex3Ly}|LkbVb}`D%E3nEnfm+ zp)L~HMp|BB@hR{v+&tpA+>_ULB?i3X zUD4jAe}PqSN!|$5#&-4TWO$Oj9cosQ(YsR000h>%6CXv@JKbqN3v*q`7zONI#a@ms zu~Ic8qru+~gQJ?gX)rDTm4NH|A)vP15Q>8Y7;*m~W%XJ$rj+{5!kCoCc9o=nNu;!} z$BqdCL`oZb&jVPU2fYeYP@Tb8Z?UAMle0f2rOZBhz{lvc^s?XB8U%=x{`NDd4`0e+ zN?9&ahB(Q{p3cz-d-4B#jFxhdJ*Uq(QZBJ?s~*eIK}fkl&A=rO)^R!b;wU`ceG<)Oq00OKTa?Y=4i`{AdL<^G<`^WPHP`H$lf~m2ZHdM=OSqrKDlpX(41;0JE?0xl7Y`$gqSX@B z5?ZU84BG4%UDA1z${=95>PPD@q)FWY#OeU0bC$ZN6{ttm?DuhNTvuS81ATXZks>mh zU7H8YYV{4KHF zW;7(gMgX-rA2@R&5MQcGF*O39Ex@4wjf(-L`){`BQUJbFQDg(Su;8u(X34oYsmO^^ zkx{qO->CE{UIKEFVZ@PTsH&X28Ch{$E**1R?uK>TT_vbg?s1HlfOvOj2X<`?ju&9O z@7{~>c$Yf_9hdGn?&>QLr{i)9Se%WDjdxE=1K}RI0tt?Hb(0|^-sP^Oc$b^U;@y(Y zeD=cAk?=Tf*TU_(0^uH}0+-7p9eKu$73n&F`*q@G3Yt#z&GO_9632ZWNq1asgo#@z z5IW-}AYR(Afyt`VS3|Xi~+>B1vER=SB9a_PS5^`S) zRI_^(8UTzrh;4Ta+wKc$Fz_?zR9R#->&Ml437)3FwU1#R1KqeuJ=qL^2Jt2)vlQP9 zH4KRH0ZO-HX`^PNwB>C@8+YT9G6>7 z9N*1F+xSrTKxF->pMxASB-XToJ>0YJBSDJ>x2ect3V9hYk%9JfG_+RgVfj@@6p%Z}7> znX5Rqsd$$yPXE;U!Sy^1Q8eEt*LjL0z;B5e7#>H9>9Ekv}b=L(- zE0%5HGNQa^zE#^qin)d$Ix6Ui6JLopjOsUq$GxSDdt!8nYnNJmSQ&Z66oc74d4hLU zQGRdRbk+2d_(ONNLlflrN6{``+fOf^v_M{PSS^-v`FJ6c4GRGZH|N77;}J`^UhkMgNlh_G zR~@waFeyZ)czB>KbNO_&Bs{E%2sm$H^o0njurL~t&g5F^Tv;GpjVr0GhtAhOrFqQkj$+Ikn^D6fl*gs-z@i*)kgFuFm6THoLy zxjTmPFp_U~uoRZziP!nz?;*T-ms1!b`=tv1BN)kJ8epUdWV3OA$(Sng#~AJd)pOuB za>)K16v$4nd&8uVA*B``MzxdZNv!d3230JZ461Q4xU~?$v6YcQ70cr8YFzMbJ@Q|A zQJT<`ceTf)JIL0Hcu1D!vSgC`AbdZ9%+D%@L-sTya$i+`PK_M0Ec#FxKf(SRCWQ2TaA-f42mwOK42uS8ef>wlg4&Xey!ARx}+Wi?m zAqZ#5A{kSS@Ug18WO)@hFM+p~RKzqtgO(P4DO+QBNB6zNY(59`=Wx`}M>!hP8<>}f zIaCoNSq|?==bhU|auL$=IWgY_7~KMRF z4%zRx5-X|z=Zg9iGN)K{CE= zg@;7T;xUqWG58{eFF!Y&cb>0h_=a=CtKqfXjv(_u5YGN4lJGM&k3gQ0L;Pd)Ff0oD z1WXFiM)DHK`yX7^UwBCTx;VJKG-UzgRl_5;IaB~U(7crFK*}Lg??YH>15jy2U=fI>8WF+&Tl^fwQm*F9BY0^1_w1lF( z7WQK>DFhkGqf2oC5M1W#c$9A+7siPa55XPr$@l{HH|Ky-$Y>&zKA8UBcq5$p*oRDJVrz7k#m=uDH1Wrg_{FPY)`%#z_f{f%7P-wQmWxa%lz>m*k zI5z+vMv(a(9{;UEbeQM~GF9bHWkBbUITtw%-w0Ni7()tWq#VP;=*La(sLJY~n?-m? zY^+MX+dYSjb@B1<2)h?d3Xv&=co@~V<;1!Q&e)!kHhWN1*m2T;Ll{WT40<|TA7bLU z=V%eY)^a=~8r_|6v(Z|HZ#XxcyNtFo{N;1QU#w*q?;yzhI0#Q1$LtdJIa=;_uz!L{ zA;?JnED_I}ASNCUiB`W3yooylL1x1soUdt{Hus} z@Gz3=NAM>NE^{&-BA5ayyq{z!Ey5vPuy24#A=>CyVk3t86IZ}vK8A;|vS+HmO8BuC zF!BTYC72YVjbxsad;l)V9I#9r~MVVs8jD@+Q}#$F}=tj|_yR23)kbj4cU z$q2MahN;eW97JH|p~qDJ^jwVpRTf+Hhd_J)V^n9+Zu8Tj`V#hU?J7$F zlhQ3x##z8DmUkO?n!}{A;|y5Lz@c-1B5iKQ{g2VGFTDkD?lw2l*ii@2P~fP*Q(9{g zc-UV*4g6-|=~RIy{D1H?97>)+Kz#uGVe;hi;}JmJHOLOrQ;O2F`0Y3g%%3op1y7B} z*yaOc@%u6YjtgOGR*W<*kQ7Vkx+-r5aV`M*dKe>}s!4$K0!KMZ1B+V9K1 zXflk-(LpbWg zRA)p1PuM^Q8$RweAq(Rf2t!hSIYIp6lV54}%_w{q@<&KI>>?6g^V++Ymkb z?G3;@0+UOvEOdb9U4dCiD;b*E_ClOe=SQ*JM)`#%)hodh&2jH0v#}zQS z{5Ku&n&kCPtMm;lrjekm0b~_<`or@H93Ruef7fP9q?D$As-IAfB;Z$<-^3tH1r8zM zfl5fX_>rsw-h7yJehLGW88~9_`x7mG8v6p-n`r9N0mup*0or{s-=c0k8^|kQ_)DXr zTo9Cf;0UTqDHZ)>88SXd@v*<*Z}QsrX(E_*IO7dTxMp0!NHxlS;Cv_&x~e8W>bI)$RZn z7dT=`LL3(L@Yeu-MHncnCSTxjL6r>m9R+?gc$q!uEb=mc2cBER3fEgWCN82#t@ ziLUqp2Vp93xIspO7dWLYmh!{M3ml-#z!8J{FK|mBTM*3`H~?9JBR~f)@Ms`M!tgh8 zi{I6AT(!+|ju&ERaMxK=s0pfnoOLkf8K4>&g+ZVExdxlJkH-113;ax8hi{=j;%Jm{ zMra{Wp$Q@k>r(Vjt$G-tOB4rqdmviXx9coJeV31KoUsV$TFA7OapLJ^;C{K}d~U{k zKKGZx{VF*32sbCy6b1+$zEpD`)fUE58$Dncqk^ctb~qLU48Dqgv<_AL`w+MsX7n%6 zf7G!&{#U>ls_5$Le0c_sGE~R9zHm310(EuO9%q$+Np$tr@U(ytT|Hn?fx}OV=*Fv& zMo|W41AYaJ*3|>36*wyJl)ghA>gx9cze;#I!52X7z)^vxp?xQKsH^jqy4~avT|Iz0 zJX(pm`cK4BS3d>JNf^=9lS*)8G>qu#-Qeg7Bf5GZzzrO+NY_=lGKg~;&{JWwt{x!c z14lWF*46I>bUBRZ>O0`r1|zz9z~KdsfHlz7KLhepvQk$Mcfh}J82q%Z?$@0<&CEhq zpLQ2A%g(DlP=zpBSNCBiPk}<`RYDXyul_*vr97>x`>@af-w~uG&^TrTdIjOWt{%V+ z1rDEqI{3pu9IL=^FPXHi?nBLKObT!x5=T97H!wS4L=QX(#}~pRy1LJ#){qIhdg4kj zQCCmEl)VQdx_V9iZ33h^`f&?7$I&Lk~)24AiwA1^i*gKwT?9h66{8CD66@1Nu6Q zuWJQ3H*mxl0$uAgz&{9sk^V@9Qi?yHBXVCe>lpwlV=Ao@41c*)%~FGUFnXhnJzzTb ztwP%Q=c*N8#W13e1u(M_VbI4Sgi#+G1IQ>C(Z>RqHJY#=Q##!T6uY#Wfw++<>SF;a zw2Y{e>6M6Lm$nIrCt!4!7Qn)RBglTxrM(a6A;PsjRwZbLfg|EG1p3(D!2Sgz`dE#w z*vkzg`dGlBb}>c1KGqY|G8oav7Qt~7J^VxUBpe%IL>~)yP4ZG7m$u&`f8xqTxxVf<-kaD2~bvFqE4oFB#O|HR@Twa3X1sG{A0f(B;6#32ND^O1mPW8QJcO)K0 znoBo0y240v33yHNvbhwpXsEtV2V^RF*jzTj@dQ0o-w(m@E{xHin+f=<*j$1z6*vM7 zJNEzkFYx{WBh4j1nSmn)_nS-g9?Hmrk>(PBtiTbVgXYo=$gVK_jXdjrf4HvUbL5N4 zx7)~As)GLLZ$EGWHG3-SBZJyyjDQCVfyD=wB{C+DnTBN>2}^;rZr^-O z%@?0U^Y>#ZcLdSBS@b4SVeJQKYENZMhB2yh!sJlEaAy{W%0)Eo4lsWtCu3HURmTKKU9P!%{b%44aD0+LudLTCw$#4-(zsW53rH{qT3 zV=@DW>$8U@n)O2DKMB;GfG>wBIHrg9RHFJPpp1SmyR&{R_U;EMv|SKf{_ew?-L|7a=!R0WP$Q`wc*9Yrd!+zFw}gIHdMV>gU6m4M3(92J{NL-Mn! zoC5qLOyMa%VdpfJ-~X@F>ZY>AC;dO0N*R~1E=PPJ{OjkhykRVTq(Z~U?W>Gb7~L>d z*I^&B8vf-le#3YmXc%6FhOy?{hEc_j1zVtWbiq?S)F}C3rAB7ZS#X!S%c?V5DILC`DAzFfIXgJO$}KWV0_x1&&z5*idyhrLtk%3H)*xX&5iV zu^Xmvug`j3!`NJ*Vc<=Zo+^N)^)kxDG5AoOGqOIm-FEsQjbfXfUV6&pqw z`Pnd91Ktv*@PMDNa~j6c|0}h+VchML{+|sanX9DlLwv@Qc*t}v2ZhR~a|f_}q<)BV z&}sW!Q-NQfYE|@6B$fP^A(@xJEL8;2jdmwLwQ3SVr!WT9H~lc0O@L5=!$%tG9%Y>X;2=`*77XU9xkP*p_>Eifh-I#M zm7$Qfq`52$A3*ub4=Up+*bDscd7dv*tvZd+DHNglPPvX&zdAKhF#%9D>OoOmtkwuT zgGhgdu^PjZJwO?mFqmB73VU_EQjfutiiaeGYo05VGUNFSsb~TEXg?J-W2yLN9ZH$} zoguLuOga_S0H*>+Ucj(OiH>?Vkaxh;<$O^9G6P3|roJk=>JNaPf{}Tn0A&S^n7a65 zN-mQ_y|v>&BnL+H)&Lk<(_Qq|KapP1Tjv2W7sjab?tBa*`?*sG1*T_K9|CzTAzD|R z>0^w*5sTcPE7}L_t1zOgo`&N)7|~S&4%~HJuB+C+0Phft=&FO^xPTu1wYdh4xiF%u z2D~PDsjGg#j8a#99+2(ip|1KR94F|Zt{NGH+f87MeQLg+YF}AJ&0oWspQrwU7$fKL z3N_#SXVkTtSDgc%d6&%?1-IWES=A4IfUg$dr~S8h8rb<$t9US~MRENQWmgz01l;Rz zyi89Np4`FcVqj#zH0meG9Nmp6Xz6McwWhR;Mgj%hG3Q+M*sN@QV`XxB1#nh&9n!iEsXv*lMzS@ z96HBrNVT1vMttCiC172Z z0?K0i9f2-^(ZjU?G7>n-S@dx2C4i2Hk>T1Ua4d$A;o5*BA#en&!Eo(UKyD(dIUn13 z;Wz|?pDb?3^DD%NIec~wgdS#MS&4sv;}3GlBzgcf14pc|z>~HSJRE7v8-|t!BO{Gn z;OGQnq;c@HrXQ&a9BvRP22ux800&Yh0Y8BPxaeUS9Jh)9E_$dJ2nZZLzY)d&=`9q% zfz)S#e@1w?79oIIfg=_vcn*+<jFhKR~AYaj6Rf{|g?S#Zo0AvIT{pNcixn8O#M=5-&$erz)ytAW3d zJTWDM!y_iHdA?y9X8jy|S;0zp=mV@Hfjtf;g$yawM2u=YJ=?koPFY@D z__*8_3HL=fKf9ismR*gfXIoslq9Kn|fIQ+uYSjmXe|g({pNcb}pHS(gli~SEdm5C$ zg9VmTNoifR8sptn4;;UMLl$1zi&RyDjA}e`+RDH`U_>^}u-E1ABc-24!Qy!+5tA){ES$UbzG1TKc6jW*|#_@#+S@ zRm1Vm-E~$?!Z7?YJmTI-uM3(yqT9z}`k)}YHv;Zce?VW&8)V!H&+z_ z%N_n@RqcunuZkkZ{JfDd{4c0pbX74{DR;FB*%PPEGzyhlc{*ant)wZ?VM5MYM*dk5 zrjlw_-T`!>3a0}Q{U9AGORe;K5EOms5s+(VeMqut@0kgXoU0L(Uu6x+7ybcgK`P@) z|BeC1n+T|r##R;mq8HqSnUzr}g|1!yP4Ir4ji7qj%xd&TRIS%UPD6~2egHC?R@%+* zvZvv0CMP3Cf6s@zdFpY7*Kpu&A*Uop?}s+z70U^T(a2D^TULrgG|>gCfN3SCAx1x@ zyK4%gj}Ey6?lK+k`t`uyCCQ4uGYsyP*@Af&lfK@)+TC*$-1lcm_)-*;w^N6Ap8))x zY77s{c_S#)T$EY*4~*rP(?GtR&dg76BZ=zla#XsBZ8o7uvegWZs<%CXS1_d#5mnV# zxGTjIVAzLVz*3hahXrZaRCgn(b|p|kMgc{ShO-V!%`&3@Kx(A26-H3*p_Pa>AwIeS z9(%<1=nf*@8sH6^yC4!0lE~;9(KO^CA<>!)U-aNotgNv!H@+;1C2hOxnV9EFy2xD! z0eg+;b*P4@BUN(0`uz<=RG8Q|{4pC@84zKYl_d><36qAv(Dv~39e{L&-OK3YXEyB4 zg;TJ12G~jnJ%da{Z$mRk?o|nY81R;(=_C(KVarK>49KuFf(O)$nd6M~H03Qy!)jjM zT#(*Cb?DB=0ifKJYrWO!wC8*8h<&5is0#gyygp(t@h%m6sdt^&w|aMreVeyQ?AyH$ z#a`k4D)wDoLJs-w@#=_uuh&KF`@A_~ulDW{dyV(J*bjMci~WfAiP(>Nr^SBEOU|X7 zbzYI!k9+;Z-r!9Td!u)o*r(GX7+-Ny&ZK>Y9J(pLrfrb$-_u?b`;WBTsto@#?U?xg zO8ZCbvuQ06-eb%~GmJ_XSi}Cp{4D&x+x#;GhfnEawE^WqluSw(6gqrL533ZEix5zc z6gqrLSF1576A@5K3LQSBt@R)%Hqtwq6gqrLvDFt8_Cs??p~L9GGj&p)vZnorzYq{| zPe9S+++Y3%GPOe_>KMj#>MS~$)K2xM)ka`+Ng+I)>raGd1P{^oJqh^T%jf=_1b$02vm;C?7{X#Yd zwn~%JufetxAP2$>gQ@h?B^Bb1Pr!saLZ`#biBbO>H=1r`kfX0)YAJP49Mf^db?9_c zZ;Vg4;sSh$Qjf+bxRo1v&DbC+H}X1&UF7u=yRkP^?55u7JkpzaXT@&rxz*@z;iZb* z(px6st-MuYxAxYF-NxG@b~|r^;M#kA#qQu;DB&Hw$zpf%=7`aQ(dDwA0#n8O%poTd$_r?Yxg_&|l(h zy@YlL?`5$&ddI}>Vjq@y3h1zTRB;C%(G?f7MG9 z^5W1X%7yD0BSLB2`LGbwJ>%m@)mCsAQLgJt9T3N=S*zNALwzNZdO1iV>fH~|6_M2L zd=NZhEk-;u|1wj%^U;$b#bC&)o1NO7kC7DEo&5FSn)S&xB%yhNn_c3qV-mBMdaJ~~ z&D$>aGLJJNZuafo_hR4SB~GM&xmQ>06<(>>cX}6zeV2Ew*ektNV&CoYQd>9s9&fkU z_j(*=ceC&F5+~7K+bH%!-s@sN?0qTrqh1*QAKdK6 zy?n7ZdcDMc(wi#wW^b|BPkWDw{fzgT*jv2M#eUZNTkPk&3}~fp_ExWn*xS6`VsH0m zioL^IEcWx>da+;d-Vpmm?;EjS^3tY|f2UU@_HJ*0*e`pRiM`jmP3%{^&0@dmy(9K( z-v7kj=ebkK|GHO4>^HpbV(<4Z75jj=chsA!&d%?Fq7W-}QPv6eGjB*Zo#lAgQ z?039bzI~_I?|NH&`v~kd*`7)}D~^at%b3QH1eMlO9N8+7d1;fKs}fn*ZL+JWM3!=! z?3yZ(#oH#kKqYGSIx11K*HwvR&&}_P?yJi1_&+@isVVxZj7l6?1p{wCBc#$WVDJj` z-mQ$B)(M{{;9o#rxZRvV-XVDG;e{X!Nw}4$hZIRU!=iUW^Jx|_aI7>WjD`dy^y}3v z^*|pU>6M7VMbIt`=-7wfvp4>%jfhy#E2bfMR*W=~mr~}8N|*&16mu&mD@eVVN$V+5 zUg9{fBgKy+cvFl~lO{U*S0Mp=5&U*QQj^PBCp$kuVNqXz_G65$5@VvLIj>v}(II3u z2}WmUI{7EHMkkbWwKIAcat` zZ*(T_!%!|0`euw~q=%7dH>Yp(8-&4u`)?5Ns9IMOEIr+CcL0vUPz*ILo!bFly(%ha zFQ}8F_)w-Nf;g+rU1&&+6WprJyn7(ut=ioC^m5uQygzB@UF1;>ck{-2)W_Vs@m>c0 zTDW-^dxc_O;&l*vf;U9$iQZ*mPx2OueW|xf?8)9sVo&it75j4UPqC+ac{3<)rdJ~N z72X)JXL&b>J;%FO>?^&e#JeEe6eFpym@mHUPf2jKrJ^(?+ zP&_IvgB(y-0bPBz>7=YhSzk`-ynw13!5qq~KG$^mw*W#d2lf5{q3)xQE7=^YUu7n+ zgI!Fr^>7$@Z0O%0|Nn9Ira@XoxAIE@rc?|FmB_BfP zYlz}^b{<^mESYDzffA0tN$#W38@Y?eFUo*J=cP|ic2PpkY=~M*Q|9%PL=>VV}U_?@rrhonKBM4FP zNPJ}&Nva059gg1F46gqz1hIJxKpvyr%*80Hir4@41z-?C8-&j5e@*}TU+KQ5fi|n0 z&ihqO|N38k0M#wo>)X8lg)^}p#MypA_0-v7%NvqFoQEBF7Jxc~Pu`~|&9v4I$>EwA1+ zgA0KBfaL<1N?RGj9HGq*E&!ek!t8*kUL-x@VzGq?cwR}fWYKbg7%&<)~vNG<@Dlw<=?I|kBHcrUpb zTmak##EtF?ft^nLVW#Lw`Lvt<9l%m$OF>*71GLLx z*pN){J5X{W1ye0FFncX2EE{ zaiXN7TBM|r`j-H+kv0XYJ(0|ZZll)8H;@)w0?dpW7B2xdaS1S6l^g3RDzv3^wynv$ z1UP*rBu)MTe~#0yfeRlEUP76UODH)Cp@(vC|77=cJXQkWrtI_dP{pK-f_-I0rw9Jxrz(HAMD^L5%J7b&%EmP3$f6zbbu3iXvQh5E{u zbdHxyaP#%q%^aJud3JMto4DH%fl-%dH|Mt%PsoV!?B@J-_7&ub=IgVYIaZ>1{Ii=i zPjGf~lxH{Rm)ehO9({H*hhj8O?@BT(qj~y>$K`l8uLO!#S6J-S*Zu^oQQk>YpzoxK z@=lsM`c9g3{wt62YM{FMYM>~u2CA#C28!}(pt|~Mpy#+)4>~J z3jG^mY~B!47^!?zp@xlg{zcDy;{?{D*K6)J%mnzUkZIH_jGiLa7(({7SPEEwu25V%A1hev&l5_-zTJXn zg;1h)&m$0Uuf;}_YIi{)*1s=x1SDq|xj*g4a8&&b?)EH<<-7Htv}(aI#jXF89f8B% z`XV@==5ic(!f(U#jCevu)t8bXXH#7=R=pmdkosGkQ_LHrY_%@cQg+z=V^W^4DCLDf zO8%eV+@_^`_CDM%It{>L^!k*tdNDPw-H8$JjP8ObYX5KnJiEk`VgEe@p52n?JiBi* zq-c+LYTA35@|Oix!09MnYE{5|9E21ZW`>{h561()qy47?e|uwUqXwN-A)01&jHp!| zw_F(wx>T8ngjMC)R1Hd92{*5RyQ|!Iq$M;4T4HF3+6Q-oGK)eXt*62;rZFuhtyeZH zSWD|&L0X@x^5R7=1-e0Bs~s4o7B?8IW`BcI5@Os#s^5WEKywduC0x=ntU_8|3ewWT zh+YZq1{YfMD9vp!Qaytih0~NKxf$iMWU7jU(ON?ESs)sWvEBeEoybdhR(n3qYEP`f zQT0?j)7YvC;83v#C=C#>Staqv_Iw=KPE1!~_yD;Vtfz3~C(mln_s?u6hQsR`lfg6F z8)nLgF$dcfNBoT>p4py{GusK~*t;LhGu!k1Gut^7uY)sqW_zPl8GGQse0d605%~2( zfq;9n*zxD%%yxFN9K4qpHzwdEcTR~vN)ffw4gueIK`a_ z;9Q0Pj3l1oo{v-9SwxE%%*d3u7=+koAdyKt%RL`wxs#ipc@1NU8A&|LJs)Se^E1v* ze}&I@(jk6Cah5w@GO7bQ)(oEIp1&`Rp;QjePizLya?gLWDtkOC4gaBkk3{BQm3R?K zi^@bf-N@is?)lfGQd=2#F3By*kH{=jQDLIYG8HvQl-Z!7CJ~v9Dry>G3oF!D@VQ0J zBgZf?Lz@#cv^gC^o0BiJIn_d&6Dw{}i-=5G6%|Kh(yFLsL?*3@T18~is;EswCW~Nm zy2XVplUPOVA~K0pR1%R%tfEd4nZzpU9Fa+^qAn4c#473iP4umRQQivJMBfS+<*k5C^sRtV z-U`@6-wGJzt$iP4umRQQivJMBfS+ z<*k5C^sRtV-U`^Ho1T~Ft$QY>U>A(IR`IBL8+PGNYLz zl&MOUHSp!$gPFBxi>KYM$+PKmtfbvylOHqepThHO{15QpfBkM)@^$w`lRl&Q>_8 zUP%4#XgmX}n$X0GKk*LJ{Wjglyf5K4?5i+qSo~?+B6^Ghwk~2MMM>ED20wA)hZ4X< zoeBJwk-PF3BmT*4fnLL|{v|~H;%EE8lkl8LV!};@INZG0Sh!$ zN-MYrarcDZk0$jAta7MQtdzSJfz~6+G>R>y1zV%z;0q}&+4>M_O0lgHnXr(xltmX- zmFGdIYwbl-D0Vb0!$@ZYxuZg+;kIn*z6Fmx1YKv#=K2qVorThE*~0(B5OyC0;8{i3 zb8>NHE61H(6Fj^)vQ?a~aB|~ft9bE*?8ni!w(@+1lNU#}iijs-^Ww->3F3*`yg0H| zqIgp6rO&~m*MDT#yg0H|R47$!UL4sfSv+|*FOF>GUmR)k;>cE&llZ-9WTbOaFPihO z!VRMtYfy~Qr=bzI&eltDx)mV2s%VhWoHM*hG;1*#NX~U@r3NXzayS~;=w-=N_t&9k!@-{ zvfJ*Bs3bIMG&}&LpZj;i9Ip>%0cJ&ZA_p&_+ogvh{rXSsp(^88{v+TSMc6cJvA7l z($L-DG13>~*|6TvL9)W#!Z-}taK1qO8BP+aMmaU{G>wKl?%EDf-3X5gcLwNo^%ZoG zYn_8HqAfV1H=`*yYj45(?BK5;noys+!Qk9_JJzu{4R;|1qv3b6uF(9KWyLrBs^~kWu5(VCOmJ8XQO?TDL5#e&Gy#)5b%z8w%E5FfahKDY_r=Z!thRARX#WBc;a|iPvcu>R!)L_f z8n*jAeE*XLGiY;s=Y9<}fdJRYy%V1$H~f#gj`F_2TO0mYUOF7Y%@^8G;tLt6)1al~ zg>#hqH;|f`tBHp7558yNsy@_O32h>rr+uz91Yf*xH6@WptzqaAaZ{VD>B%rs521sO zglj3cIsOk@n~=$H?Lg?`h%lTV2$j?n_(F};nn-DCxVds~A>%UiQ{m!(@l$q7tpY}V zIKpjwMynH)sBk;&i&)a$OSCU)r2Yv_HiQ#c+~+8?E<38uN|qfNR#SX~!(FrwlTr7h zBM*oBEB8l2=d&IL1W*othX?vlYxPg?U7&p-qyI%H{bedVM7e)KZLtavWq7E{JdLiw zu%zOLDXF$oRuxLUP^HyIfuGJyg8mjBuH?N(zc!KS8KJ%C$SSe2MrtoQvU^ag;ZZ7$ z%_UD|&SX)JR#~j%0+qR(HSHpc29tsXSI}PnG!w+s9Z<9ilP|*e1rQ%B-Q` zD)S-6J6=^|xldD>@8d%pzF61p9F_SXi{%oP!vdVIGBcQi3A%i5R+)S8Ar4Q}-X)lz z&H5zveVnYq^&8;J(;V8Caz2Mt)7gd(kL6^uQk)sky=|jr#<3X3Ocfqaj`x5voaYde za#EphnNB=P+;VC`8w)vI!C)IZl>e2xT7_>WQz@E=;XIAhDrXp!K-B1o#h73SuT$>+ zhNy|}@W~86uF{w&!^(1y@bxOnDhpY6utqm%pKDcNacxxczDKOdZ0%3z!i!qfSq)EW zU#hhpDGG1Wz6@(KavI*OeO0VJl=&1+FF@armo<6fI3xVD_Eoo%YmvqYhKhE9+JgQ;|8$LaKwk#wQ7+?|z z4iF$BXn?3eK!#0G0ofE#6p%$kb`X#?ARulmiUNv?ii(H|ii+2bi+V*x#T^wD6|cDC zj@$Kn-(Ds&iQoS`-=F6>lT%&QRn^tq)!o&7&M9+Z++$njAMnD#WiXl=^*{EC)UYql zN7eYBcn!We4Q@v^{12c{JvGoqr5fuGdaBvSi$+cv?f9R0%AgIU8lgY;)CirBTONng zJml48xU;Xk4!ry?biPWte<`3ZHMAIGH|sI>>$i@x$^Y98n_vvqDmhlAix(k-&`N|w zlVS3R7r*}mOhx2`Ux1QcoCS%?T^pdStD!{Ew5d}Z-}4IBf@7)H-PcmfMIA6mqE{Yc}! z3#=Y@Xh<(>p=F}y5&ow1cwte5#w$)NUaMP{%p=+$Eq<*9+DRI$i-=#}EY^0(NG2Xbwd~?_*e$b2)+F(Cws6?CSC%5Q{_B7^1 z_JW_?I?Vu~9nz2f;)aP+uwv7y|E5*1&<6Wmt3Fm6><`Uzt@fgSYG^$QatjJl@(31| z#tD2X{2YWqgU|0r-wu8lhxuA??gDy_&xg@-^oK8YgH4aaa|E~dLRAE48%_|kK%)(V zJ72n9lDLsmqGZmG^SoIaBA0$|BBwuwy_jvECk}#C1m2d$J_=j+S6Ptw@X2PEo2`>fLq6t$Se{!VYTiiSHTF$+uXd8u6t=6V$C@R0Y z5x8l(T!`yXrPymQbD4i*BxH8&Rc?xCucAES`iSx)p=Nw@#CUAQ_?AcxdKQeSe9W!Z zeEYvgRcz2uiOgda-lm~abjJCVy7Xui#Gettp*|~hrje?d&C(grPTt2r<@$3XVMmgx z3DVq%o}oIi=P{y&{(?w2B*mxF@PX_9n{&%6BH^l3&MQsMqA_sxS4C8m$d$LyXT%W7|Iqo0>jyGyUI7UmUj=C>P4`xl@hlCwayfc~pRFNON>_BQxL-?#{g_dWcX?7ZMm&h0 z2hx05k7Wp*lK(+(Q#rMzKNIx9Hdw?7T3`wyf)1EXVY;^+v-{9*EW_K$P%RmnSWVO- zp{dcti7m&JH|aN*;ZYctwColcvP+F@-8@_Bj4>JERQVVgqsnpBn_5ZLn-cPMt}R;2 zB62KMqvf$ujh1C{2T{k#7!|L8dDwbO#$jMIWoj$^&d3$ihtEP++JHHAncq!@96_ZT zlDk{w)NtBEs^K)$);>imXO=#vYAC9d>#3FF1kCYI)9NI2kxtiirSdj5v@oK z&S})@BmF~E>owGy6SPvEZj|zL+hA_##125wm_Jm8oiP8A?KrDEUo*m!{A}vOWsGHT z@xmoQ7icKdGtQBkGFKLHPCH6NSh4klJC6GkWw@A3)r@nJ)PW|s1J1#pEd5n5Qz$!g z@R*{ZTwSWEQuz_EnE~_0{kbxHl59rNkoj zCVhd3Q}E$@j*<^91-sx${JKG}UC19y#~dOnSdq)w!;=Ux{q4l^VZ@k!jSSC5Mmd(f zZn-r~FBW%&hFtk2Jet2!L!tbExK$d;mF>6$zg9yi(aoQ;&0a6V=gCyfbZ@ZDLQQVh z=n4+?PO8Z*S_0lu=HDn|EK)*GU~iIY0$VO`;@p3|RMYedr{p)(gt5V` z()T*T20r4~A{c}&9|^j`54b@`G>9)7_~+4 zAc`Cb)}ZpR22_LPd8pQCa0CmuMDU0jEH4D7%I06AeL14}bpDGpKaah`ZQhC@^sxCs z&|&0^y@I@P|KBov2oiKG;u)EJE_{KF$4By+?* zfl|x-7iD;NCu`!DGEBTD!^AIVnD~_p6Tg~a;=LIre$ALzH@!D>4R=&M_D$VmliHoU zrQJzS-AUh;MYEt~U)hXa=pDSC6wpBVZ?@)rvI%t_EMI3Ac~=(E;KSutn3DMKX#un3 zJ@nlBb(t$sW_H`ycy!x@|G88jAJ!Tj(it2*rTRicu2$(wtx~8P;8)r@QQeTf)}@R) zC9SGvO5aJJi>2Uov}O^^L$D|k+>eTJgFmn+4TBQ+pJ>nz?mQ7pK*LG~z5mC`KM`0| z{@JYONb^1LKB)XC%7e;p1TIdr`G3LENi@F+P0&d;|D6q^vd2(#d}MTbyvL~)Y}4ao zPPPym?=cS}EV4U2DzU(4>*?_t+8O>LPRViop`)It$6fyjHQulY$Y9(G>K(^+d?YBr zuM8eq4{pKJ`1OLH9)^K~mam|vI3Ia94s$OGw$eY^ z4c8^Xts#>9mTrtTawJbm_{V6-l`H5DTDdAl5z6+Qr?z(MQny^WIu8Twv3f-mmEW+X zAE%+196+c{Lvh)bbLBP~YA8?SSk%_lXQ8w=Xy+<#P$CaA%2w{y<#eP%eog3j4Gq?F z<`eLO+l1rHk{vjMK2bxn4qltf56Rfi=J1Swok}kJ!eO8d@xyu~m1`&=R?g^Zu?HS}M<= z>+Pn?zRZceO*e%No$vrnuaKv@CN|obU8SdnTbBC` z^?P;!boWTs^Y34y+ zMxy>?H@p+XX64|9%h9wPvvP3NMh|wI$u4$rK4yy9+^t2|z#V3LNHLlkT*-m-rIRMwW z9l{9 zZFl`cNDB7Cj859m8h!p-)=D#G!d0uZi8KrAJwz)XSDoS(ew$}igVpxfQr+w_#eA+ z5Cb}|xuH14n)G#RQdQ}1=t?*3^i8)&w^OxgT7*1;Ax1%~3xeRwdtdSEUx`)QWZ_4> zaO~k*Q_kQ} z)WFO78PIN-&8A=MWi{xD1HH14>(7Lj)dtW$c|4Z{jlHa1fDXt9=>3~&=#YFG)$cd+ zvc>~9ye#`w7)z)h`Ygf5TJ?kKYL2?|RV_89UH^#``1gToTo*;rc)By8_%RK5Mz;L$ z4^puPs<D^VM^xu-*_S4OsMBe z-+DHtcPD0xQU7}{>;RqOJ7B&uhuTf z^_7EKDL-d#^l;Q2dkbsj(I|wEwerz`HpqVLZK0oa5}-};LoWEU{Q74C+A8m&yUO-! zjRLeo)}^D#(a=u$9Ot#Ue$J)9?Utjl4)SYh++LYO-;k%FeX<38P`+QV9Fzy-e2zI$ zjXNYu7(FiVbMFA|uq>w2tF56Ug`bg29lzEN;NZ$?6B+Ysy$lep>>N6}x|$DM+0*nt z_57?afQ2jDPG^en9rGrz;js!VLfi}WlZQJLn)U66Kca!46QDj76|JJEkXVHK#x#sg zI1cyq81bilY+{m$>?<^rO+1TyCIvVu!#$p$fiyk*hHSusz*=90@%cR zm`JZc6WGM3aNqb-n;>`x&D9$?!#4oLhNGffzZpu?8%_3D+Nrs3&KOkCr?=1$W(*(w z!4PFjKkPwL6)`);Hw%!{SW~V1!tcP-bxQs~Xv9oG?)LpDpbxfT`QijeP-`N%39BqT z<&8WD#C;Dbh;IksaFuXT~JU%o?U*(7iG}xFwCkUJLL4F;P z4~$wWW<4(`qQR zpl~|?M?OO6{vhW$K%t|mfXCg0`e6qGlP*Z;Kj3`ftd01O1R*oZ85aZdXi)g4D&|_W z4}V8c*J;6`9G(H5j|D|MW*C$Fy08CupiZB~>hxcnywp9A2?XX^vn z9faQj3gyeq!1kpe`wu`-dA0;@kA~usdmR4D8cN8A{{!e14VB7MFGRjqHB=^#ejK>H zLEXBD&s0dYmU%76J_%4#wjl0}Ap1-}2z5_HzBhHgzVaz7u>H4!?CHP_mQ6YVdK=Xb zXt}rf z0s25gYvqzTfIbYe?}NMza_C~@`&i>P$-61x6Af*ZF6IXQryANJAKnY-poVtJVH*K` z7G%E;F1z*K`R76Q_ki}wtc$_(3r)FCPHhP2OAQ^6ZQ3B;R~kAb#dbhnYv{22HV)_; z4IR-A`Ds*;s&v6SG=;;Z{AC3zhkY=GSCa;UK!1sUecxvb3tz(RQ z!UXr*1b4eYC6J)_l@r6m8$!(y2?D*l2Y(w_BG#$GBQa?cCo+)-IP`N@1cByGwjZ8l ziCD)~M8M3p7}kd1S&NJ%$!d$r?_l{D}$-4a3cV;71}B9Lp9C~qcHvMrB@90RG*-UEeAB`@ zd?0qRe2Wq;3B%e$7}I@+(2TH7TR@fa!vBGCW*GJdv`n7Pe6zxECZLtFHH`1i3B#)a zt(CJG{+Sy#+5%{UEMM$%g7d0pf9nJ!- z59_u8h}rI~T&b@K>-7Ve5QTfF`noWC3_vX0hoNQqH->60P$r%b(`IAl5vr3ESh%a{ z*!r+8&&?;zOt~X!U%T9M6Sz|#dlC8$4>S6z#VKdW_N99fAFa?!QpS(e9SC~@Uymm} z*z^=35~nb671(WLBIkWV-OZvf{(y#E(GQne$`?|U>h4v5K(pidYF3E#KS{~!JCbse zAb1CSb4B$&@f6C&tb_vf2NS6t+q5o6<{5hZ2r1^%z}F+HHwhJY-hst!nA!MYd*aER z9Y7u1N8%8hxQL1BXBqB*;d~jJdVTmi(NeL0C@LhbW+HR2n`n6^>pjF!(mTYc@ql;8 zvo6WsXNad?{grs7Der)x-^Y@jc;;uf67;!9l(?_Q`&LX;nRo{b&&&8>oOovHMZ6l~ zcn1s@6@FM@@l%LbW7sYXn1UeCy!XSwmgs5{aX%1=^O(r{yO^jX^9~qpu>0Y)#8WbR ztP0p6@j;vTzD*Ro1BNF8{P20=8QlAWc*T@=!0;f0AAU|enKnT0(s~c_QCK}l9JWr6sfwKL9h+dLBk{VzB;#!c#x&1e-Ne}FJdC^ z?`5K@Q{ExdHf7#5#54IN;#GNg2mF1ooF6`F@n5CzyaVR3j{JRxcq*9#kD#lEcfia_ z@b_2ZS!>4-ulVy07@k$}!}l0eyEM4acg{bhN(6e)U1+;HDVfrOb=aUq0lGhs}Y3B|K=-|!9P}aGl0y=s>VI1w; zNdcX_zu|K`pR9nByc-;BKkcXFpXcpdk6`2$Ll75suFUv?l6oz4kb!G^iP`Jk^Ae2f7j zFE|%!$J+`uy8qUj`|k8A~`(v@5Z*I(axg=ps>l24gLoj<{TaFX3l4rbBxZ}9_=A{q0adUDj+#l=gjB* zMJ8uy^5XDA=DZ2@og81E<#c)vRKL`vvJ1~9CMURL@8AQ8FQ7CPA~`v1b3O{HkW*qT zwA1Atw$rIaM3jmyuOcRvoTi>I#pWkoWx%Gq4d!=~Gs1qLX^G=}$(d@q$#Ew2I|@gZ zMRIo75}Tyn1XM(Fj*eh>j0q;^784Pwr_z%1^di6Il*vwVerEnV5rT z%aWCGwv)l43s18p7uI4UA1b>18OIpCD82#QhKnwTFw;n0re^75MHim2NiMEU-#l4# zxe`^HT%vHZL>C?>PcBusN->AW$&;7YVSisH=3pkCT&5=JD@B*v`+~_8>b%Wb7W_n% zwb8w(_rA%yLW(`DB6)8(3^zxeiB^}~Qgj#YR|@PpChsdcdN@qk5>FB&@2)$G_ueqp z^d<#_p3?rF26P2ckB4cKo0W<2a4oC*ezy~Nad)Q-{~L8cn~x_~g=Fg8PJ(OmROs0I z8*{4Ubt;Y%dRL+&Bv&gS%X@j9WYC)X$-*K1E;tpaMbRMxmr z0eK!z(jYGE8ZCj;isUUJ%c51dHC=@bDpTn3Ttf0Tbu1yOIoz%|lzBV_k<^bX zG6KVvF8Q+Uzrof1E~3xg?cn#iV%uyFb6Tv|=&q(kBdb1mR{SjSJIl4`uF^(Kc=XsijuqfLd!6Ag8 zmk5&=U~e498$@^v?oL_dLd2Q+Nv2ai2EU-MD5fMw-b3lVMLp{1^!7oGHCh(*D-DK< z@N&Rv0T-O7pGU&iU%o~5^L0r>`6?s^!$c$M7FFk)g5jDn0d>%U;=zR?e1&Z2je@bF zwpxP9t`HGiB-E<~5US!?%yAmZ)uz2zLs6$bm57~(AtoA37h#K$;MJe4=MvHQj^WU{ z=zh&6X6Qn4Ig#U7$;aPn!Ze6B+eWJOGM%g z0FGS2uCPedUreS&(=LL#ONBcQxKK`D8@^l=vW-Wzsh4SiI8HtkB$$h-U#b_|3_B%) zwIb{|3Y;e3y<)*SQQ8H7BPV0z2yWDnKH?eNqzfLEe`Dkc*6Vf>lSQn;n>AEd%e*Be z^Iav4g)6CqX-vz!P52`qC1?Wo0n8j4Mt9FUg};!PacabWK}QE9oO(sDS%l7LXm&aI z+$$QLs`MPok$Z~>_|Uj37m?F_q8Yh|@++3%er=6hIRbq%ct8Xmm_&<4jlS3kwu-t% zfD-Z!49>we5%6V5IxZYMsLOyC5l|r&Ijsv?6*c5YL41zJ z7JMeMN&qEg7P)*bvQ7fjQ_jN36C4s*!vOV_KVvuyz7bhh02(Zp!Bqv{i>x~V4R;#1 z1Z$ywsSpedQPY@C4>!0X6TcTq*+> z$siq1qI)xmIM@rO0iQq>;6yg5Xb;VbvXS~IQ)w5Ss@R%+*_Vlmpmz`qqXdJdqDH&)jPhOi@h^VBoUM;~rPGI?6MRLV`f=hH-2hbo ze5U+F6o0^iZ{LXLp!sw;L*b%hf#VNwq>cXR^G>&96H=f=9A9fjWP{U-&BI$wKg*`FojN<;;KJY2kE#Cz8+P&za00Fx-HQ z`OgyhQ>0)_F;4DX1SD^Cd|Hv^zqJ!gKhwGSl6^6r1RB@t-@xG+49ek)_w~!GH16Sb zVBAUL_%eQ##c1>c;_ltMYaCzDuW@|yRXZnt#cE`nppkrQe+F_Z)!nDH;j8?$B3Fs& zSZ8+sP^ah5yAMRC3AMcbghbc7_+gt81W|Nlu1;7xcP|y{{abwff3^3GY1;gK9+;Kr zI%!5K{(!}H7%_kUUa;t=S@cV>P8M-R05wQ4XVr(Kd&25-Sk`D zrl+#Cff|~(@+0v%%TUq}6@x1+11H{K8&XFriJMbdSp*$9if`!v`~;=!i#C_$O8!o~ z@+IJhs{CL6L;n0%n*cvZ+b}u-Y_W2J*W;a1(DW8cjIW#t+NYI<{I*1zVe&h|rFOqm zD0kaCh2tIi3H?caH&VaB5;GAZIO{R-T>O34*ODF>tqsW{}nPW%>8P#3yw&B$xK zN!Pnz;cY^_e~+KD(5fj#Rw*+qxd8;1E7kd#i!=$!O!-fC2EMy~-y*+%q56rF-*z&R zBf97Fa~M@c*5=ROGaUrJP^$Ag88sL;9sq(IO~4Om)F8Mc2W89G1pKmwCQu$$tM((i z=^45Q@RJ)#2RO-U{6`b=s~lQw@^m!%*7`)#%=}nKl}M+1 z)-A~WTrvMKH^1RgRcM2LrasZk%};w&mB{IS;uXk!Z!!NdH^2CiE?c4Rsn37R%@2X3 z%dWcsx%U?HA9M5jAnCFd`jz_p$K3pENV@FDE=2C%iusSZ`8AO$*}A&AE1F;H^B-C8 z9miD)m?}M-sJm((>aO@ZL zjl)#A{N;y5+N$5VDy6MSuaoCE7p|s`tDlPJN`Jlo3pzD;$9L1LXRE_NO*UV!6^zT^~RCG zsR}6bZX|=A3aId|#8j%sX$nYs+tK2CoUVYLUYCu)oDpLFk9Pp|Aka$z{k$UrWPKFS z-*Z|3(^mllyhSkp{S`3K>;E2rfeJXwE7*xV=PKZA@6&z&hALnX-f9eBm;wfSe>O*+ z5egXM%_p~!3OL8>LvEuLaIRO2+{PaQ;d=AAS|YB##^h;*T|t z9X46;4jS{TBl)ktiHs-d_qg)&A=;-?rqTKBr6Bkvj|JdoMfBuIl|MfYdlpk5d)dZ*vpyt|e>niziAmC%$V3 za$Tzo%x=_Xa9`Yl`y)Dw|fF{Z0B_Y3|)Qkkg552fhxaHw?h8^RwI zlxvOn@sui@ZdYws;6ckUb{5>HEEb>D2RR;B&2Kt0Xg=+q0>u(-5`HX2=T@@)kY5_9 z&(yXdzp~O+B}6y(#X7dRewAi}O~N^?tmtXb_~8+VjK{{}aR05Uc>Icqp8DO5J15@u zcf@H=RI@^U*hHiFDHJDOPE>hq0tJ@8|U;owRa%#?CXmWqC35Quo3J!7iy5LQ70fct`Ya?XPtM8>mE!qQ5d-a7a)#igy+ zFyCfUTu$^xj<5-eOGj_lt%w3;L5@@Z9&))->C!DIgJN2jp5FdFhDPhs+k5d*o1nP# z_a1`v4VUl8a4;jqL zep-KL;DUz5XvKY(VC&fouZOMt@@Ro$S>l>@*9b*k=fJ^=hj8tK+?e6-BR-+IOP}u2%=4tzOO4 z_jE(=^c#R_uE?U^-#NgvP(aM%gLb`23(ifT^{OquUPmhi4L!alqgP8smhkvsf3IT{ zP@-Nc*Q=ERO1&o@2U%+sNp0orKMb;Ci&&&GZ!hLKy^d3nwsMb;@bxNFf#c)VZep)C zN=}8xM+AGdRopr{jn4lXQK{Y?!mC)iJL(}S+^KLmE5)OQdY@cKj}W%RD>8Z~3wg32 z>hYPW-dzeAwZZpT5uxtgweXnPj+1aEEyA*(rx53bguQbQz`Vl}+$?guvyTEWJkGrb zy>lckDCEv;v?X?I#K=N!@yA<^oZ^Vlh1{x6cxNNpEXEYQJ{KCQZ4Gg;daAmNdre|| zA@`apyr~p2p=ckdlHSx008A|A!xcTfDFh}JGZNOsU%xr~O>2*PS z6LS=1gVzjuK4PxIY--6@Qi*wm<6*WPYD-qkFXZd6p78o0t}iN&`V#8w^nOFoQ7kO_ z1;B2vlyVj+V6S&FT(4NHSnu-=pdpGSIn;W;s#393VGejcgR;vC7l6T`E`K4UD6WX} zh4WDcL|M(p6&`E5L+>7WXQQTqOEAZ9g1h0=MerWF0D|Of`@K(#v;n%&FnICO-hINY z09sB&Q#ey?bUEIoaGbsS=BhU0wRjFdzoSSL)$L+{Y8P>@2?X{YSV&O`D8Zi8=+ID* z^&S*{h(xt_*?X{gQSzyWz-NeN>NJ`R{L0?fgfGki-K}h(%Znc?g1TOPHqaHtEpZ=u zXTXxZS1KUtwZR0c_o`x=I_~WTgWlIFOhVOf@9ToWTYyY{34;<@# zz7Y&=Qov+y$bQ%pdj2*rHDr(*VT1i#}4or2trYbiz31aw2~jFO4?VY^ZL1Ho9Hnp%;+j z^b&p?tI;KJ-Eq+?WG_~w5xom^X%cMPeG2GCLRA`Zrh2}T4;|70;2;z#!w=b+{gAyF zM`gjq4{uh#tixx-dGI(<@0frew&M4-o)v?Tl8;()L@y$})>+Niu8*7NI49w%lK@U1 zgL+Qf4~OO*n;jVkRn+&o&H}}7OQk>=6WYUfM9P2sn_}T^agu_uwbO-))OXG|?8(qpf zplSN-}SKg@&=Oe4KMKU35;ycDfp`mFZ0>h^hY6#5`L&T26Po~_5P=#jtBw#fm z4DtwkbBkt?JPLnaWyFnH%J(Y=u7SpVNL(A>5IMno$M04v%D(nHlQ~eTuIc1A#yEE7 zBK@g_f=VRw2P)9r?-plo$2o^?wb~QGiLw4s^{$ssW&4EFZ=nvS^|e$^{(Bh03i{|Z z!UQH`+|ij)f+zogI@#G#P6gHysnlV4l)m~wM#^yV|Gaq|00oaQ_$ z+avTAsmR&M{{#;0%=x-#Uo%-1E&oI~uroL4WVtYv+!VWU{+L>dNfDE2Ehm2!N^&M% z@Iu~gs;DQTa)O^lJ^GZMOs0!*@}I^q?4RP*AvBE1^gmAi6o~Zi!N+?5EV0Q#-7!gA zg*4cl@1MYiSqJ2}6B7@=ZkEcii8(mWaq^3yjem|#e!(WIhXRE<R>Xpi>t|}W--X}0ha*)njPAcXV z^T{ATNl8(SJBK)m6Y5UYC6DW%ILtAq9b9ica3fWS-G+^6O#l;&0U!-OXfe=#R0fdFG|Mwhl6xRW5i3P5x|v zj7|SW#f=nE(&t7L@x@WQOo{NZMQA{6gz84+o8le`+>xf$goRhy6(?5Tv zF6Y0POuegGjuYPuN7Jv9@&@k_uT0Opns59YY%BLms^qWs7X@=oW)2ez zkP;DnBOsl(-lRuFzpCiM%Yx6}IIoCByD)U`0(rwTPQe}cQniMkmsSDJN zf67YC;J97`NoOw5e#PF==eQC)$tGq8Cz0Zj^MtbrS0a2KiF1PXoS=<3AB_T6f)9I$ zxj{AyF>Dy)oJiai0p;AF374VEh6`spuEf!oDasR=ef9{1uyHkOjg^I%AE+iY8sl?6 zTrIX@LeuJY3>M;wpc$WDm8*6vD1H;|P+S?P$#t{i4?zMRQl!|^N8%J4uC7Vg;+AV1 zr`ZXZhKrj6HA~JLg(IZAZutt|$=m^Y^|t}E;+~-R#LKZ(e*h>amp1Ka2=FKmo$D<@ z;#v~WwppwTi^m({fRDT{^Ig_Q7Aw@^q{e+Ld$_Da{M9AvwJFy2&Q(aIN1cLYMocY= zu@sTiouy5QtVNNQPNwcsbm`*n`T@P~F(WN?7h3V(1+7kj_?#UeYX?)c!KKYH&}71! zB501UgOb~P1k~*M$gsg_&xwH|Y7D zv3b*|QC2yLGMns-q-kt6k-Ec7SN(~bV#-1vqs$-SnnDX%a!b^JmTEvVHK2{ka{r|> zvjkRqQN}dYEoJsN_CRT6v;qCvbs9S+7wBpA$hbq$<`Ff7DMu0 zb&}mFl6{8cuj(WRQY7vZTHOR<46sL4p?8043teVNx>YARkRlmsNXAqraZ=V@W=O86 zP7+U%Y&RrZs*@Z^se8bXyjqHa>-G9}Insip2Fn>Hs_1&y*-8vnimx?F`z`S%S_ zV*QGge@`0!-dFkemq7I#F6G~+r?~H>;&+v_Mz$)wEm}H6XX;tV5_av^>eSq43aMk21$DYXF%!pxb(bmTF{LXwB{G$P3^cwO}bzlDf^Dp9;Kw$hTvbia;v)*5+4L+9(;(zcA0nq(RKq_|DllZ_wP6qc z5j7(E<6pms7=VBMBVr)_4RG>erb7Qx5pzgk|f^;P(ONI9nCVxn#}PK{Q>%GIrA zVoW1L?vDCtBtJUpT7g<1_SW z3s7-=_+N2~0XAhr@ToyvwUOqOB2c3&q#m9)!>P|2@xx&=u}QYM3qF?xaIYXsr`x{} zz7Z$-Y6UMI1VUHViGC+lSxU-@em^Du9fWp8d%sp2WMr{VGN$SF1@}b{dzwjfjjhVV z-U+PAhN=R-_nLG6sbP}?p#8yX!u_Y$#H356JEE;GdQKgUo1Z*gef;dP_}R--Rvz*` ztKnTwHLl9-)EYA|{SOhJH`l@&Ey-0R72K=*5ncWZT#2uAzSF?WnQ;jo1i_Vvv1PpL zox?IToPl8)ml`Bi8qUHwjDb_^_hK)jAXS5e#p7$t6J1^6v<;v7jG=%PA{28TwW#pA)%k7N6J%id$so~lG6 zJ7R#Z3;`lh*%d}hHNov}08Vh{%`$*$Tw_ghM2@&gUxF#|>%!_r2yKlsFU%HC7zwj( z!52Z%Fv^V77+VSc#QNDc*@m*kJDv_B8)r`=xSaWGhNCG?@#?bq3^dc^HzPLVgbmEd zcXN z%`2qDoH@ez160K)Ar3C4Yj>(!?|925`XYL@j2C}!v;-E=NalHuw)`BF6JTXd6N z?B!ALLrA{|muk`-jZi!c4ob1qD|ldidb_juh{C5DfewzEyi()RDqgXkWze2;fUK|a z3bJobXKnGm!e_F!xIp95S#SLwMmDT*EC41K%e;~cz&ht=pjym>DRAW+0?->bXW(+* z2jITKpI!JVo4ie%dTk|}$N2MO}F4a}8^lE=>)mL4`QbcOdri!Avilvh^ z>C%doH`ECH9YWYuuEg(IP%L}BL8$Jq$pC7-XB$lBdT;HQx@?ZqwJ(hGUsL(FYJWBd z)|i4z)zJ6{HK}kaX~x^V+FL+f<lTGWLsHf&2bgt(t||zLZissZ^yG>vC(lQWg(S2z;he76(sAT$)my&-Pml(e4buiT>3pGDdEC)OWxkM(->yf*ZD?dHSZ;L@H6uZ~^? zx+M#QGYr@9oVFKw>K*Zsg~It?rEo?+YnZN7EWzP+?WD>*b>8h9&<(_;MzF69t#IsJ zs#_lK<;}XyG!NA+Ek&dTZK^(1x3qM!CS6+HD)EW?w2pA<<}M|^!pr|PL%gLxfTJ31 zrg)2$HR;mC=Y@tz4y?o0!T~gH(zw~4U1k8~9Xc9-ea-30CDGhFv{g^hR=o!ny%U$} z4PP5-;cNw^IMvJB3@KH;-{K<*pHg4-ev6YDm!`6|*!?MsnY)z5`gr+ALn$RjRanAM zz+%;CQzBJ`Su8A8oi0s$UTBb=AS7imlg7gg*<}XM7Bc`XHgCKERClOIb%)U#O!|1! zRJYTp!-ip!c$Vk!0Nx>(^Z>5xeTI^!R*Z`^M#c&OD=pE`i{)=jH}ZIc$0`B%REf2V zH8@w}(n_i7Z*8jn4zT`C_G05QSX(?|5x{4%wm8Hhh^x+emMI6Gsprr=z>7YY!P??+ zgcSHp))prJ$@wRtXUD3sh&%P_YLs^Q5WA7|&X3;EG)}%`>np&Nt#Q$XOEK4!k zi~W`%-cm#yduM4g#apbbNmpHbLo2_GUg1Lt7EwCO@#kydbNq_HS z$GOy`!zmW5HtBaiiKjxU(x=+i!`8c5r>m7#_7f(9@~^uMK>xbH*7!$?oDqdX#+KQx zsbSJJi5mb>f+!{$Ec{|^{Jpjq*{uwXl2VbD+nL|=2TWUhw=U-;li{lQ$ERZWC)TqZ z3BI@nB;Do@$1DYXaS|>allEN|lU{h4a4x~MMx4V~*f*|NBYxoe>Q`5Ec$Y^}JWo7} zF3rCV&oG!+%M<%;!U8S`qn1?D2# zRTHSrONDbHu2vHm56p2Bd^4V0b$E8G?bIdLP4Fn3T(xX=t2aMHLM=DW6N+-xkvXmY z`W6X!ZbQC!Sgu+-zZsuu5w$hryTSAhT+Q~q0GrftRpj$CBz(X`6+*4+su1dc%i*nX zjdnMxvf{0{`tO;|IF$1%4&jLoZY`GJ15mw>t7*BRRNdvsCx+e`z1ngRI*D@|Mp}lr zYQ~ql4C%O9?3{|DLS?^$^SN##zPk_woR>S|d&e1X%!y^+H0V9bJ$nDW@T!$SZAQ)w zxN@ceD852Cg}7RftoAiX84PG3uGTjKz{|>w$(f4uebw>yd8W zwHd4}9*04I&tz?JI1EBu8tc56VS5*taiWE&VV2Y4Z!Z+ z-gYC^$@{vi4qb{pD0qjR|J8Z1TJcsLymYk-u14!uoXbb)gZ@}a|eL)adQr?7G%)i9i%ikh@aZu<7Yk6SL3SvKLE}(!Z`v! zO;P5i&b zpHf$~R*UmAE=@&cp`nJgaO|BewOHfkan4j_AxjadL7Nh(EM)0qO}gshSEj_zl(X*0!JtgJ~_UHtx(czb7A ziaXu>lO9Yjy`_ja_Ri8~inmx7)Cp7e0yhEip_5RV;SNt1>RF=a#`9;@fM43 zrBtV@F1}YvyuGt5#S?CR#Y5?(w-k5;w>n#UGFLS{ib=X3jb~Sl;MzOz&Vh)fPU!1&6 zhG>_~dIVXspD?LCku`h20onk_D>FS)ZZ|p};IM%|dSpgN2S&m+PC<7=#)l7@Xj0Df zC>-cKJEV28T%30_7bknJX?<$4yvzV0J4*%4IC}98Dmu9Y*iF(x&f5-l?G7SuQxyq z?HS`|i(ZU!>cP&m20VE*6?(RDW5+z2u4jpDUJ9S7r^O)@guLl`D%Q!3%A6>CC0X}& zqf0YbTRcp_?AEiW3bZ(wpc-pEg-fxXYwlbv3vn_x>g`B(W|jg|xN5X1k$MVeu$aPC zr%S5=C4Pf7uVe3Wt@tc2zBog?rN9QA$z^FX#apaflP*oXGVCG4NH{y$w(ynZkE}>F z^RsyD&eUjI7Kh!LYHdrgo@{%obC|4ObfYIdmfjpJ9!sDatSt^ppz5qo{z|X*XeG?w z5oHxGx!y>y&N&mP^Og%|2rk_u4;US=!%xD!ZtSTH9V{MGKHyVURPDy%FgGJE&2p;Z zLad4ShcAbjyHvaB>&80$E4|%V3R#0TB~rB;OXt?4OB1iG+uaC7#j#{XZfva;sVdIm zQE@d&W^t&vY9%Y!WCASQ`+5Wn;fM8k$LyYX%IgV(oq*%4A84#ub1Va;UDg%6X~=@l z@b!ZXGH@+8Xs~>SFZMV^;JozO`A$Jc(^t;ihjpJqa7E+fjWy|~YT_(e@u@bwlRep> z+JRS|4M^}{b0kZ5JrrRiY z`K$rdICj7QSU<}rl>L;e$AINjt$*P;oxISv!$yh>1U>B_o0l-C&K5N*EiaWx8UiK1 zmjRUgQ3in2c}Bhowym_Gn>+?f__x-w4^dI-uV8~g@e$8Qbbfi&$_R{rWkBw%U|_2#*dxYZ*&ZfH~iOAMfLceJ^eIOm((rhtQO zb?1#TG?yv@n0Bl!d-kj}UhS{8yvU)Z7C4Kv>@&oz_DO%`I#WFT4}nMa0ewX9I%HD2xsuuNZI`C#Xa4;Q+-l!E& zc}miO@^qkk8sH2$#9-oWQa@s7Fcol-{1fZP@3aNEO}1h|ZiaH#x9Gx6TNi7LpxC8C1tkFUo0 zDO@^)eqW?o2>t#@RR~=*`*}vs=yk31-iijrjCBR(6-_uzy2YE$m+`P1t|s?9t`x zwRLP%e#kBxmH#lJqVi8e+LO4Njxv<0va6!@*y1n|uf|$Us5Yip+dEeq!x6tkqRXuq z70|L22_|%dR+cOxqhDB&YC>i4I6gt`GnN<@hvO5~ zN~ZQXoSRKSoC9PnWy#@Z%|6E=)a56*)Q&^N8oUDlR|}G= z6Se2D78Ez&s>MAIOC?ixxrRQq|FILaPvOEOnfo6HZZ!mmqwD>T52+q^UOofWr?}J} zNbXvE4FgvTk}3601=Isq_Cdpf!!0qm!O9?MPLy zrHIs^O<7)5u%(kV>8e-o+?4n-=r8KX=!;gQs$h%9z6tOtF>36wIP9Acm&RI^Y<-Hg zy-Ss>P)1MtPkPBLMZ~dpmNq3)mCRygO}aGks_8bwDL?)N&Ty8jTt+uqk*Z`CA1ZuG zj4GMMWocY>);$etETG7`gN**2!P?@nfU03Mi^Bq{n$eWjs|{f*PgT76+*GGa6Q4KO=vEsQrAF(taIk30#|E<(E_4dU8Zw51 z+h|hwPOPdGI`3+O?q#`Dg@d0k($!jNw*k0TYJb20=0vf1jAQTHwi)V8Ov@T4nyZ-+ zxyrn<~sz#eB-eS>#s?${$e=sH9-lfDZknvV8 zrzl(X*0!JtgJ~_U3|&y*7)|$vJ^9A{N4=lmLkG0cd0*1n8gvrIwjuTS(f6*NbH^r@sJIHdDOC zqSsfat1fk!Xve%SY4T=_zm<9J2G8P6FhnNL%X{-z0 zOk3zDzz{Kuv`FhAgJqPdyT=KX0<-&<7byii_WGeypQ&5VN1L0vyi z-eQAlZBbE!;_lKi6lJ9$C_qtqXd*5v@}4#6!)?alDW0v&JZX+aRqYdZG$`&9uS;>m zK+DrId1DQByUn;Y#dCu}y>C%z13C0m`?~F&f~|&(1NrZoG_|kW-pR8wxVo=fL%d@R zVMoF;i>ivtK4Hc_hFAM2bYFRyjmu`|ZqO`LfYe4<&{CFYN*jUR{i!BnS!vgfCL06c zHyctYUC`5{GtBgGReJV7ldgh~(+$9odiF{Ks42*L11N2F7yuEfI&Y{}t|N1q@o?7W zn})Jnks*Y&^Akt?QQf5w@{=J@LL4(5DIswKfNZJ}V&*zkLGLm{bB$%6+Ca|kXi#b& zx32+s);D{U0n{F8r2&-us|}#!Z!!Q1c_g!tJJC1!$1c46RA%x>R^u@}J=-#yZHcqZWHTZ4s(}1@L!*RlO3%I1=3eT2 zXL1|krvmcX`_gkCOwaviRqoaZLNan|a#z@nmmR%B+eyi8XaHrjas!~^FV4(eb>5+4 zTJEM}Z3f0jQ@aAr^`a|!tvETN-)_(VGi3dyf|DaBGh(V=XmE0**D7ez@Xt#X?cj@= z+qWB>92w03X|X!Cn~W6mv|_P}N_NqaMExFvt~z8`yy9C#2D@oYdGWv_fTrsB9-eId zb^y4SXiZ{kb;%P#{}=1I2-MpSC6NlMHVO0N5xDe=IZ7g@P{raK5e>qngP_f|LO5wW z|1F`kYGLA=YJhvf2#Gk8Cqi_aNc2;bzbag4@pwH7@RVhCj5h=I;o==HUAsU*r%Rk9DJSbj|A46iIJQGNaAp+BUORRPf~XBK;E1l9gJ_;Z%5^4qi8! zMM6E*{3+VTOKcyt4kF)TQM~L}lzUZA9bR9e`8ezG)|Hz;w4eJ&OGO>NlvA$Sw4iJB zA{>|6kI?j!{{`kbp+eJjZ^pS@T+Lo&;(v7FlStTxtLujGm}$L>jop8L4D4&7fo8U2 zfog)IZZMW{_JU5lFB*;kZB-Mrc)U0Y_*8q)`$8r!UK~YSS{o=RH>ls>dY6D94bMka zaj*+7=xTbssy2a{LpM7)$4MMg=F-2*l`mjZR#Er@;Ma&jks zjjdEeh)n_#{zsIpc^`!9fVu)i3vlH;2q3r>@fHGi0$2=S2CkfI0JPkIK8!18A%J^u zvkq4aa!Wpq6uD~Sg5(}`vtz+I@8YI%9AY@{;b!D*cqu0?rST!7NCZ1!uwa4cIR8DP zamnq%X@bkiJqr4FU!#kLkR}Q1h!YNzu#80m(W$sv5OX1k#~NZph)Mi*9hY?Krv+0k zq_Hd!{0NEOZ|c%c>aSq0QHwQE1k2FRUyfhyt*2@QN28nqTY!&|xBLH<@+wfaGD?x> z#Q!TLc$V3+lIK5520#2M3&yWk_c++G0mTq6h@*D0Dp{84Fv|Fp1xr(eW#d7(M;uib zeL`9AZ4m8M76hj3h*9*+2I%Z|YcfkF4jVx@t(~NFKAM#@Oz|EoGCe5blfksACs;g; z418u!usAqs;?jCT)9F@MwKrJh2@`VgM_LOx+}vEwr^;DvD!M=5nY(xI-rbvQHk(Zk5D0?mK}118MMVKYMMWuspkU|44l3X8oVjhIy8b~`BFIve%(cUT+t+5i=L7Sr~CMm$MruR{+z{Ig&@|9rpL z)z3EnWdppMOL6uIhjoA8oaR$E@)$ z(GCu?#towRiehp^w3E_RF@(HLrtEao@D+tafwj`+a%dx^;VTLUi*@rxx~P(|`gIZY zPRexDPm&o8F4(1H^$rC#5;m7ZTVB0`#i`qkbW!U4^es{Pb%qkYpt*EhWeA^c^PRd2 zT|CzYW;k?3A3JnKHtJoX8)^fOJ9K>`bYpGQGSJOkZUb*Sbdw`=J8cvXnf*4vL*|qX z@b=E$>cQn>bJCEZ!LmxOq#MVwWd?l(fTnW#RmI+wesayAZ=3;>E!)z?Zqd_t>lK2! zS1DT#pEDFMP(#Ky2u)_6hOoX;9>nxWza}#&qra2^yXw?9tFFe`?;Ei@LCD_lHK=l= ze`2N(12##~1L0FSZ93lVR73j62E0#}hs-8hFdi+S(b!goV!w{=*A5>2`d_2b!J%K@ zI2zmkB7}o>i~UOU;D!)w^#^JX?0FeMoq`>Y*x;mMxUjINfy{W(v4?x0L!k*L<CPj5~_6onwT^ zfp<+zf?R$zW*yP+PI^7SW&XCB>%Yh^#QTdbOHNG~bsMGWwV{Q)2w#@;nUcD*9ESY5 z6P#pS+|;V1G`@5(BC)X;T$VQXl%+d-5lQ13#+(bW4daz1w6k)(`fao&MY+F4$Q$>+ zz-juhTV1@4St;$=6AX=O|IH|R&1Qb%QA!29W)ooDsKV5pF>E3+(yLV)fAM`p^#3kS zl&L+pKug`}lkl}hRV|QfL;QUvC~8>!Ohlfm5_VgvJ~nbJOFo3nWfrlg2ic+FsUz+pJTc6B;gvUWu z#LtGzn&`HBd_75$`C2Zg_QBedCsj(YhgwW z>>@$ZYyjkD8r4xBxTBU!c_Q$FjZtSxz^f^8#znpS;`A1 z8j7nx{jFZ!`VEv7v9iC5NLLZ-`lmLjDq>aF8?vTnC2YXbNG4`vkS3`BrPhd6Ybv$* zO0Q1_RaqNeJ`1)l`Kx>`@+1}M=P08sy%w~HKGvz9Z%Cv?^m$JG0;fg804e)KarFRK zA-zph|0JKdrtL$o*H2U&f&4NjipUuQ^C^!q9DTgoM$^8;US}i$K#1DIz)V0e%5t+V#a)e24j~q+>>1)^*zA7_bfZKLirI3BT3Q zK6u>bCsf}9)R`vn_tnV_`neoAZmQ64HtCyBA8eN52ts@q1A~6_5vZ?zR8urPx{8Z2 z0Y5eUut?#RFP}OkxopNc1CMAAom}c%6V90BUW8hY6uN@rTbNhYA_| z35nsz?uih*3g8+Nzazwtv^7#mUqt*W(?1NF$B4r)UQpGV$niIHluXm@LNXyF0gZOEqtbtjI(Fe>DVlbFJS7l%x08zXED0-C(eU;SpETr)CiX5Ku zGU(G)Mm4Kylm3`DOE90~=I9h6%dgN%L6r!i+IgoZ#QjP1As>I}&_xc>JbVEe85QVj zbUY;ksQv&LGB#pW0Fa+Yz!!M*0zi8jycroNm67P<*W-xdG`xw(801y658b(~EF9!* z6j=a_!QOaY04`!^8$-O6nxa!HbBB4^+@9nJRVKqr$|mQxn>s=mBfXww&Z z&1^!t=#wOQBc{)yoVKJ#bm>HPG&Vvm`UF+ph$#d#plTDv*;tW`0z;WdA4OqwfrCDe zwl(V6=>IzCdPY8R^E<|kT%(GgMfox780kjEzPYd>@Utx{-3Tj9w_-js_PCX%dW1%s zBcp&n^VlVpH0^SSTsJwWUG4@7)%IJUwgWZSL2Y+8CR9fLJ&bA14MA^eH=cJ_xv4#s zc>`V|V>}C{*Bz#3m8uMS|2i^gV zO_%5JSq21tAI{2c*o`3Yn{qB9ah?ErhfdLUTyi6X>Ag5~j2ygxM2F{b&5e*w@5o7~ zcjNFy^3o|vjaw}31!V)Y`1-#>dF1R6xP>;VElgs@-? zfVdZMT7bYxJ5E{D?2=7ji0!aWKBfgczektM!Fw1VQNxYu z;7o>R2LmN@aC3CR2@9svrDD_;jRT1@PsbpQX z;5kPn-`?lo@!CylmvU|9;PBc_!bOSZHv1zY+DSRq${|{C=pS|ka>*PDO*kosHlmVC z=3rg_rn^!7?nrNRQjSRZxEA`NoO*{s6HdyZEwA3ey8cZUr9Qr=JqOTj6MsPwIX7tM zLbpx$>DdALW&Ozruj_x@M~7Q4c1Fo)sYsO!emzQ0yF=d0n8<*P66M@mk3HU4o0!bG zKUx&-t(U^T#zwEVQ48Q5y=>>buJUj<*k?GAM+EC|CCj|cZXR*D4@x$}NU4Nayy4B=8ki3l`Mv&KJldVaMq)fXq^dD0AjuZVg&{9zK zu|2{t8G_|*BjqJXE^8MDkEI{@^7Y~1a8DoMqUwY1k2z?I7UCF*e%UBE>lj@E1DcW% z+&5-nCZZp%<@@9RfDzvW)mUbOgU4bHe0duj92RiGMcLp#ZtL$2VSFiDiraJe=R0Ae z*yB9bR?mC4PwKJ&&6ML$__q?)C(xmCWPSA0P5|- z)7J=G#CcdM=qJTGlF{7=RU{day{?1D5g-+#+~&c-VNxJmbP?CwuEaKiFt+%_XDS1y zc6LE}I;hOg9n@Ic7<^L4t{5AIB}-p+P#7ZXNt;9obvW_G^_A$`$NIz5B~i>Z0A5BB zcR0m7i-n7Rn#df0Vt!%--JmNgrh~_EF!1Gz>ELvQiz=pXxh?kUTsS)%y6;Qj#DR3I z4X$NH_~@*#OWcMt;kq!tU}Lb%71=1_5i#^-tK+vT9B$YnOFuU%J{g07cLu2V{djd2 zg7pD_caV6VfCB*Dd|ir{5ULZ;Y55(pg1_Q#%o|u55Q5rDAx^w0#rp^`hg+~Jfmb0E}TmcvQ=GGL0{mZBko7(ssVg*KfKrFN=B zF%r*!TR{QO;D8An4+Vz%^ofY@p(I>0LRTQYtg#(D4mp7@-`EZghn$3qYV1U+wsx}} zyYubTCC8pPBk;A$uEKFBz!(Is!bg!C1t-6_O_*SPSVO<6SHg1k3^O>3dQfMW~)T2z_Q9a+)2Iq5(qN z-vKm@$Xo|J+A`k&V-OYe21vFeSSEmn4ok5Zp*m3oD+SyCJ3*fDsVU4fTqVV91uhuI@ansM2IDX+6rJjvey!742`IX zb5yx88G{Hls#Ejh7r)!C>vvGNH^I#FQYPLVdCW$4?=9Z6HtmNS?LS<(|>P*z~Cs39H2;A~} zKEUjaP@Sl_qYm}dv&h>{jMO{vK!cctz`Zjt9PhLz4E4_Ukb4jze(4e=jcV~8VCkX* zS-#p){S^1;Mm58~8cD=owiixn#}8S^4IMk)yjQ6qiXRk((~kKziY$nqw^-3pe@Z~( zIsGYjjg6rGq-=y8QGH2>{?B6UcSRwCo00e(h5G>^_#%MBPvHzh2<`*$HWIrK(hmU$ zeu}?YC*U_i2%ZOU28rVcJoinuZNm-)f>GC7sY6lc@A{b(oe{(sT1w8^bVw<>|FL|i z8&u3is(`o@vs1dt5Yl6$^!D0o315*o6nKf=4YZMUg|A2)EMA~@BVF_wLpMqf79KlewE$Z@TMR;Wjg9B8W}x((WQ4Nw13f-SMSid z{!MqI`d=dIom8aqs~DLdl~eCf;L9F1mqS}#y@SPI{SxDKrh*_*^?b?JiuoJF-X#eQ=$A zq-1f*8^ z1Vz48A-Kqr zQ}H$+o(0L12*FnXRQp_tiU?=qJAlaDwFuBX2*KmX_#BB(2sj5I=_IbI5rRJg7=gqP zg#On6Y)6TMbo=re$l4x26~LYb2v!>agOM1B zpf?6!)xqC9KzAc#?T?t;jmDuex$50iy^tuxDEwFTq~rvmO?L3;0l=59U3E+Js4inH9z~4w*L&#cgb7Kl|VP8p;$33t! zhR!WdMI;X;$w{8FLYgJ(^bSUU^?@(L&wkF`Dfdb+c*U6$_P{;dQu^>4o57&^g1+J z*;q%J5MRhLO8_fCd11 zAkhthJLoE^Lj3TQ7gb!LCzKS7ZfysTZ94GfTie0mK_9|Jw>Ax@gSKdlkRJwtlz%P(r)))>Riv{rI`;UXeVnMj5#z>^QKB`7~x08yo zYf=vKRIHJRs;UCA%c!Owsj7Ii<=afS_l@is;t9#cEY}CgND(q}p{eRe~%MPkE!qwFFOj}shSyx{N<(q8p zC}=b2Utg=E{IeRsKhFw8Z9h8Xlryg#2ewXXQ-_@ph*rCad(C~_o z)zjIy(q8qTBU|J=+Y%pw2h&+u6O}?+7jaI~t*>VEqodL(k`C)YfYf;J3&FGS_D zQY0W)l>r<;VlM%80py*-7(=j{0Qek`a?1_&PEh16@QUB9Y2lYSWaZ9BR6kH^(XWFmMb);Br5X#A*Vl+$WLvlmIGs z%2!f^5YnmK=~U=+DzR^#t%bUSh|jbkdXB9-G>~I}PfYE3iJvy0(H-B^rle<_XaAp+ z@G<1hj*|I*%Cqks%70W2%VZPAAOie6ma@%IS2PoKC06>2!L` z)83L7l?6D?j_uQ9%SbvQUYK@HyMX?UuG%D9GZ4}o-@{xiB2_J==X zy~9=wH<4nsL(~J$nIP(khe2&yK4b<=5KbN1^fsN~cC%x8gKIvzLUeUMxLIAnU(05V@5f!$wDdOKv@{O40bWVRO=TB1Sq zBFPESpw~SrWj6S#l1c>{RH}pXUXZ0UxYh&LY)EB@Tg=J2d)&>_g`eP%G!t<@Nl5do z#YQZod)AY-b9wlynn>jiNh28q=BLT{%T9g-S>|g`0bMQaV?t~0H>Lxsa3}t%XRIOg zfIsn<6C&~cOOzpw;IBr~6O_Kt34gUxX|4{L?mBSandh%1+yi0=eu#)!6Wu%WLQ{h{fUcdb7VXPM#4smsFyekihz=K<{yALK1 zML>=~I>AQ-LOZ?}uG2UVRix0aZUiRejsr#)X{2T#l59PEkN-fbH_@dbEB-jn1Oq-_ zU?~7?&<~ioV=NRKz_)#ICK4M*jHWP?(9}M^Yb-&>?#E8kow|wm?_4OwiI_aIo(`63 zLK86!Y#SCoiUqHs_XL$uyFMR4Ap-&J!uyySiWo@I<~Ie7Q|fgXs7i&0iY!VUA56+C~d_+U#&s|U`mqO!Oo%D zwnunhr(4`e01LGTNkG5YO|W;V*1IXl1|;7C%qs0R!VFBk9l$!R z+miqWu{oQxfwuw}?4=RAT`R;45HrMA1Hf+W++_em*|z=K^wj`{o23wN0G$ZU5bNP4 znexYb&{NBwZ(v8~F^fUqF{!P%ACO(#4=A?@fczdX%VUnGghZX_q>*3CP8& zh=GmX;_n%x&f;GItcTmZ;2w10I7^1U1x>+k=)-YAnfMz3kIBt{90McZN!UpuI%8nO zdxHCs_J0Nu=J`BqWm42A-jB&5n5stZAdJmmni{QNccR&tM`(P(D-f38HCwsS;~st# z#}8HvNfX-JJFpjuNjywyM0}sG(X&I{1LKLVbP6V{o>`O@+E!fHhk7w!!bB2ezO)0w zvbT%U@n8Op^Ulx=^DE-~673n9W%p?sWTD&mMP9l#w=;m-8DnbII{=u?m>6xD3&3*5 z1hkImlA+Zu8kixiHB1aW7McvnDI)&LA?#y9o6W-phPWAe&IK2+Xk&(+cUM9}dkM2y z=!FoCb)gwY0qkHv7lGF>nS{30B*wtq3Bc_1T!T!K@{((glJbgsR7A?2XeoOgDb=rn zbGMRm?h~Y6^|SP3cb!{&eXaVz@j%8 zsHz z)|jyq+nAiMVRR(6jiI?zNhkm{OROi%I^a%h=OUqy)=`d|fd_>m(mJJ6gDPpAqoj4I zL^QO*G{EKO(=mO6L-NTYe{zxsB-CbM=@{6a7spT}<>HRQlKD z$nUSxr%CT9`aZQV`(qhS9i6n4(qsQZC#o2%j%td}!}W-sR>{1{i%M?sI}nxQvXBPZ z2WXwNJA&y%_5fG{X(!CJKvfTaI_khK5x)|hJ&<$i&{zVd@920`e$aib!|?jJfFrn)xdUeZZ%Q^g@m2 zF`>^Rs7OJ&-kYFC3NrQY!I$1xK{0wI!Zp!iU%~Vq(ElJ@Q!R8AB2#pOaLqJclr!~} z1U1(}!orLz{8SW=`49$*hl}N5JEl&XK2lUllGZhJ@P-pHl~k%LTjtPTD){1m!E`M% zTE?sg(C4p>*tZtfIi7($b4e`#C3TJfC>%`bHt{`s!v_q)aR|2{xIY6@6mBB64jE~U z@oHA&-ivU51Y2)N&&h&>6b%_NgA-W0Y5^VZ*{@V*#QeXh-izx9s7{_Ea1tlP1%z)& z_!rTteK>O=tOijgg2Mh=H4Yq}2ATO*dkF3AB{SOIg^ggw0$*&~UZ|mrQ@&VNg?iSv zsC`$3Tp_N5L!BwHyqVDFZP+~RUxQ%s`ev7HuM26`NaCDo`A@4shJk zI>vD;>pPB%El)+lmsnXGx3*ev+{PNfaa(H&$6c&6s-KEot$P87Kg6t)*(P>dEEbX> zz3Yq2L3&aS{XLAFoXnFkl@1~y%&kq(8a=$!GSgdpD@5kNn9y}#8qynlGjELv<e&Fo#uF%b(Q0Xtjd*$?qRDL$IGoD96w^+!SM=f6~`;B7dc*K9p?B^>obm5TOyPA zAG4})yv8c#_&?Sy96xT|$MHIA1IHVz0~|kLo#XgP>u-*qwklR8InP)vINoB7;`ljh z0ms{|4IIBkE!|T30!K(MqgB{JX4Nj$g7maJ<_Z&GF0D5{_T7HgLShdV}M= z)|VW=YH3--|C&{o<9$|pj$gMXaQvoqFUJS0jU2ya9pw0J>l=>WvAk7@|Dcu0@w-+_ zj^DF}b9~6UhvUQ6lN=wh_Hz8bb=;1B=J==;%qBTUtvrs8SzYb;7LGr#98z<7GpUP4(tD^K%Wmn9qEd5l=6|<^JKUHtVEW8j# zvDc7(#a>hTi9No0SIk{i2m0;};CP*YszdyPGjKm)DKgx%K!X0?`E@C>o5YR};)&X> zNSoQct$_fvfwh3>8+$KN%^*y6|G*>I4!jQL!z5r11V~2ry{|UV17kYjsP-&SUpr{g zw_|5)_XfqdaFufvxgy?X6opNm2G5Y#84qAG1|kKRiiDjP9GGv9R5YjS$<m^`Z)f-xWSEsnpO36W-GuIl;ajCVM;{}$iLHUcUOpcdWO*y{b z>dx^4);NwIv`RT%WO)o@j01c#?I5<0;l9j;C7wIwWtpRhQ#itu7qTu%>W4%Ua0sZPr?j z=UAILzQ=lv<9XI`j^|rHaeS|()g^fgtu&7Bv%(zTZ*}DOL2EeT+i4A~*)`N2VPyz| zt0P<=V-oRd{{O&kcip&v+poM2?hAK+&c=)qv*jf@-do zUK4FO;M{)!lxiW`$qD~<((9_--C7TBSM46wBOLcs%WLg{)((b8S?_Z^*7}Cyan^Oj zv+oV#Hqx6?Nr+1y5?W4uL?0T;u1E2((9;YL4{hOiMCb*?17ECxbNdW;?6)wo?a%OH zROyb ztcU!@4o?0`1eKT|S9(6J4~nip4u}w3Ds<4+XV- zpQ@(gX9m>jhg{ZTT=Wk9@o8L%yzh!70-1R*6VL}Pk1H9+5h#t!15F`<`#vgL=G`v< zf5PRtCk9h5;kyCXCxRbB%Zh&1$Mn&<1=AY}uPTO$O- zBQmEiMy;RMJbkdWjhB$}4hW7A(N4xEp9lV;=4pMOy;xlY?uRnG?-nTdPV>|&Qil=J zg9;2HFu$x>kCYrnZ`6O%Je%Lg%U#ekvNi|`BSfk^O!TwnslU-C>IQ;=5hAW!-P#Cq z{?RJELdMOFYHDiSmOoa)CD!d=>6ZgX3k}Gq-q3Lz>LQ?L=+-$j_8{sTLRMOZ;i{MD z@p-5R`6f8tC5`(@{7sB2)ji&!z{#^feCHtL+eE>`O}|S|{Pccoosc7?k%p}h0*g>o zH?1Tcck7-GXmcrZfNkJV*p1Da7U`ZJ_kyB5kUbp&`5`G%X1=4xKlVJ7j0f`82mud# z)f>+0o?*D?U`rkZ!RiQ+l0u&i(0|uGbyh>lb|7~-1omLf)MNjHij<{t%&6%?k8^t_ z^~H_-RI)EX`W2C%A%pIcw29FZ+=1jKqB@eF zI#$bq8R%dSTsa3VwRt&VsZGmyOKn;%SZcHKm8CW-7p-HwX}M(4rsZzDLTQG``Pj9f z5O?9BW@!SHOKZ^?HQnREe1^O+nYfa z!$6F-=2>8383<_aW8uj4GZ515-vvOOrKM;!us_NTFeXFm@(qA^1~RqE7$&(P_C@Dt zw_OD$F^D{&uk6eAK#ZmSzludsSxCV^g1BCoVi%*9; zf`a5fVsyx;hj>5U57A#K8RY4Zl&dJb9bX6Tn#NZ5BOL$PO0E+3im6kH28(0Wg}A*`xuo@PWve-QCH>eGAb7({ea zBF05TaEhcl>PV*dll`FmTA6qs(MHu~Ukrf!?-g!?gA?AF?;^Xis)+-X%@(p`yRKeL zfps$##W|vgv;``%_As!!T-*o#CM0zRRbk%$QVaA}j1?=}*^0ZVz|Z>twZeKuK<=fo zR*;Hd1{pU(5s*jZ2IFk1on+uvMMYkzG6QXbzBts%AFK$-pAv1u6wG@0&nVn$H{iDP z1YaFh_2kx)G)PsQawGdT+zx_a+{ek?rOc!15x$a#fEv$zmpou)HVNOcfk55EC~}HL zqt>njst*e!KUuWEtq%gVhkFva&Z4-y{$iktU5q1l+Ktu3Q;P47g(&G6CL&)O3lP3^ z>>~05}_PoBCP`MpQMl;20yVGa>+9datV z`%{5VBGK2Alz6N57CXBws*)CeHwC)bBg$2l8Ux6ZOHS&)t zvq`2<=(Wj&rgkB>X_-n<)r(88{I@DlMBL;}Ei1H*elwZS#7$1tvJ#1^g^R$wxdKJR zO}^J?-Hd)FnIhsQmu$4|#JS);R)HeoCQog&ZbrYKOc8OD12a*kWt!iUDIyWH!z(kuZqfqkDy1@%j*dz@KP5zU#PtER#mh2@wrjK*EW_CyaXvNH zep!ib86aogjRf|Jqk;oU#^q zBEBx%!b1xhnB)x9o_z=31W-5q2<>KEJQk>%eoXCg4M1}~1Po{exV$SUVIV~d4+GFz z9S>^s;Cn$E26D9VB%mz=x!P(H(2jv3Z87#%1??FKYdg{J3vObdo!0V6U^?(US6#K% z1axGeoAw8GoCTd3=&lJ^ThNt(9@^dT=@fKlpr_UybyCoifnFNDdZAzd1HHBL*x?rp zWS|djNCGf~fxg;bsNI5L4D{3HkhBpD^w&C*v{4KU&|*p2LS}Y>NB^vV~dL#5Ef^LmhEjb80r*o*;Pn0F$xu(`WA$XWyni(N;)#r0l~yuD^mI<(n<1y0*Cyw(syXi# zoxhk)f5rg6$)>6Y`6{WHK3~oSWFO?|m9Cv{G}A|)$|^jw;HyvLwx?J~UZ9YVDf&f!^|&IqDVwXZjXSKyi!OJ@dhBiCoUZ*Xz-G4~ES zK~TBg!Gl5gw;C;UpkQZ@#B$=luCnQT!Ip7X2-%;r3_5MFiK}1+_kX7vnGPT9>=8pi zd``)D+R2ub!f2$!4ey7?!Pr=Jayq3@RZRoH*7wN*5d7w+0?_G&Dk1e+;Z4E(=wG7o z{)bL9ZtRn)(C?fE)n6=tjyuW(*f!qN9X7t8Y@~A#&Q^np%n;s(&^-RH6~TlE0i{rg z4OEC>Nc&&XxTDh1i7h#cD&>1sDRh#evRmP$=%R5w?!vX7tpeGxu2?!)VatT?josjS zh%1lBy*u!%W9pZ5F2ydg;Krvrc37yL*Zmw^SNe3H# z%1trpJST-S%xAj_(WDyRfn=uRrq-spX>)IaY0w?C@*RXF) zF?lyK^#Wcl6K8G7h5K55F%dw#b-$dECz>S$Hz2ddBUpB1vt-Xh5LY=K?xbcJ?uRk= zRE~l8%6~rzj>_(BeQ<9EXWWJ3iDuQ@_4?Wr!ru*yH5$WrBAeCmoQO!N@6L#Gm{>}o zd&Dp&gQYZezp)lC6N!Z$;a^Eo7PBqIo{BI`+0xE^>ab0tZ0Y2F557xgs?1WlyLX`W zZ7HWo%EK(BuV-XL${_dR|JpQ4%5e9rF6E?*aX*O5DlVe%XMu6}G<4-=H)l|_;0;cb zhfNjDZb_%&NipJJD^%0u>SQLM!vsyKNb1lL+oNJzgAC0u4mpix(%*dgdl-Lah3ir@ zPf1w=y!it5XU)^qE&c6r?A^Q)-*ReJ_*IG)sj2&k-gN-!^wh(Y{{3B~E2N%4`T;qv zKaR)3Ej>N*;Mom?i@lAJ&@Q#W4z$Gg7f6KGXEcD;447i%)L}D4xK+$rFZeF?0j7kLDKNdCdX;#D%d)AmEp@Cb6kC>pSTrv{@0V%4kZ;yw@jWU z!dE=0-vBam`{U9&{IiE&B4WziVgi3rV2sT5p$y?)6&R4Yr!bF%fAb{Jjj|~+_X>J+ z_;*j>UWjc+cYc#S@qc2|aVfmZoS%;N(|lK)m8f|2ADkz^wlN~0cLMZbzp{SIu+zq21aVtz5?(X17o$!w*c(pQcTnu z9)W=U3{2LJ-vx}ivv|6;=qUhiFlLta$pHXwGB8_v;#mL(7%0^aW1|s%i-CFCt7y~k z+YBt!TE79{9R`+YJ1`c*2N_tZt)C0by9_MXOl+>g?=i4SyFUQTAqLiH6?On~n1OZL zK{RIgND{UFliIT90KCtbP1?`clZ1~luthsX793+>yY>=}!NVUguv2>wBR%{f1G}{r zegGdauva^H3_Qmf*spznZC3bW1`cRfs1811;GlK}9VYxK1BbPXoEHf*u?j2< zpLLtT0`y4w&_no~JB_-h&quaH~TE9?~rO^5%wC3%?35Y!votMU6P;Fd99~Q=y@iYq#z~(|TE)Jo|t9uUY zGB)9a#%*lC+-Vr}W(2qfbsmpI2$%rV1W%9ZHrKTG*j1xlgVYY+=dC(xPn5tjXIcH3?pwc*_g9}Y&-z>rq^hH zhZLp85tQ#PV>a~PZCujvLK0*0ESw@4e$2u1jRGI8n~nTeasF&ffn5uYQv5Fx314V9 z;|X`r%yF=}u^#TJnR{SRo%irzn{Y49x||C@dkO6ee>F{bLT}^&s-wnpq0s4@JK;`R zVqa9Xsnp01Z@7&7^4)MR<_Lqq??U_yXY>nn{CPX`N|nRl;T|271aT8zgx@b&T}>CpBXRvWyQ-P@n2tkJjLX%P2-> z_!-T7FCy^S=wfVkioxb=QPS=C4(ABmays1|5`Iog=nWaDn(628xJLMSR1M|{{rFd? zw->Z{6UzraCh{Yo9gdi%{|2;EwM#^wgE2HQyow#h zb&*%EdxRTL0K{XvVywHHc1+_RqzzC?C6ZJX|1M((c8t2Q5C3lCmltX4Rr7t?dgax- zGa{ptZrnyPHjW?}^fqGLF>#D{T^Ow{W5PouqX7ACX)mgVc=o>ajdiG|mh!(#@Ssg{U70FV=lYNa;E2 zKyjZQOWP`;y8RMGZ;JYv;RkeIzX;ib4q1f<(5_1rWa@O+LwK2j0!qX~N<<22TCV%< zhlnJ6f+qZk9;)7)6s=5v+7-4U{eC~7l?sXxbtW{1!25OgPgI^AZvl8%caybUZp9+I zN_UejmmHdVmWoy3Cq7LWKXLyI*65-0)i6oQCSEpBrAM z`?8QqnuOi^dOe{ITgAg{gU*kxnEG7W!#ts9&{Q0tl02pR`V!CBk(jog)`PUC75c2H zAls<>X?tTPO`3+C^CkuPM4ebXHWPjlMS%fbrcb*?grCvfq}ZOfXFF}ZEdVKZ>S+yN zh^fVrTpXCx8fqq6V?@oL|1s?Olb8R;4W4QOnAWJX;b9pJ zd=K|nk4Zx#;lDF!e%Pv;3rHTXNY9lk*)~0mPJ1!xi$W6{hFf1sOh zMTC9m2;<^@q>5{|&~fZyxP?5dJ>lmqG@?Fto3vF_Wjkqa*^)-1|C~}=LsMTOQFW&k z6a(dlNcrE`69&RtJZ3&|KQ{~{TRo|-0}%Qyf}ZnO9|1B&1=^U><&xyTMbsHQW@lt{ z?g97MDlNPVC*uJ1857W&FL_eE0EE5@dzX3-9sp zwNQ$Fji6T*)K}k0V|ky)`x&IH%6);L*KG*14cq&mB-14Cm_6n@Nb^&VbQQ;5lW*VlS@Y^2qBLG4_kPPUc$NU?RsULywKYYmJ^R^;Gd&3D5KCGY= zoo+l2A5l=I{^Hw!-d9kL-WFcK@KFWj>NWNNcg&NR1t~>3kB1LDzIK4ZdUe8mrp0G;vp_CVh{ec(Ls zom03?`bN_5rGmEWdOJYp6|`G_@fe^B3fiv^c@of99^Y9=IjHZadGeyicOB3%-8%u$ zH;VFvJ~ac-w+cF|=b+Zip356Oh~@w>>W8hirQ z=vu<>V9Dn9XPDYeD}brSWC88E1x$4YLfVxfz~sbJd!=Z!HPdRafDDZ`-das2%hZ}; zyP?%$pej2qwAu{hXnXg7tPVe|T3b7H8Dw?Ss7SfmF&tTI^*nTUT)vix>su|?M|ui0 z+Vp98tfxrJYYVdaEUl@ik)Wg3X$78Q^meVr4Ez;VYXxy4jxbtduM0j4*#%|qh2U-n zG7+3R7^vp4hicQM4Ql;npr#YL2chFGWI;m<{}PxW7a@DO!^xdP1YchXe9K_z(|8*g zv2O)_M;ZG%bX~2L|NKNKK8Wm(BJ4yhf^SjXlq9GBg`yGr_rPB%V;|=Ny0w2S=3nV) z4SEE&TN1Sh&Y%`(8yi5Ku<^Bk&m$UTd;`p>T08$OH$!q8WOs|O6E$9>-W0~)6ubM1 z%|0IZ$z|-7`+>cKe`RH`&qwys8`xjOPF3p^+ZIb9Ykvm#ZDs67w*%eTUoQyb4Pa1g$v`-!=F)=4GzBOThnF#(oN$4XvBM+fC5!YJ=SV-zy;&-!ar#WB;Sebg$_#6cof0rogscy>{3iS zT=wNPG^~A@d?XC~ME|Z&!Cx5RB}37NXyWtm^yjC(fLDRw z-%p(RcP}J(Fp>|+9q_ids#cXAy{K^**KWsJP4b*?FGO+DZ$L~=BQba+g;1@gdYA44 z@H7~AA-IW79b>H_m2roNXqtB|W=?qs1fMuW>K66j2DtEA-5PrkZNjzr6Y#$}G$QVn zfk4mjUqnBZK8Q|4P&(L%xMnLLex|=4I+UylT&{x`al^WS^)`RwG_bZtc2@@_e?&?I z>toSrbw^z7N_brj+ER`~?(`dIZcB#vJ7crE+Sc6<{HpRaal^2?ZZ+5cKE{IF3f%4p z{s;!ID4sC@_2kjKu2|}n17-GK*s>Jgol*yVd#KF51hb0oVMp#* znN6P3;(0;Z6HJ!bi@ybKKI3M|Z1S5HFJN4$>_&dm;(HTl`Cllz!8cgEFi6{zr81jb zqs5EZGrEfQ!n88QZ@7*Hxg^K@v;#^%hr&fx{Qq<(;kSDRPOk_HUa(Kg_EuOy#&a<%*6 z`YI`4OuqIf+-)TdS#-l{@Q{@hF``Hdz|N9J3^b}X317=CY0N-ltrIG~qzMB}wA&>l zH)Wuy_6uA$CCwOUrd>y+l{9Cdx%S3C09r86LezTVjI*ODu5VD=7&Y*E1YtB68g?{y zoyK%vSYOhPW;48qx-lDL&~045N{*1H{sgb_A=0L?5+(5(^yWEyj^Q$SUu&ZdV~oL| zk2TJr>-dcUFe6UXioY09+1i*zD({3Kt@{_)w-~Z}CV+U^{k5NQ=7!X2Fy$2YHMfG0 z+oial-AL48#r^F@qRJ~C;NwOTUB`U~CRse#q@Gv3w0Ma5E7$`+{ue|;L-am}z`&o7 z9+q^}i}VpxN%8PxdYeU{2MSv}BArGEagH+UK}6t9;vB6w8=*fGk5QaoQqLc&IO8Zi z&gRT1o?x~n&d1Q+#S@dMoTBC){wG^XvuP+6Ptr-ez(L!)C{2+po@}l{hQ`P#Au6=U zeg^GdJT;9FIWqgG34zo2hN)cY${%5D#y^kh*NbPEG#;zr8n$>Q`vPbrKaQ;U&8VKP z#ZQ|w!m1Y)Z#KV2ZlDVqr+7^yIm}_L>-x0un5+5m!NH&y z=TNC7sma_-ybvTe>0$U$q!!SaZUJZ>a_D${%MwkJWxo zBnay#Rcyk9Iuo7%(S;icr;mf`21yxDFrk|XB}y5CpbA1$ooKQMSEjA=lRgiyi3Zcv z08M^*y5L0%iVK4AN%sD{6YxD88WHS`<*jwYq^52>B}BC}5vZ9CTGg4h0Htf)h_5(I z+*;vHrY=p-VfyL$N{^jEPc@~ObFnQAU`5j0+CT%}bOnL^klbu#MzXHqGxYX!bAgqXZg*0=AW1>US!+kA< z|5wUND+NEG)q|ckZv8v0sd(NPA?DzCyh6DyYO}{apr(E!!~|sDS`Ou{>7&u0nKZ2} z0ZQ#1e7i7dw+V-6O@E$psa4bsfhTAyL9e+H-Yp;D?vCN=ww#ZMig7iFlo+$bD)|@| zv$j)=uL(<=0O8BJf}Dwo1mKJ3cq9W;B4754+RxEzb5?7yA<7qMS>fx13x;;J{Iu@p zQ!XWx9i)a{1qhbq>W-fNL_mtwp8)}q@=#$U%=hec$ZE#2N+YtkU@YrVIUK^)!Hq}1 zF#kisn%_aYTGGFR!&w;+%jILzkG=5q>uaQjSeER!d8zh41AQXi&3TUy|B+{HL?XSQ z*SVGFaY^MDYvtWCD zrS{!Z>*aJ?4F&}Nc0+Z~$I#j3y~$~yeI2XV9)#u#Z9*CoXf`(t&Z?RyyO#+|#7kC9 z46hBc>kUGCK99*>E>6jWz*Own5)hh?{2u~y{-;3YFePi)VOj_Mm-Y}IlXeeH=>kE{ zGTH%sY`-c*Z55%;#v(V;gj1k)0>TsWdz+93sd!S-C5jyBz7NE?Hm0oFm-mhm@ebHu zMR-cm>MKWAqFpV%JeN%UZK2I8mts`P@qQOLt5C0NO}*5?YJ}DC{lqHNQCm|#cTg@y zopZIWLVX)Q7Q53CyPw2P_4h9)*1>9oEicwVxfm5Cwq&R+lFBv4+wUF#)>;ls;3)N!SuF0cM+hFjiK9=yveVKoCz$`cRZZ8W~nSvTK2~%3$E|ZUp?Fu6D)t47084w2w`G<& zU=jNf@WX4vIEMdI{p5hGZp5-=DBk}I@`=QfYyyheuPC&kROCTTW)WEu5D$Z78B0Dq z1UoL9Ogf2(|-LE3&co} z3`ekL09cH~Lgt~K>hSos6HoJ$zleu==QfaRWwI;7a1m{nL7r7)x&1-r1=(?se28EP z0DmI!JA&%b4v#x9AEH}i^&uYW(G{`H$UqRuyQ4&#VMTTyksSr17$hwbthWJ-Lt+f` z&?s<3$4(}mmJMDY9_slIfMf}il|+#R)-hSy8IV;O0EE>Ye>*_;Jkh4oC~-uFoJ6F) zTcyVj01J(h6CnSD#rvXIl8=%2R_U#YtTGUPgX9{5l>#6O7b}$!)W~wAr#p#=n&OOE z#7`ru9mv}dOY*UyWtLS8EP$Hgj4ecV5r|13nSfxO0q`&q%b16TmLom8EAh0={D^pH zXzd2cE+)Hxj_Q!*lqxb0I;M3Eh|?fBiD1z|gA14D5<#TWaCCTTI|*U`WV?*U#81O9 z2jta=C3#a6OTF!+rd`I(M79rzP9W)kVC@1h4T&ktlMm?NJ|)(DnRsrhv>H5BIsjp{ z!rv;;tsvU5G5<8#v$&`l?Ad)wLXp3#JD8=?#R_xY^?A;E; z@381+1hJLPx(xJ0G7HKkl4Vf$oFwb=e#4825O^<}@91$7k@l#WyNN{8UUnR)#~_HY zwEdmzusDebOHN%Te*mOQh#a$=T#Gg-UZrKy7S(kX61PiofUMHmvIiuV{M+Ub;Aq0< zM(&K9jB#*uSLOzbB`-P6`Y!6WOwkWHBKGUH@V!z#b#cP#*&LhYJ{^cy@pg9QJv2aV(CbN#;A*C zfC!CO>{2`v#p94$a}?ihp=rdGiN7elbbwNq@=Kh2=Kb! zi-n7ppeRl{pQClhMJrf2&d!xptI{bStzxb@4uvWw9Skm^{B=&gQ_c=ml(lrc_#9Et ziW;SpP9$mhbkP>GoX&RD6epc)(xU9T;!r4^S4vQRj3yWD63RG7j+h{{*8dNC?*X4z zaqRu;JgakLS(YqWk|o*dt{7W#qsz3ki-Gjqn3U@n7wp8?#+JeK00}LGUJ^QlP!b>z z2rZ$ekpLk;LI~j!LJ~;7q`^z-`~A)CDbFK8Am#n!{l9v+-A(cy8&f7xW-TOU_be1c1*-39H;H%?bDJf36d0ER{%&~iu0C1y&urRAbg)!S5Uh&6s6zmg99s#JA-bUWUA*B?E>jeCxwflGG9 z&)wgyf~wC(a&Eka|K){d4`|pGDG+`6bgmx+*rq=8-MdvY(|fDlauc2VPg1x!l$ZQ> zDN6pk6mC})`7dIW{C6oz{`(Wv{*xANnN_gQN&rS5WQhN${o>q)8~9Q4${wThw~6qd ze_-Xo)S9d7n~`eQ^MA5-EBU<;Y?gLa9@!NnLs zYnoW-hjY6T@PtfrKn5&5GA-qZ=V-SML~m$b(afh=X*Myd#VFP_UICNVLh>qd?E04uS0yQXZwQ${vhj-C3zokzUn|gxC4(?9uFD z^)^SYp{~x)fNJ%PXv-1|L^XP$AP+D}>l*yTPGvM>^3hDoIx!lh-Ape|%Y2A1l#w{gJBo} z++2^II+|A;yilK?LC9vslVZW{fkPM4nnN)yiETU}LKo_ycd(AO%g7s8B}~rtA^|VI z*Dyjqu@@DyC^@u5rE=;-ZCR{Iv6+Etg$7`O!k#HA6R>5s&U}fMCrC#O?#U zNSCfpE!-g%*K3M!1NBHGvWHFC>-qpcNYmFNm7yXjDMf58%TV<{rb3OK>s$klhYW=< zr=sg(kDw^Jr#%l`R4zC6DsQSaw>*fHy;;Q>=V_#GEXo+dbE}~ldB$1eIeWj^WEvvt zEt-g2$h`G9_|Y{8vA4B`F}}UL@1c&5M0K8Y@5rVjaN~cLR~4FB<#$#RS5G-r*DCf4 zX9XWQm{7B8`#HPY`rfAtUN9k;ixZ9^ysYb{>AS(d>OHn-xO#8dI0Hie#pGqgsj6BU z<}$GN`-%b(t*H*-zweHc!-4gdXX7!Z@ylsNC0-`ZRu;$MrP8W8qb=$3GB7srUbczG ztFs4zDa$CfrZ|z?*NH{mU*2G^y1m=G3fs#E${!b~zcz4*ja*!^e^wQo{J_@Po)(kV zB}f6D?2+z#8?WNW|v${wN(NE&>c{Kx2$s#A@-2%poxDy%A8$jtJQCk_YPO@?@HP$thSY#iK zyf8j%cSdz`ej}lM3O!3p(BMuLg|dYgD0Es%HV}ia0CzenRw{2ZPCFwCQ)a^yv@=t@ z0_o0*c3`}@G&?)m!Gi(t2@#l`lM}&!92YS$g7mS-mN$jkSw3D-O}u$x6y)l;`9mY5 zU$q&Jo@W#6MTMqWtMmLwJfeOsps|#LGM2iqFfdiRDDT0r%;);z!hou(E}?R+o#=EZ z43|~}#Ca$pwm~UsPM1~mkUp#8^d;l7LaS`>mq&ghkjL067QlN-UReRauWK*(u414d z9DC|$sGkzGGJYWLF*=@&#y`jRVvM0pb8Uy%;+iPim4aSytx;CglUXTR3A)P@8ut&3&?%IxC2zp}~u6|}ems24ygQvnxg^twA z%@tJf1W%XnEfr5iv-H`mwuVy`w9B~YHp9>h5%JgOE86c>R}}tV$e$XH#TmIhJk#iX zxv;&XqJ?DYohem-u}AaqQJp8iT@_W!2X^;}r-g-dPsKy^pE24OD;|2d+2b!UwPJnn z$eHQO;9e-gQ&5RBUdA#px30k?03KKIHH(Sd!g&Q7smA{GRB9PV40UvlT}$bGsn{wj zy+5+uvYvR@iXmuxqV6{+mpm+!0S{WCU#sb(v%S9a&BCLyHV>6cNfyY%g#|-|IEzCa zeya?9T*3fM_m@3_rSxc8W`ps|^*dM~(;Ax5Q71RNqpc}wL_vSdFJZHY1pB*@3{@O( zQP5|{@CDl_H)qI9uNGrc23DK@*5U|@UiVL?(-an*2&FHw=d}>ts`ymiIdh{g3>SBG zt<=sszgC}SIJq^KZlXUNr8E=VKN8jjQS@U0&+d!BpBeci@!dWf1-m1`2^CetQ2Tde znh2vK-XTYUd+p;yYv;qVIzLZ`RiKB5{|oemN|++dFD3bfD=loJ`&C6Zh2>LK^*1X_GqqDFn(82qp;Y2U-3xVN4C_T z&jlcp?s0vgu=IqfW`|SWLaA3^UJR7Y#Ds7DhrB;Prpi=R)gSZnFo=St{HMq}QDkBK zxopNHg8velrrU^S<*xzrtamTHKUnhSQC6(FN0mI4b3u%*SW%Xd1{nTKRi= zK9V5j)$EKij5F=<%+faIG&rlYlkE{_mvTK5rBZkK;uD;Yf#(}cll^!O(Z=D&E_LGE zlHbDos#UA=gmeHT*Vp-_R+HZsfU)i`EE~P&`HMW=rBa2VU!3=7%&i{boJ`JL;whWC zA^mE;H0|4{;bDKmM&Th#{kp6qSug7aJ<)K{%9GkeBuU;Yc=(O(iqMmEi#90J^QEz{m@lcS`a&5L4fgg@!TvM{!yTne?G?y74J|)u>F|Q%8S zE>`tg^eyxECHLTP)jNMF3g zBI!3v+v3SDbNqY%I$rKp& zIB#a^JKrjUmUhQseO8uJmJ@*7Jw7}0#|FyGDf-a|Mt8stX49Clir=*7W)Fut6(q6-Rz|4^+$KRl=mkNORaH#S|Ax|sCc#7lV!I|VF{14E$&_ps-RB3 zru>OI$+qa%X3vZ~g(t7eW|B@shSz6RDey8uCk>TS{69u9Iroqnn0g`?rzaPCrUxT? zN3|{Lumk#?B9enS~{i5$K5-@F&&BS~1bC35H2kFg= z|4Nsb2((m;RXE^zUr|-n_OUGWi|?Ct8KyVouI2e~2&Bns89(JbxU%TwTb0!^SY>Rq zU+Sw{?dQ&0YHP|{c%Jd+2L;0U;ty!dsq1=enRdW{_D>Is)&=)4D2Nj41LuHuFx)p3 z=T8v5IeS2ciVe{dbz?^7LLo;9Hmww;PSxS8aYjX(Hcl4G-JsDP60w-`;X;lFh4q1sAP`R zUp4xnf)F_`r>yas7D>jX=U4cwE>H)7)4f+D?cl0%u#loce9m=TE%Y_cMI>> z_-rJ1#SP-2GWY3?k@rG;E|MeTCXYxq>0Y=M&Ktlzv!rjK8}FC6Rooh820Jw6U1$?{ z_w)2yblQHw<|aRLxZReNcLv;H*yqlGI|FfY%U;I>BTV?ay#&B;zb8r!clrHQ(F@Zr z1wdYZ(C%EOCwv(Pw?BOTN*Vov%=l_#dIIq8m4rd%;CNCd_}5fB%z*TXETXGmLb>8n zm6B8KEugr_qAE{P3$7;BAIB6;!P-!S}N_1)=~Nu zS+U>I1e!1`ZzR1j$kV`cZ_0<_2lD3BJiubg^+ON+t+oyd=jLxK56F1CKj?c$>Ye$| z%uECuVNn)jB^nW6rTO=MtbK|-R>;_QdB!EGD%JMiBZ~Tsfat2+WU+&%|H?pR$ABGbF-o7XFEXT7RJO;`4wq< zmLP2^u1Xn{!^IUG2ERF<4`Qi`mf}H019(d|P1&-|l*)t4pZPIoPY=mhD=@MQo@_7G zY9-5^4_!Vy8$eZ6Fl@ZzBxSMSeLXU(r(u4OJwJ8h2A}Ow6?$Q6KOSA79;B|QV@xIV zONVf(!g5L_lwWcmPT`tx@W$G)sbUm{cU+Wvh>lN92CFZp6H!xT(6zKYzn@s~L=quY znLko?)asYxNx@bqJI4B`MX;0=ot)wf_gEZ;0<0ussHIKlR6Wn;gX6ADQ9iv)>q#xY zGs-llv{dF#9>jcB*;vw$fwRj>#j}|M=bR|tG89~u%er*x!^|quDpf=MoSZv~Id@)e zN0~G`KbUhD6wJ8`)472z3ZY^h2N@%#vcRcuZ*uCA!ZZhsx6+W&d>Px1v}E$BtTbi( zYDp)0^k^zs9+&6DGeMcD=vP!)I)9&iBX-NyY{ATdbMvU~tII5tVA2FCrTeny=4*3w z4MO=aKU2v=%)oVKywot=W-G{PXdIT%E@ zR4xszhg(CWkT)U33%3=+AHpjCJb20yFe@j+N7C$e#^z0?J5rW04!bkuFzx~a-Bm^g z9a`O;+UHaf_?Y_)LyWd|y(g!kYO`%M=wf11>Tj6?~nwj;*OG=UjfuxF1%7nd? z+edOdmWzs+!HHw#~;z!1j{oyEYilClzAq z@f3*7W7ulHNBwl83Om^od4OU#JN$1(uYo=Zgn1lDhqmA6c40?$`;@m-srLf|njTMv zF+6RJb^QCoazpkNI%!F*je0wR6q6u{aD&*h*V)Lb2m=an+pF1yS)+OKzIA z7L5FfVXw?+ksn5;I-**)r#4qdszMgdDpg@pY8*~ZjYHYB;yR-VXOF4T++8%DDvlfT zq4#D(1GDm>^^I;k^?UEc6d8q6v(`q@RIW}d(o>>sdKkUoC{CDBZuiVA+C5ukdLPv_ zX3Sr2*lazT0h_;Y#0Wf3%nAJ)v3WtUsJ)UiE45wb7OM%(d1dfvt={LCTT=_vD78rz zrk2z;6(aG<2+vm2*4&FG~vE1I;shq-T9mGZAP08# z(ohm&m)vgfhQhAprpRuofw6m$1HAJ1nn1HKlhRCIn?e?~UYGH0?tg!M-k++xAtw&@ zaM5tsqi8rR&PHyWS*B)q(>VBJQm)OEki9Yn3RAduYA0YBmq&%aiQ!}-o0G)sd0@S_ zgy(*^u*h3eXH9mVs3E<*%wY09ws&~96Uo|A=cXt2JBt*|PpJHXVi2ae;tEn_%p~StbI8^Z5u$ zT*Yfi1tXy1&7_>_qn;$DQ<7WS%s{#*WC7%6wmryHvqJ)klp2bM7T1kG-Z-p$`ie)2 z2CHmUmRa683m@raoIewm%^eQTVVoRGts;&SQ&q9>EFE4j!NXRkmVQ~-F=M8Lz+!Op zhel}b9}b%Pv1TkBXU0P1i%KcPU}|S_!S_>cW@kkF2pW^u+D|Ie+CMr{Yd?8}fp7|k zr5gFE!6-N_r$9zt&7c|7*%%z(zF=hMdN->q~p0v5j#-P@p0s)=n z6<38`9+E3fkgl;SyP z=p~6#u5CK6iBNIVhual63+Oh&x+t^}35ZiS{ z5{0sH{(Pf8J;p*U=idut_o}X%Qp?{c`eQ?VRm4Ba`9B(5zhQWAq+@R5iHn!2MUwS+Qp0%H_j@ z%QwGi-}mcc?V5d;ZsMCouM*tSFBz(JZJ5ib(^=m0?Y;n z2GZeFm5t30>QxcqZ=wt}MAN}hafOh9t|Ji{96oph>6eNKmfZ|)I+&-g3faLGEBD>J z->Yr3Vbk#1@}8G%+JDY|E7z^uxQ1CSGKbATdC|rd`!6dmS+j1{nssaTUAAro?(fyh zn7pMMhBq$VciEn`-UtU!zR`WHM4X@vS&GI$F2XpH< z1Q=euan6dBtCnqEJ4{J+0HLnAMU~t%ykhD8n}=6!@y!{~(gR`D^&9>DvbAg1FJC&m zaT!eQOV+JCXsMOblPb|k@fIZaUw>dg7sS^rU%F{{(*Qtr=dqF(6C_Dgny6HN$I` ztzC1-$`u}vikGe3Z+%YhHS0ls<+A`|rDHc-ipEr6NAUW$DsY8`f{i?_R&hUa#{{=x6it;iY*&eg*I~>#2o<4WzmA z*D78&JZCe1)=@%t0md5WzuZGjaX~&V7Xj0rhu7?%;S}JE0HZpaHe`@iLx&Y}JXg+1 z;nL{_IE*KSl1+59Y{d%Aj*#MRrG}p)I4lZ6jpggtty;Hie=!RW1tGA8k$dZ{^?Z$} zDz^1#+7n@>i=lltuUR`hXU)2uCBm1l-nf3bOJSK=PgL9DhSy!wID}cz$)*5nRCI;Z=#P?uhFvN1! z+qiTsQ>wNe*;NMxW?Z>t`N|E9W1U2RZ!eS)5e8xNrj?t@)}cml@TTFF`!8L&apQVJ z3hph+j)Rs9fV$!V{pf0V^9GNuo;m*;6x#%%O2&?=z#MNx z8gJZJb;u}~7Oh#o9OgLaagF=T5m6Gwb?%`EivaB@ zuAz?Q>QbG@sneJ=$F;pxrRu0RZeN^N`eq8~X)1Lj&AtAS`gkgRL?0EM45WQ1`Ir8= zCuv^ihDWPdU5XRHJ-0)s`k^?AORh1Blf-R^;x^YfJP?duU_uJ}$aNiq`>F=|$=c;>qL!m(I9FIw&zMZ(*M_2szK>)qZ`ajja z-sy+-#*M0=_BHON&>3~q)ftBxB5}91Jy2aF?&pw>rzLmRp;6*-ytcgAd51#Wnx#X4 zZHQfSbG$X}YYvQE0?nt!)q@7mB|UL_6jv|$zyGc~>FXVc>ynnZL|_qgyr^>0t~#{W zCg?lWL!R(g1=7wn((V_xC(TyjTYd&h?$c10xG8{rJOI;_B}JK$)Yx^}-^4BPZSKsG?GtkC?u0|(5m@X6 zV=>)(>|gN6S%m=9&4>o#>ckx&rmS(7=dhXutHWIyU_DtqkQFQz#$(k-jXOUdU3=oL zfh=+IK8TX+9mieqY&U*5j@<#hFqCWJZ`*vh%552lT}wQhYHi6O@%Y3Y5&^P5uA#*B zf{$nCqYKy=GG7S;xvhFYi>JeVh5lNS-89<7eJ(}uL1=6QxZVhmxSLrfpbROiTMX+L zBflyE!kl~qC>{NAY5UmqTe}-Pp*kFpz-F)JxCzYadW8ESy>UyFXmPl@D6UOr#8Kan z=ExoF=i}D_wq%u`kM9H;UR6CbP@TjLiF^3KD4ve2qyKjIVFU?NtS9adP$E2V?pPjF zCxda~&Oefs+|ts_zt&_4wLO8pS|E_`>L?I)$$m`!7<01NM zbRUF@alDl~Di#r&-7!!nMzpjt#wH-wQ0F(Ci^c9QM=-@LRE`W6<}7k29Yzl=Es1;1 zX|4z3t&(VfHZ_TmPlQHO;>JaBmx0?;kKFS_9mehiMp4sh;7-?=1@2cuSl~{E@&bpj z8K@p3aOY8dJd2XcUmVs8v1+N{?yMHwtim5y9!(N)tvsUE$xQoLch=#0JSB1WM^W`y z#&`D-y@CkY*GJWLU^76u`}C2X{*mit33Mbo7-Jk&3k}=@M?~(p!?YIx^*eD?Jr3+I zJxC3#=p24Jl9nOL>)fwBw^8%Pn#g?t@{~N%KY-5F(EU!v5w~!$H@_V={Cn777&VU> z(KDhlBX{7ZiWBHp^D)kT2d&eRdypBaNoFyd9fF#;TaH}(4}(qIlYniRzXXsB;2JP> z?mcwhEU7*e&v8?<7l6pfVkQ>K#}gCVPa^G&Pwf)+#)$@^md(1MC$8<&UyUeAnv-d9 zshKUaIj)Z|R%WPV_EgcQS(|VV1H)zZnEs*Fs z&@a2Yl6<4}lIr+_f*AN;V_*P@3rc7qVd|LYI>&9~YI|YWSvLE(6=2X{x;yzGFGzkf z#srQEv_=*o?`b;E&};=E!2)fUtw_4gZt(0EJNI(Y7ni1pROw);z$)43 zQNJ{Ft1c6FMT++0V@w-pR|)7fy6=wBz^1!P4jNGNL5*XA@Nugb8~#_90lFYG`;mt; z-JNg9FR-dtlvRbdt%vWYRWG4xyQampAx4^+nP#my_jMLSNyRrDqE$BEeIs5>LA$#Z zxmbfnAi>n=?h+h5KJIYi4us_`lJVLkYuxd9-#oaBbu}%4b_?Tq;yJNHGuzxCtWJ|& z_(IaxE+)b^G&!(0Zl>h_uQ3`uNl0Wj*AMEA$IdlQx-qn+$nI|%V|qxt`#K!zP?6!qu87V) zu!NUOJ#EEnYk@u$X@WGv1JS zp#sQQ_izAmt;gZb?jeA*tHtJ+ukRUAFhKg1VH*}afw<^76P48{3dnw~6NU}Ct`n=C{Nqo_C8M(RNCVlCon@lN6( zu;OMqdX~1?zPJq`;p&d2x4lsZ-OOGd&qt+-9gOJu=zoST68Ef$n%C>bef$v93H*Z} z#l4|Us|pNNtMvyq{8Bv0t}ogWDuICtru!zQzUjWl*X#4eS*6$NS*L&29h1VK+D(bI zf?StJko7Q6w+z?dPKz6K+mlwZ!m0kQTTi;PcJ_!JvmBi2G}|A|wJzKzVl7JN2ZHUW z8?*q#tUbPb3#7I(m@RJ66$NhGK-}jiVFA3<8n<`H6Z?C6;>K=GKy$YH0W>x$FfWISc^T? z;_fPBJJb4FgEzzi*K)in2&D3Dp8KR67Ri*Vf&C z1$6~sr9FD=F@;V{a={loP~H91u|%Ak0~0oL0kIau(PRKFV0STWP|h>^-7nxTf=x6X zCO*V3lG|(2a$uF0rw^E(Xom+g5 z+5c&;EJo-&>sSlN7lEC+SMJr00s_Wwg?&%}cqU0_D1x;{uvuVQD9U)ct22+LW z5#TOz*B>sum!-J6{*1NBe z`1Xyg#s+sE`emu5oko)qcOnl3=6OT}B~-r(P5XTj&oGq?+$RB7+YB@m^~8P6@bjuV zI+i=BWa@_-481BOrB3spf(HO1q%>GTx2w4v91 z7PHoL@~dz&j>jLN@s8gn{LY|ar+esdQ=3roKCMbgG_`YTZzoc7XAD`~Fev%ST$S@X zHT?F)r3I!C{s;Z`#=+}a%YIXu9xu|5cGGBvnKGM);(E8Q>{omgEpd-JnHx8)0Nx;% zcrj%J`40N38$s>?ITBjqPTBi%OI&CEgf5yU*m%rZr&poA=W+>5#di10gS{9$BQc{) z1zJKoW!i)4#y(T7T|0)NKx{w=XW8xO9@_<_L_oP0T zkK_(7YJ4uZcJ5DIYqzVVm+6g;QUiB;@LPScP|NTUdc9G+UE&sE_%w5Y3?GcQ>%kec zz@5(yBcc7{xHnm_Kzf^dCXy4Pgf@FFoIED(cRw`)tJa-=1UfETS3b^96&z89#)XG@ z!aeQ6FfY^;KsZwwr*N4X)1N6c^+WjhVO~XiR@<~l^zp;gQ)oMrJZD@#JYC-_>tJfx{$1P?VB<^Tt zOSp8nqrs)dtuXy!(tuP=%*D(cU^6P)!c`xq$M$iDEX!Tvg;bX{J(FMdJ&Y8z(KfiZ z4l6Y2jGH{i_v=Sh?YGYqFIA7?nYI@2BLve*5LDz%E9t+u3KQ&tXvUIW{S&2Ec?;^{ z0&+&z=L4^tSS@c|yW>8t^KQxG#Xd>QMtv>*!+y^R?e1Rl9~%36&=XXv!QET*CEh}% zI;L1A4jPF28BV9nqsYNUllvcb>e^&0(|VpPU?mcFyPv_=O?`29k1dq5tIeZg#d2>9 zdJ{cyXCEmRt8v9OX2Uot46AI3VGOc{V~Lc={ekmSeuwmDiFo2yhYi?_>}gg^geRzZ zN*s0J(fhm`>UH-riRM^A;9yAHASGBzocl5lR7Y$Br3Y={{5RXh47B2Y4X4*#d<5Dp z^K$=TQOh=v<63Ji;<^t(w*DwyfVM`}lKT@d7oedaY!W;g=VB{iWVmNyhz*2qz}aec zKL%BwpOTWh5h3dm@oA0wT6NBTMvA|pg4XS9bo?t^5z1^Og1_5^aZD6b0(Jq!sCGYP z-QuXW>vLdiv6;=Hm7tUPl4jvyMK%OoiK5jeFszLqi_zm-L6A&xC{By%_Tz`6(i>;~ z5UbA=@d6VVlAk`z>!aVcMT}k^X5{p+q?d6GIN8c#=+y2`x7`GTNk?wfY3A5V1{$2j#C6#f45nY( z6748poJmKFRs%BGeLP@l9b6MS&?Mr^KiEssA19jnN$%XRojsG7G;4F`fj}vFcU(I+ zcDovY%L*(MRG|-!iL~(toPQ(kmW2kw$Dk<*@j>xV;*Q51UWykw7zfEHVWj16Ok)fa z_}w#!7{r?XjrkAzN0@Idy7OQkoWwt7$wl12Nwx0#CC^Y=A_DkGVHn`_diQ)VXilsN zJNfT1XkI_)RhtvXn`#qA_(iM<(*e&dtN6PmdPDWy~?y+Uj#pG%VJIrppR6AF|}Dou*B0k7{gDUpc)WG`|E( zcYvwu@h+wJ4B4u&zWd|a8EgcSfOF$&*EqnO{!)UVIHwgdY_xTc|NLYGR~>%6xOtB4 z4bq}!xYfO(W4z02hG3;h?m{Zg6Y@yC=c*;1c6X;9YU`HXe*!5?>uOC_u_gb8${Z%e z9fRhTXu>Y-m}=BIy_^dM+)b>NJ}(dNwS{g))NOQM*P5_tFY^0<`w&CzKo!7yPp>8| z&H8_)rA`jTBQDn)!}>tGR4dMeAg=p0JqP-BbjN-DlyR8sHhS?rDpxWyV@ILdce9 zf?#L}D|3LS3to0*+El;9%G@(?-;1Tz$9pDCL((?au@#8f5pn0)mhAQ9-Cjmd)&RTQ zInsQLipGvFrzP7Yg{-J0hRtKziy`#$h$vG~fZyShyff0RM_rpN+3p~+P z07fa*fAdeKI{U!S0@Y=L2ZN;K&Vb}bf-?^pdetOgsFC|xmG&Xr?Spr652DKFNI-t!W<`%5@Fe3iwjvaNeIRJq}BfByiA zw;WzT#(cYuzw@Mhyqxn(J;@WcEoXB*@wR<*0PCF*_2xo&R2}K%C9!omswA#U+_$Am zW#JPL{zezIE}UlOa~(oir$IWfMaFipoX}t*_kQW^ZZfA8da&5y&JY7Xwj-Vn1i0Fn zXu;P3ZAvOibZ9g&?wCc}K1MMyZrefLd|3dPd^nDDsS&%=j*Q%2B!qTT19LZTSFF+K9?){0>P|QW&a(>b*}$>Ef2xk` zKlcP0Fg(VNd`RThnkU@7P18R$aqq(H86VGbTSxJ@UE@-}pP@CFw%Cri$=|9`w3zeT zPTFE&I-T9#hI7{ui?ag;>51c! z{yGJyk9!td|Li3?SWu@J20h_&KTTR7ec^<{f)9*tCm#VJ8&Gah&($T{`?Ii$G=1bn z=1MYTP72ulF19t@?oPscP`AB}sKt-y>d=Pq3;hdJ!L7B!3prD2+})Kxj|)IwjDyB; zoZ2ihpk^%MU#VO6)A+jgK6T-vzq7q`LNxuta_Q zCU-uxqn|gj{Qt$>Xkdx^dTB^PK7kQ0LMfRecGHNTLiqPcI1a=;eJD7)3?wtt-9R3S zR3fPEpVHl6@hjX7$mWyo20yg}w#Zpgwi`Tt7|U3oFE`MW-0u#vDJ6`~h27xs!@_QG zMX2&y^Y(1(KFZ0qb^{>4n%w{oam8-%NO9T!%Xfp{xv2SXZ3k;?JLs(34lWDZ!4vs* za9P+6D8eiJO1FcDkeUAvYzManj=A@+m)j0bw@srHSEt_&ZiKH)e$M=N+YLT}_c!bY zAMmpC_k{pg)=|5AB#60d(%s;ZbT|0x;s3{WgDcr!CAj}siQNMMyBpHo;DHgl!OugR zup2x%VmJ6;rDVT10KFxZ?DFfE?*_+Kwz(&?xg%|JPhmGWD%}k(WB0Y);J(BDKeij3 zi1R<}2H)r4BHIlvX5K1x0|kdO848GI+Duq$8fChE)&ivQXCRLT`mo5xPv?2J0zWK< z>T1{PZk0E|{SdW7k;NVPhB8JfCefMI_;Lj7L?qc5+z-zm!j^!gYiC~L-6~?q0qS41 zpq#ie1o$foy&laFMps#aa~eeqAH7WVhiZcgbL)ZLHFipkS78`)2lkS?f}^DI=57+Y zhU(oWbjQ297-$DJ&HlakP*GUH6Zp+C)N9`p|x zs_mr$$}=E;UJK@GbqlVW zgOGa$p|)^OtN$_9JHpL1Gur-6JnA=^hG_?lWG}-8+h; zyWsyJN%u&QbQk^`OS)F%TtUhqL`=$kgaCklODWf+&7<1=!u>5NS8}|`TkY(f;;QAr z@B3nK+8obOIj?2uapJyU0b7K+R&#FuYWF|+GB_dmTkmNNs4MplGZGRvW9VPAn^#U>GWTB zk)M_pl4bJVblL%47RcDD*F&q{tk(h$!HZJ8um_cBvU?=vlx7SnlY2}NIp(4C9>mi( zNja;Pw)0u+-m&fyPCu&?oNTsNormursAbZvp91fhyoXiY5|6Q0k9L?h5cfva6ZP;O zd^N4^(y`#-Uf@JP3e%rA3w&$hPU1|ivKTe_hp1yZ@~L&}qUtspynsG+HEw4-zV8*L zcW}f5+5l}E)Zs-7y8e$jvruL5DGj(Qsl6hiJ+=2wEBDWd+xmy7-QW~BYnAUM#%H4Y z3{lxbaouSUt0$hwHBm!@+|1#IA6{7QOCNFFoL;Nv*gZ%%#!xkQ-*!Z=!-Wjq_@#yS zAJLIPxF%^=%@%hh3!;q?KUUovPoEaINKJP?q19{IyjqjRy+c4(ze0i)v>%rvQQ$#Z z2Qq5xr$AVv_Kp8)YKwYZ?tfJcc>aFGswTVCeDT&C|b(>2JF|WdXGix%nuRHwqD)Kk6KDs>y*$aXJ`MAD-jD5sP1nA&HxBsc_pQht;y&{cw7{SfQWznuI{+;C&v#}HauC9Yj3 zN}|ynNV#oYw>YEUJ$wWVD1r59qvk~S80MW7$m3+JbS$K-b*FJ_(M{e`P!CgxwlcmN z<9?zyZMxi>=-I@{t(iFSI6Zf8WQ^YKo*EYo^=c2mM$qZLBRBpa(p z()LPHs{P&h$;y*@X*8o|EPHiC88u7V-$AK=Ak$ef1(wg$WjSTioLD6?cUi(O(hHG3 z#_?rDavCXnR<*J-6%&8)tSs@D)ed>Xcveg(#%*QFF_LeEWKRGdnfQ+iQQeB^To zDG8R(`y?6_@*f$=3K_7-#gk^hqT+JPfW<|51}vZV%EqD0K0fc2s{1rmTq#WzKb5(q zAVZqqDr5>%5-YXz8J5yZvT9K{B6$^M#pG2$E6YTsCV3_*o`R2tDp+JgONr~}LV2ku zACcZlKuLNudV;Qsho1TJ+4lEk8LnuN^Q!X1Q4qLw>6&#R0TN|t7Av7znZ=6770f5b zT)(c6$H~&fg)B?VwNgis04k(fgPTG@n!_zC0b{X7ma+}z(Ue=}s+_Ydk6Ph2PuLdf zdoWqfD@uzwueeRKRMA8oLBIkX9Ew;UuTK7JkI5bw!%1+P>Rcnj96KT2R9;z zmQt*3*|KckHB7{s;iVa`QXPs{*>?Bbeqp;i-FCpSN;rZ#gA2s{oY)TcKo!bYv(j-8 z!qUg_W8ubKb|k**q3LMHip$z{bpSPp?njOmPNeG<;XrW2FFC%Q;^FqWkD-n5erbFb zeW2PAF>=rlmG+5i=fo5G;@Td}OZwv|J6Y7K_+E@WG@AGIVoe%qEqbAn!bW$Ky=gJk zeVvG;dV;;>$vYWsVnWh}&oZg!o_sz!ooH>Sw@r?!g0fyAs^1$O)pK%Gd)==HE_?-qtwfcu zuZ*yL9@Y1GRM8ews^0R-QT>Wged7`=fVU~IaDjNp$bG|+7P;B!zN&aG9=lud)Y~!8 zS{;HUn&t;EDNplJOix)9lRdvjaWz!H@ZH6l_<$u-2MJiJ4X^Je(D%_Qjs*a;Xtdb) zpJ3SY?8L(@^oT(F^4J)Q)A*tSnQ+tNxa6sd;GBefX!<)=b6SPq?gcK2@Qy;~piYXOikJp=bg2jgq5TwN5-39pJv$)}SheU~e zI^6~-?d8$^3kc;>bbqZy_a|v|e=Ub1MEC1-MDGS9Q&@eq?h;IaMYeEW=f2NWl;TB{ zp_@nX&J+m0DHuz%>C4u;UYWM(c&ya>k4#6Wy>%dTCW#k1-6{e->{hcm)$NIwK!dZ% z5`9B7)`)rPNn9WEffTU%oZh6NOl8wG9^kKcQ`FZaw+u?e_!O8ZyMJ5_MyA)x z5XF}?PVBZ*FGq9mDburu!m3K{=o*Y-_Xq6R8g~vn(Bv-l{Q67d*KsUqAJePxw#l=y zz2lWPP+*`RDo$}>zzj&?XD>Ic2EqpKtBM}H zVD5Xr+bu3I*l6#K{GBK$BD>T5%$$wP;*JBzRE6`AO~W=5USz}3+JMMDL%B=D0l(y> z!Ks559O)w@WBpjx3?ZvLe*ZA%!C@L+=l12 z!d(LJVAb z)k*U+zq~P9G>Tz@;5QM4LjG|q)nc0QIU%1jb$#;j%CzJ>DAxCuV};#n9aSWV&dO+E zgD%Uk?w?}3^OON)x!Ac5D5sg%!MBhEUG35&=v=Q+wswqMjgKo*MyCT-T6CJe!W_{r znGjk|hmhT0t9j{i%k@t_=+Gnh{&QRcmIj*pPoyxR9%h!K+SA^DUVv-KPipWHlvT^uSxXA_6^?Y$(mdA`m;27V zU*XjK!!G?vEH1nOq%R=TDGq^nhiP%Qw2;1O_U?LZvZr0BXmA=9SART#beTP*8)$0g zR=VxG73zZB!n?3!fuh9Sv_Cg5%3EFuDjFT=q5b9=!5pJ^XAo!T z^u`LAVcn%1hB(xwCwcS9--`zOp~nzwhnq#O332%LE}cEpxK9>SV@a8t=01V_`fjp; zaw^9Q?~$8s&3b4?WLr;998J*^_a+bE(>Z`XsY}z`1+-sf?Q3bTcW$U%Cj*h}&w1@; zGbpFItIE1lOb;U>@l6cTl$avkyB9;UEot#dKl^xFP*Zeyjj-iip~r2`YTU2F>$XOQ zKKDJq)|0@XAAtJpV&-ct`lrS{8>)&vq)Xv&Q4lXOCg^fM;LZ7P?AQ}o#y`RSK7aFQ363)<5G$rouA_1!X-Nh0B z@dm7jM|$z}4H?XRnFs&91x@*Y-gr7^M`vOjVQ5D~dh=CwcdRU4b#5GvsBlHT=;U1_ z0#;HFD)3fun+#>*Pp4|ciMySX{)qU^FCWr7+h}k*!CWf%5)o~aXIRnah}^{o;qIfT z+ih9Q3&VP6Y@(s~=R5>kb?(PM(Y;kXc^Z{`j#e@($K-Vue%!-L5M)gg~$C)tu{sHC`^Zdi1X zU}$c)j&3g!uEU)~WOYpX0WF7kI3RQL2xLy9nnxyjzuW--F^rYdA9pg|p18A5e-%}u z*ZFGjgtD-<<$O{#KdrY~-SNfX_6WQ4ZVOXvba%$KIy;F|j^Ymt#GPt{*h$>C@a)k3 zwj+mW&r5SDN17Se=^ms$?^}oZyf>$?W?oJl3tGHiSgSO)`l|#XBJdN%ag%O}=FVd} zQ&G_aZf!+9iY=tC|-yROf73aBr)qehQSTtd7@~0o_d!Ah<@trXg;c z8b`C@rd{KR+(c9HtLex7&JWimm~3lkI>zTl9OvG^nr>Bl3H_3rr)}U(fLsN~<8KBx zb|N;K-l4dG)Dj%+iYm&kljfLc8dM0Qa;!8FoT9X0gA!Y|^m#Scrmtx+>^c?ilpN-y zJYwx)pV{a|&GC4Md?8IFfNK`C>rx{90RsjgB0m zQ6JFAF^j)k2{<~EgVYbdKEFgXO+sRvJlc_)M#7G`$8DkN9BTAIwMlwhow&6_mR4IY zZY${(o5k23%KKDmV^Iohh@|U2lhVkmbH~X=D>-m8-b%URa1F8q5AZVB7sl>ugogM^ z=IEp0qoqjlpvFCSNEURjwfl7xgGp}uP%lYdYUY(9x;6ROSPg57bd3J9z)7>hG+|l1>Qh9RRAi>-(Ev$}>x}zWA$Gx(wiM3;i zW2CN92%$D;yR23c?hA*t$xL!j+bPYU(lIHSJAv6(vtiXvY{lKYoZ+-kxot7++$4qN zuTc^4`qb8#!T#J>t6-@}=t5REn}$V+eS_fw@CGZc6+fFgnzg8E`paVj3l#Z4(C4ukoxK^svmyhd#@{1jrN#E`YgE;eI?XJx|Nt4O>LY*ThJFCI%}`VIIm z?Tfp_H+zM)do9$3h($7UI{v}tSC4kWz+M_vnCeqwIfnuGqnmp<%!vr~;}0P_$P?ro z@z|@9-V1>-lnmo%zYu&-pN3CW9iAq=xDx~2B=;=YT9I^g4=maW*6@;KNpG?^S^~TQ zN{5hza5r$H#U`%Z9kgXfH_|-C%d0S~yATn;Hx1Z+uL_J$aVIBBFuAz?2cGLY-9;R( z)v$!M-@wrKb6Q&Kh}BdEfo?L|NTFtZYGOFlLE+ZH!L>FKL}?zJPZ97ZxrZz>S)==m z2d{!Ce&;|uNsP8gK=H8>R`)ICts&;pvnT!Df~3|L2KeH^IO1KG?611o&c@Sk87~P#^J>D|20%Y<7kBI#_T4@< z=7B_wyR&>I`rQeZ`jT(Z9BQX+Dj>&FvbtIJCI_Fb?y1dUmC5en zvHE-nlkz=?UTV|stK~JB#0IR$*I@x~Gn<(kX3J}dCwGy}q`zCcGxCXTtIsYcqZai{ z1^v!=GNV{%INex@)0u?0_PON{#C3V$`wOM7g8J@E{_<$C9-*!6&dqy$y}U)-JzXYt zzqIChHbW@|2?IINw%lIwM+GV!ceqiBfk(Oe=34>O)u z@@tJ5V3)8sYQ;n~?!^F)2i=MLCfU8TO0PfEs&=~vDHqR5Pea6`I_|*Lg#LK9?sx~W zGb^<(-rb&>AV}O37HB`meNsg4F>p^<4#+<8rLpx-iDz}itER`@UAoZTGACsd(Vd8#3TkwoslW#DAi2OL1x$zEY zd0a9r7Pd`hxF(e;Pf^X{c)>tCcOc%OM`r25&}MF2!waD9=yDaM(|rZm(ST*4+wyy3*y#jDTQvWAbP1M#Sl>r9K`w`}iB;u7+>#;oM}gd2hR z3i=BvcU8ylCHL9b$C267Y-r=tGxOa90r9!8o80fk{bZ%0VO)Cx0@S+gD@LMbQ>(Cp zfD_ym2DHz8H(h6!m8~;rF62x^$0<`?Qg296ixV4+(AuO9TKSLb2C$_Zp+#{c^WTk} zG0>NwuH>K}kap)+U=ehH>}AwTD~Mqk{}nOmX}G8DlT9CHaSz0ML2kTYsg{0hL7f49 zx4S1;40jwpBtR;#z$3S_WI#JG<`hkU$UQ#XJCvM?T9q7~Ea4j!aGA6Zwv=2S%M=Ud zv_c_6t4Id!jhhbua?rj^`9jr*k^x|oW)q)M@@z5;SSl|WxKMrIjktyp)+fDERG}T0 zgVMa~5z)pJ4;6-{q4c{KP*LLD5a8mb&1g!q5O@;7cm)(oU2=aeUy7aXzA|S2T*~bC z<;*V5xP{|Y$;&SlyENfE-I5aGR>052$e-AJ_0@}IpMty;&_^~)2h*^I7?b^jN2Ra* zv(&YtUxB*D)*8`0JD2|*Aa9Oel_GHq22xY-vO0>6v2 zfAP!rm^>HXRA{EDnB_=6K@blVX~eUqDd6(<&1IZ~61#Yal8CoWk|k)BUjJOID^ctv z%9-bTv98QP^21>%NBHmv0-J13)RyL!Gs1o$+kXbON++5c$rfP?_gs}685l4#g#VIc z`fjK@FCdxtWSWq~|JCTm4|uihStOI+d8n$5a|4bIz0cYM$(67IFN6lBm?e1Rm?IaX zs3g(Rl>Cubap@kKx!tVfjnU3zpF66*h%b+ARfP)hA@7C_Bf>dcr=NL z%BDWe-2rwb<=2LQPahy@R&p0M^d`H~H6cQzT}lQNLeiplkZ>D<8I{5I{0$N34v2q@ z$GD%r_A##Jct-`DASh(mPqyDh&28EPv6_hRK~y)OQ6e{`3j89GQa06{Y06JutZ$nz zH~MS75>+A{9JPh(IlSGfRzI~?b|25!3F3GzVZSxgD%AcMy@6-Pm|?~|F>dYTZcu16 zN#BwS(yrsac&hJjoOSM|5GSdtHudF;E;Eppq}Se4P@Yv1qgjEx6;@5}E`VlU%kq@% z=z%4DYNCV)%E%hIpE>0NjPx;kaV%;n@NuAcXAA3sK^?8Y0yIFa>yGrr2=?6PpKXb#Ku6N+QI({tFO}N%5otA!u zD<4xeTydvmFrNWetDv;fHBu;0V}8olLmbQ(KAIRu98hj)v}qnXag(4Pu(|i z|GwN*?vFZ{a38KQ8QAUqz~R8#Gj}JP>a&WwbB=;}J!tJUZIDlBdEfk{vXrb^;<@Q${_=7QQ|(2Q;bhp6tGr`IFo9B1u-Sw{cn>REhKmL!tDv9f2a_}M-F&p<1}_r>!oV|Bi%0d!8Q_iBcqYZw3zC?LVjrR z`)vlY$$bg7Yh^c*S7BQJ8@TR^o4n2N=Ri4Ii~4lb7jr#25fZgLMP0JUF?CYD;{erL_f%BeNv{ieKzdoPn@ z)R^WDS?uW{F<*n5Bi%bRrXKf4K9?v=;E6lSxYP&+(f=}%Lk)vp;ARj{pDCA2c$`AGPlgNSxnVfhKG$?h_0qpVI=ozq|)8{}AYFoUmwZlyAP;U%74 zz~8`~9>96hTxaQ*Nj1b55h&?)HvwB8p)op98VY$Tp8tBWT9EO4h19=Daq7oI?1a9c zKss?qKR#~cgJfMOLi$2UA1b`JskP4JNp94yXxnGQ(62Ut!lPm<9ag@?BONyv9_avx z4+aB{fP_ADktR-x`q&5K2_V9RmXgW-V<6zOAfPp9CUpTyv2Pt%y~HCK%Ox@s62;6O zcHxoQljWh*@aMf71EMRQ$Duw%NTyDSF(ig!!t+UgI>q*(R(*tkYk3{{%CTK9;(F3h zOxj3p<3?~^6iZhuB|F7LSx6xia*b>R4k~Iua?LLk^td|!k-5d8pdhfo*hFBfUcN$0 z?qSg#wiH85EXwvt?n^ktG}B)wnY31cx?N;PZX`zFj4pBHYcsW1`!;GPC357Wb1vav zd?Ng_PX5*j^r))_eez4bSpQMne*1VdTH;h@#?Y8=K`T18M-}HCWUD=mJx@;uwHYG{ zZpGcgc-&WULX_c}g4t&@Cy?L@!D)-Cnrd6B@-!5G0QoO~I+kA}`nMs~R0(vzS|**Cl6 z(nh$Z)!Q8}u$oIP!O9@khUf^4j5dLmD4*cIMT(*Xk#cpTQIk3R?)u0Nicc_Stl`P< zC%USeA9qN{-^Gt>62l56Ne4_hNnuMiLOj|=Iy~I*q#ZNlzg&*|he-FyMA)%#GjSx0 zV@i>*>$#mWlL(1B0Tvi-V zljWD^!|-Uu9W&LJsSy*TY4&s3hz%E5CQZ>UB5^QDiW6bV*I7K-NX|}3hmJBJwH}dW z9fz5e&g&V)Tuw=+qZ}aN`R(GP>~uIo-;knDA1Q4nxR;5m6S}byAHsNii%~4@?0`ta6n^za^EbM&7Oeci>`31i} zcPPCx)%WsYEQ`YsNUd4HG^ZRADKyDlUy3|&J~V=_zGU#RhBSeqW^}SHtJr3*6W3J`Z&TGE!o{6l=flYYz~Dk-eko2TDPo**c><=nq4h zpAPAP!jMde^}9dP9Ut=YLpts73k{_&RImlH4scHv-vb&<%MGY5^$zE}2JzjIkpBnB zTMRPl`xX!Q2P3OJTSQ>FulAQ>HJj$IA7&P5N@@2o%Sw-5p}-JgqHgy?X#LhoTK9YN z?4A*|kEM4a2twRan3+C5ri(|^zLMH+F01_x-lmlco>x9$q8pF&{hU{10mJH=uuncx zZMs6YqktAcJ?50f>)oa$Of-E^=@OwbtAy1LH>{WJMLURy$3bHtgdi`I*pRBAC5Mcu z&=sZ^b%p5_y22BL1Y+K5}Hfe7vB(-JHse?u*t#hs*DS zB)=Ww`sH+o503!(MOw5Z|HV0yYaxM8i(5+^<+ccs9{1Jyp`m#4HtKqkyKSQ!J@Yld z#C-xwiDqPS*E|#LWcakXZ!uzrlThiGCv_@dv4gK6TjU}Rq_y_FJh!u?g*0>XbFm5x zSettU^J;=N85F6uZKTk&P4fjvGNu)%C?+_YY`OgYh{Bpz&!+2xcgfv7CIUX5PIQpC zd3=zOQY@QvsbC$pkbsIa9>N`^<8$L@0xv)kv2EfM z!_~l|sO{ut0>9Enni25Ko>UmjY+`+C6?ogqORCbmYW3l#Hjc-+T296+M@-+;`3ly= z@K;P|gLH9bvss}KisfrZS3=!tmip8%lcFj5^rmMh-phpWQ+cP<>iR;qBb$xCP}q(> z)ET!=jaz5Ya?lJn3lKD-e>D&t-n5XoHg^<$DyGM5)7F7_D-cJiQiyOo31^@`bd~kz z(%{&;N5DAFVC;h|(MI7`C0>Q+V-aOLewzhXIbxA#QH>5}p~mq; zS&T^+rl&nr00IjNsm@TRk@<@R!XnVLZS=c1o;CwEJ&1b++D;Zd`E-+4D=sc_+JL(h zY^lwcq5^S(WAWo7&?R43yk{W7LHHg1bV%gC#VSJ{R$w1As;0(!N>y*K*Cv}ap2YpB znq?;Rd3RmdPuJ|(!R<3RVhIiz;A<6n+^sEqio*En5r}3FlgmuM@=lfPSP3_6vuWd0 zAvUI!DemYqEJ!w0M(zPV9@`r$tu1FRZAZid@~0zf@L)>OR*y=XM3)0Pewpr0Fq-mB zTtlYO95@~ex0?AHfkz8?Gz!%@{osKG;_-NF1RfhQJT64XWQ7>MBvi}s^;!>ZVLs2} z6@*KUxZ0|bdn&62uHAg5)g$gg)K zvwo?9A3EHJ#1F=^)yXk44eIAdRQf2D-jY@_0bZRbguX_}?y`~iZR#xQ?p;yWEBx1v zsLLz9@f$1Zx+bqaoIj#AdGr<|NlgPa?U;}AnFctb=54@LR7>POxy7s4Pu6Jbzm%6; z`dxNyK%T6LOaVl)axma^P~Ow67}ehiF+C4Cz5-yk+chX;NKp>RpeY|;_rp29IH|@A zcQK_Sbh17CjFM2W4ApM?K(Tx(>>@)^z%9PYmx2cae`V%%rajlIld4PivN!~ zfzXJkq9B^#S@&Smh`aU5M%;r|;Shsu^or@F^FKbkVc*G;i1!la6UDUxpf)#6qGdnx zMzqY1Clh|lSy_vMyjpmmU~fbG;);eHsQQFhYNI{ck$o_7NTLq+zQsn?H+rgmAv7|p zC{k7j>7CbdLW7prN4O_)t?(wyxrIK!t;>JUxY51UbS-ZE^7H`}3VNSz!_zsmg8Unu z1$Vc(?bv@c`Z@ZOkDdG-WwS;_jeWHr`_}Q~DU7|#kG+)#Q`51ZSkbV9IE*lMjeA(* z7N>g(sW$*oQa$0*@w>(W{5D(4)?_>Hc3;?+!ypwEnnspOMhZENLT`+snO>u zYwRlf5RbM{0;g_$Man81xXO_J z^N0#0?CFj7gC~K_`Q@ovdj24R+@bO8H`5RM|Lle7ujUh5WoKC}xaXx8wn;@{|2qjY zO3UeYOl2+Kc|?J48)C6aVmG2S4j2#Do5ep#@AgJAf`B*7TIfv!@#+s&wD@HuYJ7E<-LKIfyY!uNh;kALqL1V9P+cP0eor!G!M-oRrj$%G zSikYqP6ho7D;=&OUwL<^x}+=;8Mh05r#>gGlW2R%M{fu=!56KhF!hxDwdK+8BtA>? z+NivhBJD(X3cHG+OS?;wH}czH_X-v$>HRSMPPW*A5=y<5Zskk08cN2J9k!FoDJhdk z?5IO^?^=nbV1B{1>lAN~TQ+z;p+Y0c7#R+ZI0kf6#eh6!op5r(cTfE~*-jZ*<88`1 z%l$X%602Z|zLqJO=4JC^1-J~j+ah6Vy;wNKQc78o5rt40(NYE8f6r(L4e=}C$pRo> zODRx9%d_D_YeoV6W~Tgn&Jj3skQ#_6#|+^$O}yW%hZeDujyl@*_S5m$5sHMEuQTUwA5;?MaSYA8|ZKMnHmmsPRgt-1Ryy8YIHSPy2)H#2zjhH%DxJ z`fjxU3u{w{w8a6ovEn3|v6?M9M-^Rc@}@zfQmLQbsE@_i!`GszWDw4)z^=<(qj0oU z@VmrI-7u?xw*qvjg|QilZXYcC;Emzzs|(=zk~yaX>cZoNSm*H-#?F_&F*m|Y7O ztT%)k-G!ja_kr75#{=+rB4EAYKcjd$#fr_9&iR>b^Lo-dRTCl0*d zAbzG0sIUG??xKStP)2PNf^6}8L3$%cxy>i&$akzxc6qa?K8p967r(79ep65U-t=!P zIk=ayXH4sh7j_G0y_Tk5;wBcz%_(wmmf!>ZIq4SDK>!Xj>%~`To}xF-4hVbH z7}Q{oI3C~Wu$cC!(^D*Xp9B^mjgm2etobz<# zN=yTNa#Gyn#sh{}3f7-}{GFa2t?~l+*}_0X^ZD)vVI&vn<4e8((d%Cp-a7KALMS{P zHfi@1CXMQy?s#})mVce`55_jL+_3>9_X4Q`&Yf$pa&&;K$zko{>(XM@T%Ux$qU4U< z$OyXJA2h#HD(AOr7L0MCukrk-HQ3LufmvV_hWibwjCG&&^>s56BK1F-)&G^%Ki${Y z&8YQH$?E^Y>YwTB>t@vYr)BkjX7$hZ^>s69{WG%qKe75B^YwKzYW+`U^&hqRpYru} zGiv=Svije$`d9nR;&V>t@vY=VkSuvicYM`nnml{sme6C$0XazP@fo zt$$Hg{|T#qnXj*#QR`ol)qmXTU+(McX4Lwh$m&04^{@2xbu+R)((T2NnBuefSAitT z&LM2fc88zSu!U8}&fh}JT`He=*ShDQBcKpn4JK7a!N5|pS!%cUrK#P{Z^S>&2g_OM z8|0RW+#};xsepS48r|!g7j|#$A0^##b=CO^fB$8<*NfS`{+@i{e@C1D!ztW~Bg~Sh zy}A@;{|4FB%hJC6tt@ZFA^+W(_6A=f`&$wCGRx%V^GK~Rg8$T6sZ!MMsvY ziqu+J&MvO=?AkO}YAnmHZJ_>ULNc{jO=|lUuPpNz*}s;pSg{crFsNcKFrh|5@HGFo zo>~bt!O${=k*NxvUa_w)DrS^}hG|AQU1|tbx)?R1oDn?FD93F@Mmc6DWR&BXGRpB& znNf~9qhyq$VwxvDT#_fAtFk2U+!vC|`OYl4oGKO)yL&##naAIcNG=C}V%D@UgPulN zax+Sc`Odjb^PNN7EZ;fTFP-n4hs=nwo3C2CewlKM`8g`jcOK?V`Odj~nRIA?8<7r; zRB(liZ={10S@Z#ghCJUPpXex0EKl+`TYY4zCnqA6S%2lp-Yf;2+HGFH@B0g%Xb36N zNWxa0Y7KJwG-}{DYHGAQG8YH-LkT;uOMBWFw*t?IUc11Y?!?4srjW}OzD}p#_m-QH z7n;05?{Q;Vn1SufIJ%bStlbO;G~X3?DT!DZ(;4^7jXD12&0OAC9y1%S82LbCPjW>x zuPjv@iQ~;nV8;=-cNFn3*P>0G5(CYRs|U?7LhM=Y7a1T-3sY~rL0TZIN0E$j2)Sfy zd%<7fzJ+2A><-k|!Svav0-V`O81L$bk`~-y7SUDT689_Ip#hM(FnToVSiP-1o)yL0 zU}f*LfD?C~&rY8MlnV8e;;qxBy6~jjVy`sS%XG^CPtTr`?Sy3YWT1{`rcHI>n_37& zy)v^+O&{vwe-rm^O>SgcdKh$$`$Ra#GchBLMk9r!;Ao_YbL%+;)P-aZyCXm#NupT= zfB=eQAB7?V1)!?X#ErOAk>{cRgTwC*Klvy4*?#q3@S7ds-{J3DYww*q6PZ9JSUpxq zI!&?)$lRB8`PR3-rT@5K6SVyD-$FdW{`-mkJ2v5#pZph8N8z{0^B%c>yyicC3xxIA ze}W$O-#&t1`s~qH&;IjQPyWMK&;I_aCP@oV$ve0pN1^`9ze6VV^p_t{hNMbE^Y3{s za7=FW>Hj0pbo(9Anq2W8>%aQtf0Sb(he~$j4Zz%A@X7xild-TSUp>JbPLl2Loj4Zw zhkx@+v^`<1{|Ra5SI_v5e@UcV|MAaBLo&;Y*F-W(ia54gJ`w6E_{3xUB7Wwk^^{qwIL9iuFO=BEDwuKlm7=JI?eY5Sjva5XmKZ@&7)zXu18r~j90&Km%4 z#zftC28cKPUx4-hJFMdW`rivF`fq>vf8X(*eJdQ$UqYOjzw-aae&zo$zw$pz*?_+R z!Uu>=K$3s+tG@!a{dXk)vxW#nf-fVV#Vhzv078EOH1cooUtIS8;S7Jr|MVv>7z3E-zr_!zRo?wWf5spBJN?%|O{~wPV{UljB|Lu_|afg3wzV5Ee zkNwa`rsOmR`0KJaqo^?mf|Kj#xW7soVZ+I6+v-SvmRyXKpf5xL)=#SgO(O^HHCezaIr1eBBhW-7tiD z?y7%de>3rNCxiLobI=~NUk|2ysPJlY9j?ZI!jJd(b@Th#Xo=V95Bbdn7VUHZvDIO4 z$6v#W$|6aOQa+Vue1#0)Io^J>3}jhfm(S#fI`xZcZ!_y(O-AM8o6)*6S}#A>=9}4C zKdZYwyF>CZUp6Yo`l*Bd8msoQzrMw1&G6G$3R(DLeE-lvlY_#O%@Rtl3*Yk-9 z!T43-^?W()W5~>MIbX^yU3On}df`R&J#r0fpsu_7>J$0u8a8G&nly&pb$>kyN3+e; ze)k!aX~#FS0Egl%IVVY;PUFsS&=32A4?HjZ&-f;Pj?gm%oZo!oHu@P)<#)e-B>#i( z8^3TdAC5}X{-<#8(QNOT&ck{#+{g^5S!2>&pUQtW&L`yn|L@5DpCAaP=RxN+4jT{k z<1oauopQNc@h?T%ebAHkcsW{3`h!t0opxS#Pr@m7aWJ1Qu!uM<6GYYF0t=0UJ$OCB ztKsl$@9-0B@J0XAyCwG)yEC3Z`5Xs!%F9u@Ue2eXCS;|swOKDV>jrijLHe@Pc>Xqg zR||vp;k!ofRrvgeUJ#xKO?=9HG7NEH$E#a8dM7+kHJ7ngj<_4<@2aZ1Iap|7I2ZXuj<%>@M`HMng&Y_k3gd2-a?i&jLDN@A#?A zYHNJo-fv!mem7|00H*DBy<*m--D$KsjouGfqgO%w^1RV}$$Nck?{%STv*5Mq9?LiK ze!DB`+2ZcHa_p}IhmMVBa$_2}lGDw4^vP`B?)`|{^fUEAu){^~>**kb)x&b&%C$d? z;A)1WPo;7yoYP1IdUFxYD=w|#`FAU13!!aGi2tOyzk3N|HcU?JK z!X?5w^alfYw`dyNx_={&iHnhQ1K^?eY=GPd+Ar_gJjA6Pe+mw?y-%@6lhN#EeGA_? zxEkGzXR?Jo9PnoKB2c#_p~`6(4Nl`Yfbww+%Q;!y_ZJc?n9ExZdz%IP;dr{3G|s0- zL9Q!UJK>EehwfS&a6mQ6VjN<_tV;M+JiQu`0tc?l1;RNGdkgibbQ#vP*aN)7#+vv6 zZ$;mB#Mdf^*1q>H!e%S%RbfD2a4TVr9--T4!S~?L=fT_H{5Y&tVP`^^nV{SFW1wqW z^v0g`7Yjx(sUgH5D9te)gD>_-gH3#i?D$ifooW9Af=ivVfje;uXSN;(cL9zAuLv&Z zW+CRA(Um@4{&gvzg}u>qF<sD06 z$TB4m`|i&;3`cjE zLcm92G!2^)VVuUCHGKcN(>R@99R>V>G zKEf&M+P53c@Vr%fEsM`X@^cu%94F=RaD*^m{#k>}yLL}wtXML4HXL=}e^!XgO*Ypq zmj!@EA_?CulYCapKFtOAxEaA}3`ck40dkkgr_RQbTv2Ag`OS#{!t>$l0QmVgk+0XUIHI)xl(s@a6k%$YrDW{ zV*>Yap+ioWFrn-D6s3a|64Z&TULT1JuIhUU!7rN)WTaT1L|#*?@a@E`_|~I*jCt2D zM{7x-ksgovyWYE;#8Xa15e7l!F&xHXIbZZ|nApx|Y6neDD>vNxkS$A-FZ9I)IB#}C zobE&lVocPT39yT9v>G^Mq%Io46*?9hZiCES8CEcDATGOxCB$Kg8KQm0@5IEo@PNdC z<{SLK>kyHu1z(E3i3Jffy-B8t5}d>9$bmK4`#0bC*}MFN`2oTP)`bd$uyyd|Zy(Wb zif8!Y;=I*r+fWi_sF)#LtY}DGoUadykG{aoBbXH4uSOq_EBuS`DwHCevxEzTvl7ev z?5P#+9?>rPdz`mxmU3AfhLz$oeb8t_twH=W6bMK4Kq7+VRI|ZHR{28Qs1yYUHQevI|!1<}`X88?~u8t_=n0VFf@0z2N?`#vpixp96~ z4tAk0KwEl9k+2=e?j?qbn@Ofqk|^{#)h5B1UU=Dj-E6%>b`UeXTQ*Z60h+!$-UERu z8BO~>az?S=raRY}1~&abMA2x!J<~`7>X@elFLkO1~7 zyc(hUg9{EX#Uh&GeYhXJSA_AyZuLbFzPN1GdH{J$LR|O&DH1I~O|j~sMd+}={fSsu z;JAQZZbr{ep8WpNlLOCz?wX?JMND$}30C!bj3XIUwG2vz^~8`>E~9t3w@mMP?wj60 z>EitTY5gsM2zZF@>#$cosyAMsfbxP6+j<(_&NryYDOz#>rXbY?&;4&!qgF3CPdsLd z4a#Bl#2S^EE3I&n1~9ssC>it!biMoe@&jNHgq4V{QD?LuVkhWzen9mK6|4@bG)(WF zcTdB{dHc8$wqCq=-T=H9TS#2XtuoQ;!?I3EaQL0I*7dv zjy$RUH_!ZI*bJJj4vgnfgjmI(DgyaMt%phG%ZK642oMmy>M8aDqD=Q;VXDUi2O06! zqvRilz01M(_{(H9KLW5&a?`KYB9M396LDR3jAP6UzrE<1ZR1_Pb;#H6+<$$IUE@pm z@kYOLK!gjF5GNvNpUV-k5ZkwMYMbZbIqI5HCXXy;r}g}@+tc8$-NALM^-6z89Ujh- z@9+;GQHHCfq}$tt*zze$NuUk@FggczI>`fKWS#&GAojx>o=x1B_S@J1ClNWGoG0t- zvbW!!M5JI6ZJmW7r)NKPtkB9`x%>n{HHy!ye=#a$i58AWT=#vrK;?Qe!E)R&h6A60 zK^$*&4@`%*8g2`TWXo`vm~o3YVIxdUE3$rS8#fSc$JVDI9wn3@*XwWq^D*2Fm?T7@ zjN3yv@NqNO{Fm-pmtQhX0A})iMK6@cWgtYjUHz_|x4MBVf8$miBg|NhRvJYep}aDl zeSk%1zc!(BlqpGYx&IvC6E7@r0xv5#I0-pmm(TB`65f`(taWO~m6{+6Q@F|K4oc?L zXub+i_SS#C2L%|llGcL69)w3U_RUs32s_P2O&1Q4wV$1s#8_+wGvnQb*MO@M)l04# z*>4>L0F&Fa++AG7)8wt$cjHb`_ySkJk26x;qlMY=B@71Tw^DYuZa5nJ8Q2s(a9U#3B+cgh9LnQ2c&Xl&t%!l^JHmLi9G*)ruofo~@l5@n30HEnUqZ(+ z!gi#vmdd9HhI-3BsC$Fj1fV!fu))tzwt?GgfxLjQ&I@gEO~c*~?I4u<3T~Y%vX_4H z5nDX~MeP?#8*rYu``uT;IYQeD8Yi4AuzlpOpW|P89dKU6D6;fIcO zFOv(P|6slMLfV6`RdumS3Xn!3I95WU!(I~FIgMOODX|Kv9oTA_z`ZaMZ2_>)cyX^iMq}HE(5Aw z4|i0lj0V>@z;fV&e3AoCJZ?=+W^DOP5GULLAllf#`E`I*v>~EaCWxioAXLG51goe& zTR&rQ_VnzXSPEYOi5KEW5;f7^JNVF^+FEh3H$7WzuJB}F zJMx>kL?G2=$zOmcB29Oy%%(vK`*So>{Ks^AB|?L zsK}wTNQT%`b4=&UtdK3DWRX9b9y`|}V8iZO4UfOUblVTa_$H)7;0 zR=s5T8VpV8tSVijUTcD}pZg+_B&;#C=Pt5C59=|bBx*P(WwRm04$oR7kc$%*5G_#} zM*yFb{Ur+H^QW9M&;DWiM3piQhIQ6Hx*|v7?c?yg4Ok1{z}X4TAWRWXpcihrDn{`X zPh#}UtRCS&i zonXJE{^5fX2tiI_9G{FJC>UbfD8=4F*vYWJ?whmioy-KrFbEzSm>pmUyjO2Iz8m)^ zZ%NEzs80a4yMFQ|j7t}$f@%*WE1V8s@zn$uja4EbwCHd8mOHvv1p-6tVHeD}sN#!5 z?WaWK@9RrNr$E!UeF+IppgCqdH6gc6{JX+KhaAK055zMeJpsZlACCit4+n{O%?NCS za^cGG__E@$MA7#}u4 zj}`FPqoxCN8J?ExUh{11cez_R(0&Ju><90?ls1Jf=#=QR*XKRNI5ON&0;6`Mv{1Lk ziF~{jmo=`0N@!N50AU8_${}Bgn^WX=I*`Z|m+5p`Jmo*hiV0n{^iz_0%4}!bX~vgp z|8YT$Iadbbn0wQXg)O|q84H16j%{As^kW8a8XM6X9|M*J+XJmAu+*q=p-YSHVB>3q z(Rv`m{w|Udmd1t+AS3ibA}Pm!?Qy$P67?8=rBJJb=Kzm{cXG1H4GQ4caL27<6I)q+5?z{bj?87$pVrD)yg5KcIcrOji3lwl6Gn=`KYUl3&C!$y z7cX9Aj@G|1vT_t0wS}vAu>#>g5Zv1lI7_x=VJbY#m*=hLST=myRoFmaIlubRh!~*R z6+66RO&n6?1wLYd2!D2}wIJCAk;RE0edL9WWnU)$&9aUI;_Y(S6P7Ns;$ZJ-N{o=^ z($hXW#~HBSg8P#6mHUF1!+=XAlUxtUnH$w?BV=hX1p!6a4mB_e#y6&wQ`+ogSEI;n z?}}CWYk>VIZp;SLg;;=UMjGf7gU z(PF*Qpd*XPCjgqnT>>@gehEtL*TKr1F>ONFG+BQP@cK`8Ye$xOPLRRyi*a>Q&%7ZEEKoi3WUTjvkIJ|=ohpmNDGsdgM{IJH) z=-C9DD~0tD;$-*$1i0_OI(%D#ZvhE|JX?0zW9tdrZSx5SK|HriZ|TgmS3z+6*e8I@ zknyu?Ucebiw%ALFOGjseSc#r`3K#_kR-;$prgDX`w4GrUrQET)K%Q*BJdmwXP(F@v z{|Lh}-NCn$kY;cA0VY$8u%OJF1Iw${R?_X0&Bj_0&;yjqkSwGA6!tf=IjJ@9v#km^ zVkIJ;_Xwcfzu_>(!)dO)DMU$Njd%Ir?9$0cW9M0K2Erkjx8^f$H7hsBzmFATL@NP)X z3?~Y|yI|1v#b}a>n9x1CfP@K9^fAxa2&jMO^;ij{U?~vk$HtC$;#c8tFeZ|qyCYZP z0k=ilh(d&^pbCN~hO;C9DrZ$r4$e7tJUW6^?bR8!2%@9`JDzbB7jiuG|(1{dSkO{R>GzC3aRY{Kk-fU zk<2aYS`^Z2m9~q59n-ewwU*m;E7l8%{^3K)ay8h;I=_wrH{_GNQ>kxL;C%44QaA|c z!UQ2u!xdX?vEmlBx8PXud;OFsZBGxQ11=`ohwdGi6guP}K)p1b>Zpr?-qO=KBr8Gt$SyHU28j zt`l=u?X@nDzcpJ;bKDEtn!E__0116SJ`ER#gt+a%QYx%Mck{v;c#0xjrt&R{-NLGZ z3C2@7L!*&WAq=#5@h*JcXx0t5$Oi(t7=Iuk;LOY;DM23KtMYPYyD;P_Y)e24@`Md- zo!119afGzy!~bFoT`He0RN*!h6d8g0^a^Ct`$5TSOlkiY(ryzABhVht*}4>IO_2!- z-az%dQ5PYkW^fL10kI3c#zoM&>+luUx@2aw7EQG12k(M#ZH282>s_tCZFF0RShP#DvFfsDgLF2w)H`4>-2J)~ zwGIdy%9V(9gxteMZnz!Dhb$>458Dq90e>Zky|0gjC=WtdfQ79!U6+{FRA<9?klI5D zs)2XqzI$c0Qivn5SPfSPQ79p28&=P!Hs2xxZVW!J}Y^LSMmB*F`4zu9W;ay~L z!%BQkg$cCX{4oem%asxf%Nlb@oz3Bn3ED%B#t1CxT`9FAuJn^N8MvI9!rO;W9GsN+ zbH_c!ex)cDc$-78HFhxb+W_I`n+*}7B0s6f6*^OWCOiU4Fhg_*O+IUFMOCr+adHA< zG?jgkAp-FfTD&eQT7*RrQe&kAH!LN2+5vogS4uf7m80}$&J4Y+F-a+a*zSje3_q?e zI5h~dd}9nry}nn{C#|kzB76f7@Mg_b=+S@^+yQG63s~)lLH2Pa-N&+%nN9q{q0-$x zbGu^pirmsnW1Nz@06IgXFT^EGPXz80L?G#|CA2s8}L&mK;; z4*L9R`26?iy=4R=Aqzh7#(=HaqKW&!`8ds_6G!QZIYfD9g;BnkrZu)-keqZWHR z1#CUYei&yPakz|3MD`E!3?h`fLHECKenH@y-Rv+}b3% zkgl!Cjun>W3i*M`UjKYDP`zZiEe}*aL`ySbW!zsPr_;}40oi;QGZ~3x*}5%`%XkHX zK~&rNk{foW?gv-Z9mlK~3Jgi1Q7hmf^6u2gI$}$8$_Pd`@1sdL+7)B1*;b zXoy+i$eNpJT`FURa{iQl8)m;;EAJ2%&z>@XeUy2;9yVW|q1tYXJcGq~wIyIY5Wp8i zFSKdntW}pcs}i(OhQRhz0;Q3p5LhlP;R7Kyn=@7PSSoZ{hg1YQDLpwt_D6yGCNko5 zY=WzGLM=~~-IrO^fPG#*4P`g#iTzZ(J0+eb$2zOm=4WcOHa5_QGW=t)rL)H*a)K(C zf*@PaiNYYLtK+x=?)xcqE06Kd7wQvU~wQN#ow7bm7WKmSU=}!1zDM(WJ7|VlSVbHRwhB3IMPBa>yRG}RXgvx5#xBwRT^)_IRU@9zOZ)fcFppbksw z;qsb{CJFgHSZV*&1#}%FMD1;+cC82^A}lLkG#!HOg;1_7;&AZqM@Ky_o}ks^@{tVj zkbJ2D#nQvqfAB9w!|oHI+Lb9xV+>*D8lgEt(SfmVvXs1UUslaDhCQi7$POMo4A8cSXN#3wCJA|*k4|bWtV`mD9ad=*hoh861z_x&@ z^m;y+Pwc2AJEFlT02IV5qFpi`SrckoSHOxFzUtf5Fehn1-u(T1g8@TV8kiD>mm_P2 z0zoejbBNwhH5pQNEZl>pehy^R>15c3FXz#{D4Go*bNr8pFtE8z89 zNPwblY1<8z%ihQ-lH!25nhpY$2Pl^A>)l7bpKf=b!tN&XVbwOnjzLl?#(X-6l(R=^ zVgNJ?Rch9jyKB)mXmn6Gks6IufdlAW;us{^v<-wkC#A75fwXmpI$d1 ziM>Cr^HVaIK&5ACC!95be$ZU(!MHm~=A=xQQ=gUQOr_$F@&I>@ibUI+mXc}|dn!{j zgJ0ne>^S{z+8qR->(=ZA9PeIB5nw|Ty~7-_DWHT zr`hT?Ui`qipJ)+EyqBCkD4O)=RmvFS8$@`Dk%_b^G05cc=3Agn6=8h^f|9}A740$` zLXlXq65b@V?y%G4`t`T!He5Wlth|9BOvB`$P)Qp7Xl=;gdEbvoDzA*jh-? zhE)EYNi#GKPEch7JHiLtL7mNGGTTD}YU~$t3>QuEZE6xgucr(4nX|`t#i1V{RK{AIn{`e623pj1h%7TXyMkHU;Z34NqCe)V~6(z%*#_3pZvw@mFUY~M$tBX|d> zqi{DBB9?$6HJQkCM?qG0VO)7;nOGkg_wZ%Vd)Wy)%5bDUu~p+H=7l4LA4xO^^O(gT zW?bGr6mpnTqXTKML>LL5SoHJ+o$^z;O{#7XqQD6iB`gn~;NndvQ=LRV8E4Zo4Li8A zQ948Mwc%hr6QpB3UqfY2q?t$`RjHF%qz0RY4*+kRv}Om)fDzL%n+E+!eY6HBA^+B^2gcz z6pBpShDn>)s;^36d$b(SW&E=wk~)PE_f8Nj8C%WcPpXnWZqZAnUCA1+9B>9b{dagK z+oEI6bOvPrWiu1tq@k!BgN*KNOtK!AyqdYsOFV{7GvB&XeHTLh=5>G!`6s%;P(*cT zFOe6ThdAJ+9C|}Q@C{f&9ef|pLea%dqTR0z-2DU%#g!w>%8+SEmb4@TMGyKO$kt|s zcm!WZqtK4S!z#hFA)tiyycLRBpA)OhotUsgQAl zY%5gq2chU=+cT8uWnGMD2K%M%25p-}W>$L6oY1_WqHS(5>e%p0f|~Ng^cy(>*+5;o z1`%6ehv>gc{$zFy^rrBd^T_3{8OCHoWvA>cUeC=Y2wM*Sk7NoDsStZZTi}V|NGa5( zf-ji6raTwK0TS$TUcH%7gf+>2G`uMbxGsv;ZaLfpg_KM=ZM0m@5nFJz-1cXdob3J+ zZ4}99*ER@$90k0F3}<9&iXqBNvZbRIomhN@jm6Hbf84G~N$lvvm$w*ehoz^rlUp(Gk}aHP$Z6ksL>NzUXJz9C6C=WU({&pzDB;i?Zjs z2DxWo#g1}T-0x2EVQPm(7fhx#z~h^0H=(>x-c2S-fuOLJ=_l+=rb#x|&h)11uw2B* z;!Nn%FKf|%BK?Ca=?bFD4B{Hb5q`8oz$sqqoOnPT?rlVMhwoC;UfEy!$!O1 zPctN9Fq|>UwSzJ$1D=2nk11wilabud>~wnXkoW#$R6j9F z=qwwe`(=O`QA0uPDJtT!N92QM?rg(Cn3med`Uu#eIq}f>@yAv- z&c{aq*TxdXIh`fYn8lb5b{=pjrh*N3*Y^v=k?ZRc&RjU_GfnJLe+m>5=?mfD1GGaR zYBIlX92OIF8_9Ni)n>g4?e`bw)t9L5X(X`48}(zDtyGf}8XVo8=1c1~2$E4bFAe7# z3`xW3VC<~3Y0w)UbPl^By6pIl7btSQyy&5Gx5}U*l;O7^CPy7A-L3IOksf|J#b(!U zutk8-3=IQi+wBJ3s0V&hr_8OL|856$Eu6T-)ykKr? z0aC*lEf7dk5e}f;>s)pbhYeRq`B}U|=|!BU^LxmZ(Sh2f|6)i%8kF@=7PFE_RZ>M* zDA%ETYHxIrV_}G7YPS#h0KY-Z{{DW~jXgR-{A^bC3-q{(LpIh12Rpv zb`m%;@!5KOJq9^Y87@OFUK`IiVfY5c0=PtRbkT?wRSh;9k#U;TnBdF_3WP!giFq6+ z8w23k@?<8mq|{aZ;U9MV+jpgx&C5r%-~F!q_))q1kClHcKdKy6Do5qY<43>lU=H`I z{@VP**H3@*=_jqyvLzlFQRQa$qj?(6Xk(oUn**Y4lim?4Mlf<5PqdN)@rmhhJ!8}uUT_`qFD zVmc;2-15jMMHu#kUV(l5w8tidQFQ)J7;3maxYZ#>B}(;bUAl*|>$NMC0*F*6F_LFeGRo?DiXy6f{ZG-)9~6Nh z1{2e34OIb435Q`D{{h^vB4m1fp&X%MyX0|e%vjej8}x4?)(oBPeDx}aHJ7Fz=<#^x z*{aG!P|J^7y)LMr&NftBz(niqW&P*uwdT5o!__=g4HqsVoTgpHz2@G+z4}{)6&`jglgg2Sq^4<8#~x%g_kMWNJ3wXLoX&`HI2>N=s>7wsP5( zQJUvk#@YQfInJX}kFuuSQ=p@d^Cb9h(QP`#P*ni40(ICdQi_SDYGJh}g+?y%aC!kh z+u{`zMPA=wCZ$+4-@xvug0phNjpaLBXnDr!aBW+(deE!ZUWFI6YPTn-8D+;PPx@Xl zv>%$aSDjW9YDjg+vdiC9z(b_=np%;AbN^Gh@O;S44AtjhC2;@~E(ACPxUO#C6;c8-76Iq6nT*rgLE? zLv1_<_Q*)760pekdZ54TZoL(vdxrxQw>MkM&~Msi8_5f;y$Wit+bzu0<4C*dc&2d~ z=~~(@(S7 zXcs@7ZK0|H@%y9kr0@`Ib0q?hUCN<4aEJmZkX=w0hJcV#D(q^PvR#^{)DpVpY=T{` zt?czdKti-8$!=g`N~$KJ3=bcm_~NBg)Z6n}X|T^>bmWDM*#Hpd&$Ue4wtaPhLxCxG z0Xe6D#D!gwn9=2f5k_dtyb$v_ERAi?;_SePT>OM@;0acGpOgl-6sHFqj@{vHP59z2 z$TB$Eq9J1ly6e7WE8$KPR~3nRo}0!~sY9^Lh9yYSs^lsf*JMdm==qJ!Z*pd!cuf)+ zKO4Z@xJ--l8aI?0N<5%zh_!uMee}aSK%_NSY3noHCvXAf5SvFM9kkC$M_ z5k}ORx=dwuX~ZeUg)`%kkE96=3?wIrrht9U2XW$8*t|H6;=BQVGeRZoX4E&7efaZr z5gm{bZA0++63e{lBw&0IpAxECr_t&(dNx3mhJ;jq+l;1Ll+Ry-SKNGwX9wGu$tVaxL;UD@;%+98ZB8QhgY_0O8!`7m-prV;IpvOoL2_h1+ zn+bfzSj;SrWBj1(eRM2l{vwHI9HhZvwHOW9eI-D(;M0a+Y<1bt;3 zn%biG`KcQQhuI1E!V8k&>0J!T$uFh6deMONT6iVXtdD_+VbZf@x}{Q5*R3$f!-^Y7tQ~uQnAS&yO*_E(CtRw$1TQMLOjE%ks6)YUCA-Y`U&<4 za2$j|+=e100w**YDbGH!jIg4MkCQ?6H=+kT2Z9IJ+hj_s;;K>E{N|hD+*6icqu*y) z1{F`t#-)}?wBViA^GkGlwviw}@#9qhk06P=(3iT(3xwND-C-#Yo&c5E`=u57PpLSgQ&7gOic0Y0R!ZNIbweJkFJQ}vFs?bG z4K17S@}d02D=*?az%~=3s#%~kH9MHdLpk1pV0VPcR~-xhJU7hI#tMLhDWYa2Vab!4 zh1v4l9Pb?yiBLs~{nWp6*XQf6&3>M^s-V&f$vZ3`xxbu?%|fdy=>IYhGWvvXqyJ1) zDfi#`@^Ny2Eh2``BNbYpg)Gpkf*Klb4nq%|=SJ(T7DVE=d2cS@N=ZLiT?FD!x<(dE z&v8twr?#v&BMhJuU5$Cht+|yk3d|POWE3$xkz#+ua$NT@>{^;8acem@rNibNmJBZH zXi&q=RslXN5Jpxt&fCWoj;x~Bl1rU%=6hEw^8NsDPQDZ;Z(`%6Ge6f_+?B3YxGIb`uqLZMT9qyPFrEjLy@@XY@KeEVT=(LSHk3Q_ zYjqME?=FMD2T0Wt@%y#qn&JB15BpY+c~5PI{!V6{a$W*_NYqSWR(Y2qzK!wz@GVF; z$b-iy)uBGP{4kPl_ZB_H(q~(yYy*#hUg$_gJA~d>s0C9b&)l4J>dF(OTy|ybE!8#% zPUuUJlLttU(z-Frr(jU`mi_DN@t`(AcbiUMgRRJmAo&A?a@|3* zAYj;$*`f!)B+PuQ7MhQjq^yxTtIiwH3~O%{Sp|1rB7LMN+9l}9z9t@Zf2J)dAIJU( zI{rxF)o^+bRW}ImOve-KZO?F-fBuM8&K84uZI`j!LaECluY@#->`}FA=o_ueuCO;Q zHt4rBcLAVMj7^bFtle$3y=KtD?w&LiJp`74WT24)AhVRx5R)I1Zg;%N;Rk$p#cz(V zZ%m7s$obkk9DxO9@M}dciz_!tRF#OrZCe%`!@ZnrhC?^QD>1NNZ}fMhk!0Or~5}o!rL~_wZ zv@>1RMbfDkDv}W8o_vd&1pT{Q^xu1}_NDTQBubiVP8<062l81vXUu z5>;IMGjO0MU(`6KUn^NOGPpsYUfsg@adTN93&i%jDIPon1wyx!AsN_{Ej&6wyvy-y z9*LVN8x75Z@~=j11F{}%s1M>?$(b#>+h_d+NYzj-cJ7`EMHpV}Q5F6BpW}gTO6_5@ z_;gDHEBb)QT&q$09PcMI_5}VzZv4E8iKFt~rvE3_-2-4K&^nne zL1i=?-sX8&?YtB+Ffz==XCW_{s*vKyf*@!22S>2wp_DvlC_T=fhua`JcggRPfp5qN z2xc*5Q_7yC5tC57AS`}W+0KjG&zxL_nh#}k*!_$2d^sK^VbFwi%q&uE4M|1^(0H;& z`_x87saUAAqEyB-6`q-`aV2LZ6;{&6+ z8^8Py^on=ZdV+tU3DmmaEGr~iY}kPhiplINITr;Esg+5A!|lCribaAGr{H#cV|f<| z#O1{4b_v7LRt~=XRt_W&BZljauLh>8DI^+$nufdvb2S&w(QUdY!0OeehaK7tt}wyiztsuxHn|=4l)16fOkBh~K?TYj3~A zG~f!0J8^IK{w_9EG$i0=DOYMqr!M}p$}9-bX&jP*ujp-FuIDJ@>-Vx~Z<+fm~ zo$9T&s>ryU6awW*Gcz9AomLOXxM+#{Axe&GWfzIA13fh$0`J=ka(`fJ@c@U!ZIJdx znu?CG*IvR3!HW0jLz19h3{6qbCywuS1R5-@pjqr>M*$+QTo-vn*Q``QlT%5r$wXo&?79BpB93Hl#&+_I&}pKPCF%jz9J$ftOL%uA zr4&w${>o$6XXr*O`Zs`uNNw_Ki{KgbSGbu_00R3nyc-K8*V}{~=f;}JyfCmel5C2F zJ1&#ow1j{@-v=()ZT~*`oAW|GAqh+*4Ip35{1xvkJpgByy8g@l&7LHQF zSI?NFVM0s5$TFULGef9`TpH?UkReAGwa7*goqrnjPlH}2oq_nJdxY|A1%)7mbc8Za zy1-q>K%cN&aN`^q(9Gpbr(MvnW-x4vK<~$1^BNl09PS=1?cVq-G1Bb- z81rm!g&EK@bIEyt-uD{JhGiJ5knD$}!GuiuU(X=Gha~wo@k@`(%?{}}j~iu@MIR%L zl*z54-I8Fl84S$E5jGwZkuhC;Bv;O}A*u1@VZF4rF$iZXp?IBR?z#ts(}yBMnD)W` zK{QWm*m~J$hRy1Qv5EfG-|sV0CaRpIO;izAR5U2v;UTaN=?o6)M?uj)hy;;~MtHU& zW5T-wPGVZ46H{i%nYRq%QP7U!o%1WafQCDy2ig=5suU2iKyA?566&+vxsFBzxYcv%MdYMG7vg2& zpGm&%K5vR!ie_k5W};c5A|-$X*Tj)qgRTo$+|#I{R05QXwup2ygW#5awLF~kZi`9C98USZB(G^JhStLmo zOIXT}DF7X-tOe`rUEt$+cOz|$vVS?+=Gg6KrTvx~0ZW_lQ=<8tl^A?ocYO>ErN$J6 zCTRs`dCPLMQSimL zSuUp9ibuAg*x}9+2^yhq8Y!d$+MhyB@ewk(bm{iU9o2chQ9A2Nl=oy1^ z@ak_`dGoLC-tc6ro5(=!FU~K!uS&|56B-h?zN#u&cpGHYGA;ajFJ#4*B=I|>l#nFr z5Ck}m4M=FbXYb(pRQ|H@eSHDVEBvI674CGOh^H?Q2U!XJsK_dmNle`dL_DH+RP5}J zl~DkPn&JT^92_!`nfS{+PKM@g$gy`P6HZa4)<|p=qe3=LjvDW%qKfnU!B@O(n|X15 z2h#HfaJ@)f?U_(i+$GUJCSWtGB&YufLeuEe77QvMBmeZ>PLV88M!6nL5Ia*+ZM+&n z6*{x|L=SgdUq~Yy8*-~o-TyCdK|9q6USe`*iRz}5gjfMg#r=##JFltTM}I&#FVX^& z;5ALOaHka1|3E18`GlGp-iziP7?oU@i1OQ%?RS&8hvYsawOXOR9MPWx5}nd~al4`a7@hc7na6twNo>%rO*ZtPg5%s4^X zg99^|8_)@ibr&-!;uR`?=wv?KL+*1N70$A@_dTMR%P1Tq)Z+ZXWDlwrrYey8lcnY9 z%jCAQEpO&2@QO5dF!3ZU$)Gu&2Vql7YiRH`Xll{W&7_99max=$%(uDrgTP)>wKCN@ z8cb#3I{@5juVrykQ0*f`fX&UcJ{YfnXv=mP9qLw%e@eL&Zd`WQ7;5(m69lEs6G_sN zA-m}CPVMST)$np2!-5fMenkBNm4V~kizE}=F42?0vw#WGiwXLvhocVQ*A)Vws430c zkSE*FYS4ZQaf~}}9!EU*1xIl+-SSk@l9}>@Xd^8c3kpVK>+DH!Co`!B^It(*LcJ9; z>Wke$oaciD@VQk=kc!=<46>7KG6XI9WUvm&_cCoUm(ADB);pWI6&%!_56T|^0qQC$DnL=l>~(bLhV(O^T3?8;ra`~>;f2z{RjjG>hRyrPx&PR8niKHToA!V?al#;d^jnrJo3~8(!R8DVnfeKO)l|wUh+7=?2mV6&r=xHd~ zy?Ex5o8hELi4OfsBae{Y-?+MK0|G&XwFc>&;EreOpg=L%{ibl3DWD;*l4f+%i;jB^ z+OV{5hXeL+f>@fKKcZM^*HN&k`lTa8agM3 z`}d;2D>yjM`H14jjT}^?4Ipj;?_yar0B#Zdp#cbqO$=;J06W<+m0o)wC4Yj76hGM@ zg%Vnez#oilcsrT^ntpa<2LDjK*=nrVTuTMZ46P0SF5#|{XI(6h&sWWe%rYiEH8XxT zaR4e;`f#N1Y7wT30bcU24_SHu{($9H4n zJNIX=+1|L<1<{Ix99j>2ir5x!xtXo4={Z8k)jho0Zp{c+PEwJusejNI` zSG*z0U6P@G7}Sn&9@}B3x$3nyyDw6Xs}HR$BT&J<%r<$k^f+>6aUv`fuV)w$L{bCP zG<#n|Kwy-}7;}8PjRZx}M_9~evbp4sNog|<@Y$BD_Qe{-@FgOSy=N=>`Iwj#=LAeK zsZa1}_PZd(n4=nDE{0_I2gu<;4^Mv8Q^JE3UJTZ!|~}6)y`tq)De*9SD21nlB2T`BQ0_;Ab)Hz%Rp0ffwp} zMPYOr7+k{4e_}=L&WEir^S`XNUr* zFY*@qzmVvEvh(rCow*1(8Z`0qiNNp6X)aNVhqQO#=?;ltyEcMF%RAlg+wdI#>N3-~y(ASw1LhZ|MPMO$s4WTDY(h~u61t<^TBE3s(k zePSsh{-!ye!dewCR`b3*<;|o6fRd)M4ggV^K&qW2Z?N@KC*Sg*GdccXIC@2rzGDp2 zvWsMWs+etd-j2Z>7ylIH`DT#0m+tQ>=>GnZ1VZM2aJy;v!Ikc>G@Ap@G#pR+ke9gG zKrT8QY?g2ulg-qO(u&zpA&E5OoR;!glkj$16N9m^oO@*(Xlmqjq5_tiF$AhKc z2Lg}`EuTU~BbJI<3G4=nCB|UvY1COi5n?n#Ryly^%dw_-?X;Z#>wimoazsQV$uPq2 z!cHL(gPo>=i=zpMn|_19?R|$t6o@yf(JK~LE9Q*Ef=~r(fb950qY$h(<0~>UB_Bk? z8mmpD=$W=rVlIpzV^V0GkO6-7K#EBSZl8qp5$G@T&%4TB!JX8;fCj)om!^|Xr^CDO zO4v;D-SS>GAT8jRm70O$nXlne4vXC{&;NZVk+FiV$ks`!k|UqF_j>A3OT>@>s9PX5 zXNd2$UEeIF^A;<(ryL>J;t-QCg(rwR@PeY1{C-~YV)Pi2?=(WfuckV>97`L-;S-sT z4bv)NacV{O6mt`hi;S3W>?+5?Ud9BKy^YYD5E6UMvF!a$#eLEB zuZ!|VCoBl&6W*i#U-(=d@OH{-;Wwq^wWR3uFx?wXmcgwJ40eF((flxVjISE!b=Q4d zecOKZ0~Ins%R#LU0$njix)2j*{pkn|pH@U0N2L>l^~<(?NVuLFTjcKAzOtgHho2Ow zl}C(A^VrcMIFM;`g~EPj1c_q97RNrj{*e7IiaGdLUaNVYWVP&jX@uYh(Q%??rBsuf zdArd5Zy}sWyy5y9OeypiB!^A$sO>Q?S?`yfNrx+@oGX)Z7B2P*!fi1JMm!IF4DT6djRiEWF|A*g zdt}@fUR8QPROVBmluon$7G!v%ss{4}a}M$jxJLLskon^v8TM0b0!w)a(GCE0aB76R zv?I^SvDlt?sU0}M$ODIM3o&T;vd23EeKx5|qpC1=VGngi8oihZ5}hQwRim|UV}BAy zCfjq`lVauVl5;vtQHdkJ8PFAVNCzN@N}9m}0+exO06C@%n{kwPkiG&?AoX_|*{=+_ z8VnU8TM2p&td8ET?pGLKgK`~E z4)C?{z%JP}z_QVIC{5}2gR=;9{3WPEqh&xkc2ssl^=ZgT`3N{W2%h5w8nWQ|wt^rn za+ySrVIg@atIdK!ni>;Euao00+T-j3ThbjP4mD_&UtUO1Yh3syAPOas7j{q8blRIW zN|#7}^k%s|+lwA=hw*0&bJt{4{-ji2Os}9o8Hm;v7nG=jH3f7UU8)R$-+|O@H3OGz zYn^c`Z}la-zxf8dGR#TQnTZdFZkU-2CXB0gYUk+rNhl{o_<&L;5|c|fi}uT0{XPMj zE!Ev;f^cTiJ}l4V0cqH*)?#xxaWA}{2@FAvQ$b}6mDnYf9;eqNm{=g!Xm%9*+>K^M zZ;A)F6}PGVE`}tEt4hz`QONUyMx^Cb{L(9({|dT-9)B?I}SLHa#WAq@b z(u4H?`J?`_o}&(dmR{!T@&+Q9j>d}c4)x_Zk|Gr~kPQFXuR*<WgS5^U%NbJ(Ffs?;RVG9kvVgY)Y+!H?)-=RTf&aqpS15Li(?V51 zwGN8k$n7Y{&%IYDterWQmvrw+YRN6S-fspMZ>$ zF|ZvRVn~$zMs`MO;*LVq;3tbYg{@@jwWwa19ng%MndX3>*(#%uOVdi4lSPh4ng>YMuEMSFQABh3b4>20*NU2Pp`P(#K zv->2iA?4(@59>#e+YBhb4=8*-6K}K|sbGy997TWZC$wOAK?!o|&}tjXgOhVTX44w( z5e|`#Dis5+)z`+9P52Qfd>7t%pN`7vN8zqQ@MDa3c1|29Mhz2#e zH#*mu&H_O!Y`6MAL^~KL%p3v5B}nY6(=PlBap@2WhY)o8$N(B;_{Btz0YL>rm9yp} zl^%=*N7XtpyfOxhNQVJtIRFdEHZ4lpJSf%4-IIbE1k3^CJkq);S^G6Bn*RcN0RtA% zu^M2nu{-W`mVS!K^YdF$LMC#VT;5Ho!Egf(fKTO%wc33dMK|(h`CnFUsVRKo=^%YF zUyj$N1G(raJOCH*lpErXey@Qov#g~}1aa}_=MA)3UqHnHK@tY(PB6#=q&L%06QKzE zGg8W1Z8LRwz0u*@WV?3{P8Ee0wHt2Hvk+J78lXkVBXB&#iXQ42e)BsQ;Up zbn4-};bLj0(gV-V!PpddE}fl|mIs_+;iY2SAdL_yGg5R?2w~=-5V0;zQtW+#kOe^t zOrKWwh(-Q1z#s^7%$$!xroWC+U2E zW;lJf&|yA*(J-*#&!(w%MAZuCMa{IQLRSFsPK=LA~w8}lT+^vCJd^hA0JGH>+3}bwkw1$CDcmH_{1@G zVYMAzYFfOvMg#blx8frz0VW0@9Kk_OX%WE1#Xp;6d8jHBtqbfPZ3@ArCk*gn#wD@A zIlu=GhZ79W;gyOSm2Rd+shRd55%KJeNUQ%S7TUBMf7@Q zXhR^DBbir7!h(bs$<-yQv{V?T{QWxwVxm@!1=iCTl@asT5A`D9BVxG-I?R@%kux}2 zo;|>hnnK1376`>zG~LcnDYNBH!}l>yZ&GtMze*7=fK?z3XdmBA2yf`Zoyz4bg?DQ% z3J{TNBnoH(Ti?%7dK;pD;6MwI?6z}m0iUnIh%|DCb3E&)KP3ndUrfYh=(Jz|xSh<1 zc}hgS;bpyD8enjjSXt$Nyl=mxRkuPU_~UW>k0-cp_lRItrMuXGucC(D2;GZ1a!$e_ z6GG)2b`XtILyndbeY)T{ihz>diK0*9x`_p)j~&iqEH%C)MjdiIINa|Z>RMduvos^`zrit)dM?!yrZ zP*K61N_Ap8U7t|>nbImEvlK`8l=TnzCV>CRi~5A>HJGWx$#97~9Qg_RwmCeP%TD)* ziD@T|oF*c`6W|) zlJ?b8XD@oSe1u$ZQt5+cMuE3?Nd&e9w|Ia0U~p0ibUC7t2DlqsRNJpw9Z&>uun7Li zUxRE@#URJ-Wt$L&S!(c+V}M~Jq9HLJi^GN5RDmE1vxoot~< z4la&6jdE-}p(uP$Y{G~cFoH%W@ST~VpKL(Pe^SHV&T&X+4g3o+(xK)?`&#+1qHUtgeQ0iIJVI zi^qPi4Y1iNqI*uZtt#DXG>=)cwGfdJ`UNWDY z*9v%^jPYkmA<7a(P>bTO4?{GtsMjbO6ZtY^^g0h(w^8&(FL{AINetbPy@}0-EV!Od z-x@yHVWLo1Wn{D>CW>qh@;V@vprbO`fU`GnD;xl&#-KFSx`S$&P8bTMD<8cX^x6B*WuPUahsN-Vrkw!s%G^4V2{L<`j0kHab#{dbWH^oiw zim?NB=4INj`|usaPHi(?yjdgp2zvv*lqa}a&OeN1;bOdCjDTwZXf@8~7SiBO;aKC^ z_>w@e&_xU0|8dxXVvr$XzZ_X2HeZk$y8+^%+CwCar)KZJ+Rl_!?({DR=JZRE|w`haIh5kmATH0Uo_CEKUQl~yR*4hNz( zg1iAl^c#NZtP`N>8(wt67w6TN5d76No|?b1H)m#@-MFyaV`q;sMkeZ8o`E|tL%m4C z6SuM`(wiuc75^nhk=%q+u(c=s8%CisU{VZ6%_%u7FgWIEG0xvq2_Q8zML-PSe-C}; z)R+NT(N@?nTd$T)+zWPF-}cc!i@-$-V7N4Q07nx+1GJEKEMi`Vg?Mv!@=|D6FL@X^ z+I`H4Br#_O%s?eo2J`uc@u>7uLox#99JJc;wTED`8{C$;i4NKmMN3$~Jy5ilrafhJzuD-?t{bu-OP zj6H3Zoh`Ll+hDDivm2Rthf8S4VEW<#%L*YQSYYO7RLnUzI_&nU7<7PD=4DLP7D!Wj zH$)I_*Z?q~31^6&qND}q6~=}WRqNGuukkj3%p+_72IHz@0-oH~6OSfhN>B>IR5yig$41A2gc8Qfu&Q&Ax@XYWdY-jJVMD;S8+Pyg91FAzj_ z>mD+fLSey*cuSXnymq)BJwY@Ce{>>(&LHg?HIgty$gZT7)oZHWinc^$R8B#TkyX+a z#QHoBP=U4aq~W3yQXtJ2f;Gm5rAEu`Ru`frM)@Zy)JU=Ret;Q-cIwCjW!M0mtt^<- zg57005H#lfSMn!4TEtSP-I#-YhD2FzVg93tPej5ESIHy9`8&~nq4)k(&|yi8F+fqw z;t)=AdfkU)62Yn+l|+scjL)``60}mxK!V6O3J!Bw>$N&zqleal9w?vP)ScKH-^f8p z3u>O8nPXmbnM9Mph@DBGv7P@2*CdTkOzx=_MnMRKH&!A^t@A^>r=&P+Ds*J)b>SH! zG^MDT{TIv`gcU=zvsdi}R%SLeY&dgcV5}xlYS7>rF!S#NV}Y1TWiGA?YOs3lr%{W~ zJnE!vge#7o;}OkDmdtYwo-|Sgj7&|GX5}XpbmuEZw1n^DhU+9R$y5+P@*L#J8}}k7m#(pga;#wAvC)plG@hIZlv%G1O1a zTp#Y_c8b2uLFRR*O)wPb`L(cL9?5Z(FbK!6DET}31@?1_W3$~SOvGj0(~^BC;!bnt zaJDALok2u^r;3`1@RZq7mqZREqK+O+8gMh?Bj-%gxp^5-&z6j2O2~%iz63iqeA#JT zwho zFR4wT%Usma9+J2`2~9s{_QU3|N6NL3!+FoJi(c5-J;pxSpPqSmw&cjLJTHS@`&|gU zkbo>99=X3Ae|VONcMQ(e~N8(f^&h=rj1fnQ& zKvXAfT0(GwQMgdKDtZ#^MEjx43&Zs=-59mY$fVkT$Mvr1L_(eZa@U(M6I-J2oK5rdQ#xlh=N49M02B} z#;$xOhmdiaM2GWhJ%hw0k)gpdB-^WP71bxUpfn#-gNbsATQdW{gDQIr<{8VKSbAwHjCsgTt-}n|?z3sRB8v$~WUT=2rS>Af z{SH{*6!2D?&EPz2)Wa7YZByOupDP1?Oz0;3m@x8t@5qkcoRDZC5XNg>7Y*evsTaT$ z`Fb*kJo)S<)1pXHlJdyZtgd~mL!IF^__3swGtcN1y-r?H#ESv(DO)WeI~LxBDsccI$2$7it+1!&Ic2MB87zX5AYCfaO_w= z8P0h@8m)t*ea#lN7Cm?#Y0~eMpGu@{^1tz11{JJ-Y?qI9tQULI)*FK=B#9h8TTvn= z3>=*f`=71#iL_L%H?u*A98qhprbi8@>uNKe;AnxM!XAsndEO5!g0_ZsSJ(;sGH_>U z)B-R_E*rNOX>4kJ#EEMcJ%MKiy%Y==$}s$N+b-!P=@8xHPDUX8CG=i`TH{3nJgcqH zX6tX(B?&wzuxfCRfTiPbGUjAWz9xl|1uRCG*DfkzR(}9rUBM z0~pE1IeOA~HO^!)c_Vrop?g1t#kuHz>fVefm(&#;5628V2Lm@0S~NB^t`$Ip#=xZCVy#A|}zpd7~6u#H@W*Hg)M;?)G*FU`JZ$w&SV&cZ)Mb z5Dh^yCrWZ1Xp_i6$`vH(fciALN6AX&_QDeuy_q@L${UfSAF}Rc?aH&lm%E*YB zM%#L>MkGB))xe8qzvzQuXPdw`85^%K?r=#%uw-q{lp#>#@P#~S&60>>S~W0p8>AeF z_N#=viJAE((P$=`AG`0&$Y6;1Q(@xVg3@P1#AW)tzKGfl%TDQ@f~5cs=@zlA9IPl$(Sm)!44T zA{_u31twQrbYBYRDM~Hd9dwsrf>tl6p=!I0>r?ltzaHF5VL~RCQ>;9KFCW?fJt#AU zR8NUNVBTEKCo|YZhZMV0Gh3*TT`ReHKsymTImhAKO1WZMDW!w*c&62K0j!GJq=*oP zjq(P%NE9iY2Rrp?N7RsQfgW2)68IkQywC$6=R^201~zbHD;}IqP(_F4MF2$gWwUxN z9=f=pEi8=-zz>EQmAfh$M<4>XzMXGYs5b!#8!bvG4#Sd7!mH0D24Mse(@EWwqRS22 zU!`3SZ^y&YlI~`p0Ib9a`k4g@2433>F%+DF?T|*~uOk)6yOLqvC^ND9I_#B?(ESj; zysUOCi$5W-v`f_#tukY&==O`&DBT#p9f*A1U=mEi^JbUs^*j>ErleDhS#A!trLMuK z6noJFy@tcMOmgVc)^=o?ri%!_t>GJ=-t-T?Ja0XR8I2-|!%n14M|3<$bjhdVorDPI zjQkWB;Z4XOCYek3I7A$C#7OZ}Fh;C8-w6^YHEq_qo?1g^JA?MQIkzeb;)0umIcW&wDk3?Hhr5DW=b|%BqK(fT!CwRo40!`X*>~JCvQT0mKAdROpvq1YoMyDB z62M0?++T{k5cb3Nn1HxI=!7c7Pg!Qij27C9Xw%Dyd~guEI{ew<#@J%aa_|e>H5f-G zEZeyGo67)LB>S{LB0&{}y4iPZ9F^^KJCN`6#B1*8_An)PB#7joF?u1Flhef&Z%J!_ z*vYt&^wKc!8!6g`5;agZBr{rI(?is<3C26XWK;aGGM|r7N0hxpl&BHr11qwY&xA7p z?ghgC(PBQhMWDkWj+Bo|K$2 zB)#R{GVeIN2x#IM^2fdFkuP(~j>lvn)dU=LKfDGtVe=9#6RL7&bX^0$0Ee(G|6xUi z$S;h4YXMZPaQA!5(iyUM!JV0;8p}`OI#e_Zsk2b{D9mCT#y}w1OsUvUG9^mPhxun8 zA3X%sax9)t>=D;H0 zXG4gX%xC?{Gm%v=fg>A~QO|&Gzz`rCstNeAWImepWD$qMHY95%y8q|Rm+yV|=o?Hl zYc8A!{hf=@AJ!WuQs6;fybevoSMAq;&$ja+BV3_Vl)QMM$ZcfQ84nx`PNI?>6&p0` zACK)H5$&}@;&rV{5Z}oRL860TParO>(%UMyw4CWm3Jh)ae>q%iG8_|Dk-K6h>99Jo zD;I`wf<3Nq@`~67rJ4oJS0SVsn&yCkHfOd3nn8%p**ujOP0Asm5Q&_omr-`uT`#Zp z+=}%LnH*FL9wa1DBz{{WWf)3-5!Ue`y5s9dhz)rRq8fAqh!c)%^N&HNRq`-I10UA9 zlu9t$uY4)_d1^$SH@avSw0+R=s$0~2p76|j{c4J>R0d6PoI<=jY$e~AnM|W;o6GW6 zn(+y8CM6zQEoLNwnXW<}$k;pET9=zv`f#{3_0xE%q-ZoZzFWLFD>#_bS@_J{C( zzL`LpYcSXtAg_GH)>=rR^6Ev5CmhdIF;@hVF}?TPx8dmmlgU9agMyR|x1%^K`x4sA z1bZ7zL2xt>JY_cVgJ-1Kss}oJMxl(m8WXr(L0uZ>6SP)MBH#r8`VcJ{uccWlrMU1E$K3EG1RRe7DoTG6j0EosN`H3j z7&A`XhJ;W>rHqfM&1cu+8^gnB_m}-?(5~oEW{;pD|6ojf*&H#Rz$kLCEhUJXSVx05 zxv7rFy8#Pp@!yZ6|xf z8_3-Ba@eRvmf;yEz`)1UhbosE}MkQnO(@l;4UAS#L?S1qGY)S^ib-l6@LYa6a{bOD9JR@e-=dw$( zH`;JDVtn4G>m@j_yim&y7)(7_dO3^s<~;0TmE z`s#ID-QEkH_b&=Gl-Hke7bc@?MPR^aky(A$XaR6{viqu|V(+wWN@K<9BM1dF5?9<4 zPz&9=yQ1DHvVA7}$jmFOsdZjMZcpY&0Bkd-&8?!Av-Vnr((T;kEdDC>;kGhfV zA;M`)r6*=?u3sv~TQlwEj037BuxQT}6);4gI9MicIt%}VC6cBG#Np(fm#*(o<=2O` zm#xTsC>EE9*(vVYPyRGo&ebKm+ELD^;CMQo;WvLWITp0dMNgL#0~H-g75v#2@p07| zP_>ZGL0qFh7{F5PFf03`I+=MmZ?UfE13$~oPT?&C4hij})B3er+{+i!` z1dvQ~_hylzRm(KABn*DeonhMETlU9mL}a}148mBwuMvDSk(miC5Y|X!A$n~5Ih?Z4 zNV@`&MCKt~gr43~H2(0BC@q4Rv(rtn&ISuS^ z-M_)XrrwJI4X0OdtMG+*@@VX@LK}cT6oB;P2QfdLb7YZoS!#)i=zgNG}FA3sEEFr+q9s(-Yg|+#gW`y32BjyM#M0qyc;s zw&<8>Dd&t!(OhPs?c&hj6d-0o?1Y$x=aa5#&lx*xHq3Bjy=u{15*D@Ukp$6?Y)FFM zixTa)NAI-hlH|l0vu}WLhmfi@E)>o0$m*%Y+rRm)WZ0OQwn~hLw;G9S{g`(cQX#lP zQ_2Baxr_+gsh9E6(d=Apz8_47ns-;i_VX@D7p==?kDZ3F#A~2NMh2$nI(fZZe&q;l zM}Ffbn>eK0@H3;qu+Vjz@uBA<5+{{7d^e&7-ibf=H!U&9+_S=>KC&3aQfZ5H(|Ijb@dRZPiqIk>yR_uQ*Huu zkMtJoAY5hs(>|}6X{S6@2uT+Zz-Y>c4r=VFX32P7I2Yk38n^9rrBd2kDkAKurV-Pf zX4#*AvlX%wHQRg)B%cZfY^>r^0V3XXs#hol`YTg7&vs`@I7x#nme?AeUFj@jk!d46 zi3Bmn#j*Po|7$*p>8a_%lnT_IR&`T`LE*nHCkUVQBwe`8;$WjXRlOXdISLby<1-{WfpOOI<(6{A=7 zaE7favmQ`~SlTjJvCXg1dBInB4lqHO%8qw}r&6-zNEk+%-wS#Gu)Xq;h5Ulfis4_o|0qFGm1M?2il5R%*- z$}}G~9Cn3Y+#*d9WSEk4qzp^qMWZB|E=W#Ps;$a_L;(&nCtxHzMuP%OAV#d&f2^cg zImQe`LVQW#i$p`7d8osvw%7tW@Pcv!hLJuF)>=$g#H$*WAJ{mClK)7qGc0-09rq9^ zehz|@j(9#pY`3uxL(;QeaP9`2BBj?w_nMPWYzfMaxaoFksHyA5 z=RfR#sKkuw?-i{6lvz)7Sice(-eK}%(5t-?9bddqwxQ3<63NEr07EC82~J_MGiFz& znu=dw(jP)Nm=L3)^g1w&2{@5b!`$^&d9J)ymP%xQVIlh>fpM&VZC~i;VeyCAF#>8_!|l#Sfw76SjX0!w z3^dQeZCpi}@EX>uz3TI77e-1o_@v0>c%aO`Qeazyo4XUZ?;XkWKED8?q{???pTYQEXKav|Btx^u#Wj&bJT6fq7*jMo#M4IvDJTmM{ zfZ#}5>9()NUIUa;ewFKDC?sT}vDBpU#!%zbRmnhM&Ned^L|}kiC7NKiz#et>#9VN8 zlN4?|Yn1wGhk>4o72xV2Q{a`ee7~RV+r-CiFZ;gRs%F283ENCab#7oOY;Is>EL?yf zPLF9$)dZy}bup`Y1W6YHw9;7VbxSY@5u%TAfeEgU>`U zczL|hLVhhhcu~cmrtoIEMr3XdNCBt3IA=^DnZlu}RY>mbG*TKUAG8WN5~nf1Unk;; z0KcT+Jg5&NZ4xw(aTtE;&)>w?#S@I9pdG=~=U1?na?QB?X5dwM7ZQ<$92z%~USQ5) zv$j&Kl8TA*?69zh$+%)VRUJ>BLXbi8*E^(pK(lAd=4t_d^HW5`G%Nfd1Ywqt)iBkA z^Xd<{@d&Q<3yNl3@tTJQq3By)jzNMiO(&mDhj)~b0agRb_Ip#=8bhTgZk6j=@@j0r?%c!Ha9I@%1EiN{hU5t^TU~10- z#JFkUik<-hUA@c}tAj2#ThQ13R{n8tI|lhVUf|EGV-PL)~>jYvdz@<%)3N>9qQsA}P}IV~D1?L|V>yIZfYJxo^GI*S&!tEpltY|ku5{rrF>P>TSObswX1+9X=lOVf zdwXQ~O*mPwu>>a;A4Z=KzW5H=3a>_rj1_ld2Nd}bnxoi3s<)YThK;|T%j;k`o(L<5 zL2-w2U(O}2R9MbRyozbrq~)O2(nixwy)-g^WiCeLY@;|QP?GI3jlx6wA_eS9g^J-e z26y*@6B9vx_D9bb4m)BRk$6U&_SCG3yl-&uO^1uc-8nxdu5D7#FiG8v@e{|kzXy8X z4Vn-J>p%@nHXZ1HBqW-zwF57q+1^h~U2ASa?UuBS`G(Y@Rkr1WjJDI7!|e?2gtXfe zA02mEC&ZAO_` z;iKStFM*};w&za!85+1Ps5k2>Yn2i|l=zSw9XS6VbMGH()sg3k)jj9FA7I?gY%??7 zX{15jWQL5`G{&@>?q;WP18$hcaPNH&o1SI!!0$eI*w63`&o-VVZC0kcJ=;j_-e$Ax zhUAhA$&d`mkc^WhS(HT@{;(pnL5Zbtv`C9GNP{$vh9r&}sgXLLZ`Joxb?&LUhjTIR znP+qBTXjD5{Z+r~)H%m7aF5MA=$`DuJ{v#B{RTF<2i}yj`wOyGx4RTL$<;T0$8XTZ ziAj0?rr-;GMyiu}SQ})|Wa02(EJzQ%DH{kllZ=-!9YQBLrCS;H*{vhCo;kg}wGZ4B z^iSO2?bb6-ud8Yi)1_w?jmP^8FY0NU?p| z!k+P7NSt!Ow?S|+eCoMP&rEP%wD_eId5q}OeD0J_8M0okKZtKJ$Z5ZI+i)iW4ap7u zNA|rjb#VUmr*RnA7L7duw@weW7ax~HpYPspFFbhv5Jfd?uax>24ep=la#-Gb#h087 zbziyoZ77-4h+Q)avu}!BT6)FL(?9vN&IF^LD(u5aclD4vqNqo1N3^h83SQxZ6j&tj z2sU1!TG&Fu&LCa@HT5DMf{>4=@Sqy+R1Dhb!;1=rKZWhy^ZIF>#YQ{tt4#JNr5m*; zrgrW4_Kuyni6|%Z`kqR#l~7NhVDQDR)REWb-KR;rbMlD``=&R0e{9%(i#Ly@e;MxV zRq@~*+LOEUiC3_fGD!t;bi+x1!v{zCqFAGC{+6YTKa- zVV@Flef?M6emuITwwKvVG?M!K1YQ-s`4qYhh54fgR?#RcNY2^jH_?T=<9_8iDz9B2&TCIe#8`a-UU^Y;zh3dDgpkH5KVh$WWtS5Fqon0f& zrLg9=_tCc1TS~394-?s!e4+&09XK@LlI`-Czr2eXU)#Zvix;Q1O-;Xc_{Ep(-rK)7 zJ?)-xdD*@?4P_@$_pZK)g?)$0o*3M#x+gFu?6Y#(L{nAEKKt@5d69u7vJD& zPK)WZl$ftzQX#h?ALDTpDdU1K82P?gtPwKS&nD>M{9pye?{&xGAQZUv zVwOvg_TXU_OTNN5(%+)_m|3b+zk*7?4I9v|&O-tFCK81BpVkbg2gfs4D);~c+Vg|D zR@~_-cdex@wz~UtcE-isEZ;Xj+N$unK0Su|{J`lqI+1eTOdIYa_cnzZL-Gx{2h_tLV<_^As3QxG4;%riK*Rqv!Za&E%BW@@S3FOaGh-R z4Te}I?CZ)S+jw!bdF9o4D2OTRlk&6Hy}M)+-uv+U7QCPUpZT8LA}_n%x&3*3kL~b& zIR$T3vG3Y}C*;M~33sbM)M$#0{ z@j)ebmQ}2`pUJT+AM^68{oWP=6c)aXseWrcGl^}o$z3+ylJ`|SvuSeM^IPDDXYt9_ zXmbQ729L;>-0>JOo^>$$aA!|G6FU+6BOJn9=Ux&?Dd{V2+$DF5*yzwd&>*Cqx7w2Z|W{|uA3?Db1 zw+wLAX>=4vpyjR5@-c3l(9wc)Qz%h!A6{i{H7!l_UYR>|OpZ*;G|z7SVkb;IE^Bf9 zf(B<{lMzHs6Sgdff=k3lcD47T-D0O3f~R)jjd1Q+ZhVx|9dw^^H8s+{^~|Pk z<0)V{4!T(^+Kgcw&!@STi$jl6Tkym>-j@~hH1h}XUXP=;Z1FzVV^cUHCH3(zItr;K zV!^lYty6nczq1n`Xn5XzueOx9)?jNxUOkFSmO?N@u>Db)Qj#M7|X`y zQEYq2XP3nE19OL8#Lb)|XmB&GhQEemKJsQd3q=)@iavGZRa>p4AG0;7Ps|kFlVk8E zB%A?vy3>2Ee?&_}k0ftW?QChuF}fW)cWgmlgr{lVlpJ0_J?hWE2a|dO8HTC-R!ZCAb-yxgFGu}9d}JSX+2oTF za`U2VW~b4J594K`u20f_r#o$X0^nu!>GcWq3VkI+!O6~-Xi@vI2QVj}@uaoveOqEL zR!bfEtSLLTgNNqu&R*-h(6QkZnY;@~julvuE-oX4EmhTBiV3oHIB{c#%tl>*1bt;A z%l1jWnoE*9ONW;hVK3roYu$RYulxEzJokhz(Y%2-!H90?Tu>5Wrwxr#TALe$Y&+kH z6WXp*icR$c%{=_#UP1_Q_>`?}QAggecQ*E6DupxIT2Y@iQh{W9MCvWxO8D}u9QRp3 zg_xF)fk_#OKK5oj`gwNsQ%Bj}WsI<$j_tegNwry2zysRV+2-8WElQ{7hA;VE!r}eW z&ErW)0a{Ju%POt|koHj=ho+CbIgiTe{4B4S(_v5g4Q1ets(REzE??APi%_ax%CtFc5Kg}qv$5QN^$=YJZKWe zCTJ!%Yh3St?8tOiy3N9LMs`Nn+oCVW8|ZCb*PV2wH_)-SJM%JUFrnX{+}4?TX1h$H zCbn#U7QO7w);H0aPVL%cnF8p)&21a|i?3leET8Kv)WprtZj)2a-Ry53?=is~0RdhTs(pw1#^kGbfo^|ShhY$}lGuUI2V&H+?Cl78 z6qzxr=x^o`QEY6N&)AMt-3A`rL5NyvKFh|if;_#fU+tyNf(GyIRS}mLR=q&Xm zhb2E0he>9HJhL1>NXG`XCa%%`fp>e$mX5CZ2yY?x|-Ohj9v={TO zBiJBnt>^3zpW1xpo7<-B0z%swtzU?`@YgxQ#O~S+o-M5ThR!jQ{ z7t9$sxLTLnnE`H8;J&Jz0WQ2aXVZ1IW)Bw6V4Y!aW7&#q@Bx@wAKzxyQCFKhwWRFKK*N9 z_Cug{Dr1LlneS_@x19?+fa!x$F)_Lxb+d0AW0k_f=q-094;{62-R8h6l`&h!o2xKa zeQn0|v@XqdC~nkuN2^gQ`#L}|QhP_Z)s3|MjZD@;FFYeVExS=BPd;60S2_;Kkt5C- zWuh*t4OuCukI|>Y!y*hvBc;!Glm_4!qQ2Q~V(#F6 zJidfF=xTIa=ls+k9Hjyk2MCGFsKQ4C4^9`mvgclyl2460#?}@cfiQ5})$P%~u}{}v z_Vy{BrhFZ%4%8OuL0mmTQ67F%UUyaKitPv7rzl8k6c(yj-nl|zEyMc*QOTxc^*Xup zxow+VTX3T`-%#fkHC8FPBRL0C{bwDKS62@5fydUi))u^IN8Yzo)J;0Iq66fe?rxH9 z_o`)l#*_uU4(8{0gY3+{LptuwVE+d_lwGe&&8MHD%5Mu@-c679t;)&JH!%3yStTBV zw31(F`wvE85@H|iuygN1?Gi8HVT#FTzJ;ebcWlDl>_d1;Va|;dR)GB~r!>)`acGma zs8RpzVjgRYBZttCP<4*b%UqS)`tL?VH|%kyCe=??w&)+Uh{M_@Oakpg%bPcC(~qT0 zxEjQDFobdbTb}LX(QSNl+-^{OYm-h4HLFy!=cai_sd@ z0%J^4H*eW3FNAml+XXLTX*Y0GH?Hf@u3Kl(wiw*3PQo_^H=^wyyTB_?CM~=$$D}0(7SXsiVUy4PxdunoG=hRlrTd@6M z7eZK~2~Mh{eYGdPz9czdad6mJMVFoM%m-TwNtXsBE!+Kb@umZ+k>G1 zr6u9T=JJxmP=&OK4w~dWw+X%GtFNKG+r?;qFO73uGMSV4*Yns{(_*l@L)LG0AK~aL zXrykfZ1)5vpBr2YWXX?N2v)Jv3&moUrMC>2QZVo>st1m8&Ew-M7?wcUshS&s<}rY| zBd=l7jBe-KQ&`es&tlt-XHfv(lwCLN^xZ5$xMH|Cf}vO(>DTY_sfj6>K%jszI&1Zk zjz_C#NHMQr(T7Egyz)baOqOG3^LJchl$|qpLRR0-8atNS3dbFf{Rd~}@VQ^xjyTe4 z?L)sSeTZbZ#UW8Y)^1m0_M*B>R*+IDIcHLR zCfaz(t()2CwubFe`x-u)0(Yr&Q}7i`0{Q(B`LaCgqCBkkqFdj}f<1H;C_d@3F%5tD zASMQOn@^XC{i}3aiq*?5`K9XEK~_#GPj!L?K8tkwN93HZ8^>)i z%H9|L$=nkIzV3PP*?EhwZzx2q{pNQjx46Ay8B=%Rn2jB-u{Dl49J(FrZgj2Md%pOl zD`6bMv8Np{K*@O_w~oO+0V=h&fBSvw$z2_J(S+Tww*8~qG_=Xz+=2s~;p&d5$=zrW zZycG217>vlTsOqJ(+h`WAoc?=nhQqVDfj#twp6jWkn+aZ0_WQ&k)<8UUZ@s*=o)d> z+i#1vF_2hS3)=Q5QY2c5+>VPi&wW@6nSzTgTdQ{ zFp*M0n903{UEL#7FJd0%*URWNLRFMgvQIv3#k;`+woPM~%N6$IuBo+Oep)M?n-;qU zhc(KSY>C;Sc3}z=QrW0D#3G7E+i1VX_XzG`&lYar;xjk6L111LhrfRCFlH);Q2k}p zlA7*bh$#!YzKXBCG$gv6del!>(WHK%vcV?@Fr$`@DH-SxbNTH?q;9no=i5i^R`wy> z4VG#1QG>S79mM#T#f3$+BFg>Da{7DJL2?nwRv*I`Ck# z#aDZ~PmL8UdRDtAklI|hyI~iG7}U^t;tlSyJPDJazEzR7g1!l%+tZL69;&iDtGjOj zLpWN1?0Ze&HFKCuN}adg97Th$7UH~)Yi_pS?d=DwO|e+&V&`1Y3+^5Y`yCmtjqjx_ zLTkRAp=0)eJW~EBeC$2@?P@o>etmAAZehswwe6Iqa1+zj3D!D+TE^0lL$k4z%vKC$ z3PiM* zd&5kdqMgY25k!{iM=+1YWWcs)9bH|Ub4PD{2eNB(%UUY)Kv~7xAyYiqSKzo!gr+E) zyD~q-on;x}-C1^pEf11eJ32}fscgnu`ytB> z{b=xTzTCGER$S8-Y6GTOM_Xho8=_3o$4ROdIhiQ>6V<;+44JueLZaeDEDdHdqa`**E4oO zu6vT!i+h_>YuBt>Zw?>9yu%inoHBZ9--}1x309%xFtJOMqj`>!vv7`*2ZoN)z+(%uPp*|1rx#(5%k$B@+IHgNrUlmHt_9;{?d$v2mUqLRvk!&P~cv#g`-CJ+XD_sTCn>^twH9rrsc^ya^_6K@1mK5lFb-S)(eZO_WBU@VlS zr^Iv;WslXb+!&I%g}ge5^9xsywnLT9S|^D88x!u{g}BOXQgPO9cYUxqA|Il%lN5GU zcrmy?yd;}GxGsBUvIxLIYg7S$n+7Aj>-)GbgO?L%>qcJ+b>)r*hF`lk!W9XoLr34h z^A~Oe#zIm1e5sx6;kEP8dtH9=ux`y)?H;3D(>)Cq=)>fw6#~2uOM<6du+D0XCMDA> z;cr)6xbKM_9OaD;-1^NMg9kco`;^UDX}Xw_*kvtT6m5EiTUKEa8D?&FKR{-w=ykBC z>TXGucGcYLfoS_Pcs2;0vs=VdyIPpNaA{^oUG{Ql*N5z9-R2M4&XJvWXD;_Oea!{;({`-Kw8joLY{p-HQZ|Q6E2(IHg=I%@2fT?&p`(@d z9pRyr;FD+Ey_EPadSRWqWpbt z-1f9xBlfN7wl1c$1Aihr&CSxM71^9oQl6?-6k7q@zP8QI5>{3mNQ#Moh7>Zv;zBp%Hql5U?U3f$I_HS~A8kc-wTM~Q^ z%1$S$mE7dgH5YnAXSUm%fFu0}scfT@8z|Ts9Z;oo`oKNRLY>Ar5&O8i+|6?vY3NfrKhz`20D04 zs!z{#7z_K~mOJAB9X$S0h-eA*#qb|l;*Hsi3 z7gHDyrp1&e=oMo2E%$?=Yz*z}Oy0a=9D-8y*G-V(N(in?9C4MV$pUl*;#-X(bD z4R#=5fScTf+vD4(c0P-m|IFqI!RiFa-G~>Fg|Ti|;pH&W91o%{F3212;VfUl++8be z_HNHp7EJr*upUMki>vIE#yuQ)P)^$MzAxJN)BZ50_DVV>7EScNjvRuN<|Ni*q97Fp zRZI5^1XrkodV+EjzHEt|WPIJS<@!BrLJE@GcJ9d8g!FH40cMe0)^ec61>gTjO`Iy- zpMHw9OiZ97nGZmR{}2z9u%8B;j7Id2yncB7=^Gdp*}b68v(x&;cN?moM_ zwP(kYsLV^ZZt!T=K{;?ftTZ=yD$|}4l15=~F;pKq@~dzG@M56K;T=>aFqkp=(DPQSP#=3(UT#)~#EA86PxEs`HQ8S}@>obB`2(NSdPhkb*`O`L)%`VK zBKfaYcy1Q`yvMv}iiym{FrEAD@kDMUG8e-}V}&yBlg!HuQ?LX#(^y&JmZ)!;p`K8>BCU$`%7T8ZC<}wKz>DYXU$>}UIj=1sy2ppf+;1=G#krB_b1Bhi>`qCp150o- zjXfo9$+Dnk=ZnUcMP??3r9>j%E$s>ZB6JcY?^JdYjhtB-ru3}?YGmhB62k@9CwhvXTbG)?k)UtY%k z(gQmrLm_Lme2`!0l_~EPd`#YDq94TA3GbB+-YXL%=?4d7?6`Nq1W6k0fQ-@ZhM6Eq zyEF6SW29-d%gh)JM`n`rfdiHukd+h68nt(wh9hSGPsV>T&ggwjUL?uyZv9E~Cru`? zRcj7L>9}z_uM=Ku0&L0!UQAl2?pmUmoFt~wse$DcE&OX57FaTgK2r4}!)*f1q|&42 z|M``#HH=r8l9^7qWX|+7cc!jaCvMdcy(G!)-tF(0wZGA0bdM&Fo9~%d&2n5}%JssP zAJ{8&?{Z%^TO?PiTStuLUe;cdsb)H)@+{wmnW4lLUg8YNRX(Xja;s08Avx)j+9X*M zz`m>|lFF*(BP=Z611k6+VztDxssKIyu%O6MpQ*zs1&TO*whpHh zDB`rV4yP0-;`B?X7p!-ueb4^3S@-!Kqb#ry^L7)-<%-m3GC#wHiNs`eKzRg0<9zHJ zi7v7^PFV~SJ?>~7&{zb5%s)uUG-giyb5g^E%oHecMhc{}g5can9dRj8BrXMt#AS8F zr9hFm6etpx*AbTjMdDJRNL;gyxD+T7mjXrNMr<*%y1cK|WgJr)%zw~?m~vgOJdP{# zX6?%5C+%e>e-LF1)q~VKieV!iG@KbzMkYpN$CN;7*)Ru4QnPWZ?n(279#g0*z*LQ4 z!;5}Tl}&&Id|kVG&H-u5`^vJ;6t>I*ZM2*{*=(J%%zaNafubbuYf>s;_rawMq*T^E9m5Z%U=4a(~O=`}Td1W8uR$a<_{4dI_eha}%{sp-;_W~c} zn%p%DkN-uvM&+8&xBP-!)AXi3$TiKsCfBIkU%YEf#xCzcu8EO@w!l40cAcM~7p<#Z z!waPy3GHl`CpWhm`12X6wOr5<>9`-6+9cocNga}>G$}W)HhYW&jXES5=H^Hd2c}!#p1~ zGblpXLnzXyqe#O`s89qo-Y*}i(527{uPgaMNFsU5C$&i4)}-7lG<%E$;VqI3amX}Y zD`tk5mkjRlQlMxa6F`qCr_6jmDv9P8)m+G(zpej~>s}8FGs$%uI zI;;Yyij}L;OSOt~CXQiyk0!Agk;IXRGw$Tz-p_EAZ-wocVVexk1{6ukKyw<8TAhh` z>D{dWZ8QmDh~t&vvZJy(puCwk=^%z^Z-3N6dn0d#OfL&+jyK1dmm%()FdIW8m2-}c zk3MA1vGK7eC-nPbJFT}(FH0Xc;(coTiL1wBMs|3}jte=N(a;0)S{3Tfd>%KCTb;@C zQ>k!|`*NmwiMsR|BfVd+?o-j^Gj%litoiJxugPcYXtLBS{q!|iT1OMBMq`=QuH_nz zV2z8Np{_<*x|+=H>3l!hvWkA#Hr6Y6k@@~o*|Y(B=Kmwl=T(tO4{zTkcb(To_vsn37!Sfx?ur)jn0SGqxdQFI(c` zwCAt9J#CUy7dJ#mlAY9@cC_#pj<=Q1$DZH*^{N9i52&=|oETOAatfnrIXlzK_DD7T zq&(ynX_*JqEvqoVg1eFJE#~~XFNdg(je3d9pJ3m}s20NnC~MN|3=>c7!9vxAb!3o3 z;rp6M*F)F>(HyKW(2^wUIa&-!R`M~s>3px@YdtG9vXi8?9&5!Fex&U5@2^jZMn*ju zj$zMt@y~z$Yf)>7p-uDltww~SQ7&Amb!>xgUoDdF_@rr)r!}c*zK5=Yu`>Zk^1VJF zV^@5t^eK$7%Scx)GpU*8G?YC}(x)^n(Me~fku&RV51XD>l3_w-i*P6y}nu5QZ00Zu@9ncdMT%JPBgK9{vz5_IXlz)%NRRRkAR1?hq4~^Eoeoy zx2XKT(o2a#9Q6{JKXEs`kx?y%36L?Ynio{uAYV0VBk?$>@*>ZK;AS0Axx9+;8{c-Z z&uw=h+(hz@PdZ4_Jm*kuHpbX8O~tK1lFR#mjI{!gY@F2-MeL%*R?4To}ohNsp|Cj!|t$xJvo#cY|Uza33rZW;%VBG80B}tDtAY*h7 zmYyW(2nS@0Rs%?q_BkM9!P;nJq~A`)Xz#c;u0wKv_~LJ{v(80!hz`g@wh3Z6Jah?$uEWA5Xc1wu%Yp>zN(-*epxK#~;WfXdhh z(q1TqETyKDl}yzhIim2ec^ifjuB*z`LS3rUVFmldiZ-uPfhGk0cwQ zH<5QdkvF>6hWA^k_6!qiDav~9JC3@kA)q9W{XKUH%NUZUG|AOs#y;}S8aS1rn0sDK zo8$>E<|UG3EMnR{#)6oasC~VV!tZ+F9g;VGmo`q5q&N}Y@xm{8EvHF-RB%S8$JjFO zjA@cjXp-Z|*!ln@xuFlp*q#6+xwj9<*ogondA<+G*u?-ON#{BpAM989^ef(h6C`i? zqyr?2KAlMT^gzm|6W*sMy}k!X(iG8mqQ}_#0Z6iFSh@%6H#RnGl7@ZY4eOFD8aA0Q zteY}yGGSOZW!PlGux`q*bnhyL#pdjyIqzuw&CQQ5eU}j$l$#%2`Yt2%p+)w)E5u?+ z&nF~ZPD#3)l63jIfpfrdKvEHODohm$l1ZsT?p*J#oWvPmR|e zzeMp(^W(eU?J-6!ctt=#LrXR?iel)pmT}=`264AlMc_}o)nkl9Ar=iJ=|Kl%j6Q6d zA0azqEThE2Cf0!F^&5NASJpX_l<9zsQ6@BiuNVs&M80ZzH`51>VcAzBHF0K?1;a2i zPsPO>p%TTI1}Mu2+Mpa0oN~{p0%S5? zWSHQD8vrV1r-m8MY{!2@Rhk!=ZC7S;0DSa|jUM9^k~nbHh%`yecmt?H5qoPy6`(%|x-m6N}LUGNG<#IR!9u0s_KO`3SEwY?w&rk;S~oFaa8? z0~)UbT2u$L82VEiPJUtHt?%|2`%pcbIA^!mXC)}@oyV6_1j97$vo&#Jizts_!jbt1 zFEUJkM#gxNVFDym6=Mh(*Qz^;Gw5&QK^E5EJEin;?IPYXEBy3x4>fi_8Gq#4%KkFX z#BmPCE~v|<;5^P)5c7}?Lk^DyA&=T8{oI4H59t%fE~rZ{JYt_L`BZ(<&;1ko#IgI- zeS+8gWFKn}!Vq2Whgzo@4%lwb4D$@CVOL76jttAK(H2eNN5+qsJK7Ul9T_8uJPQr6 zz{!$sI7%_}I|Y}0GwzZMGFp`J=N=Uu`H~wz&B!4*+7hcgO?Grc;sDGbb`R+RcY7+O z-=p(@G5579u{tC=z!WHPQ+>p*-a{$WahoxzoOSAmRFsgHbpXRE$)HG`>d-Kw4{1U= zXB`uyng^-W`=L!RhULia3_DTpCw6Vhutax}d0s2D2_<>OummrYkq5&BC^NiB>iM5U~F({gj;^w(>A~>-iN`Ycd&GpKurD4KEtWF;c%0>xdnBbIq zaTTCu9Zq-xUv=84VP;PDd)vl{sx&V!+pf$;!OX5sOF|MQ)`&F0Q~qU50;oa}S)Eef zhfpN*ndy>*A^}vP2v({ccW6QD-UiwqN>-0)&BG#Zm|&s)Wv)39=_J`@`F zyocibk)oTrGh3xeZiYcOhe9_DcgnZd&?FlQoeza>7~YPXucgT_=zJ*Nrg>2{xTaxh z3(3>~`2$fE=1C}03DO^`i!--VnbT*p;>?{? z=JeUDIP*j*bNXaMoOv>pIemH{&b%v?dC=J`WB#UdDVHj5ljd5$lT zBpaN~B3a~^KAS~;mz1B}G$+m6gU)6p@{T9+M)$|FCUY`OF3hCDVydrCn$2nmD9Pq- z2f^7al22%otHq2R^UfN0Hj83TdNFO1OT3tuNRqLLY4;clVxqelPSHWX6n@+b?~vT{ z0&ScoNpT{)8?Hkg+=fNb;jTAY)5>IZTsW zqe;#f#?}WQNjld72YE82)2DyxeL6vM*8B7T$)Zmu5v0;-mY_B)0OR{L#WWum+%CO0VVcnErlL^DRDZ|peYucP$G-sJs zB75SB5gKIAW-&q^R-Vm@9rt`f(&g_aBwhY)Lek)~S+S%S5|XZ@Bwa~Ks&_VvQkQ5g zkglBcOgeHBEe&wnuVduO0yWs6xaO`Hy=ddfD~gK&Tv4AB)tH}05V2Dxbszv(a)9V ztEd6Z>o<0(uW)lDDboQNqfB?cim{+U;(Qe)Gfewx#1}_3&Wy5P7^V(I#i&FvW;t0f zOtFel308Te6|792uezo+;HHKNW(`vVlw}0HKbTYQIaPp6#)}LSI$?ia#rzu$)7v0K zRhk!=eW=X1`@lGbBv+u65kS#x$A(w8LJ?`6PN;(QfjK}N2rTwl2}*nC@ud{OFpc|cP2AWb%43*tWIn=+3=^P{FQ)s!K0CVxPDpOBC{`ebUeU6Z?ectEld$+pyBZ zGW`J zOXsXpN2IOiS$m3lw43C6HlvpY+kiHc!~?jrNN zE@~Y~@`_;zUM3?Ch6zw+c#+BvK3}yr>h7YK_u{Px5h$9D;w{1oA~?B?AA@2}&1>qW zuum0%usVG(C>te+VZvFsXRDkTCP2+PobWh+a{4zKrtgmuRcT&e_MtN4ZAr!{B)K}J zi~vg9A0?&2vZ2uVQ0Ru?Ew%f#G#Lhs6Kcw{ z4sX+3ueowRzVet;ArfFL0KITj>bNilWFcz z(1M1kk;2pflS)X~yfWjk%{YZ5DXyhAG#vHi#~IkWHEF4&{a_(ibRtpX;iwb$CX@CP^i;mjFJ)ycc=e()$X>} za)x=Ac_A|-=QSxe-`knEL3%=&kZH2E)&fz7An@(@J%%Hu77Q~#d^3vBb!vjVaD()2 zZ)un09&hQ%_^s0ovt2JwdTzh({8{+T47ES0sH%w=J}#xGI_Tz5=z>y~T&gdf{g!|E zY>VU_pVTG!u_n2y&e%oWSi-8Eomy$8M~+73ghiIsF2`vGosSky zl8WOb#BS2m8z&}qlcw5&BTcOZN193tjx==^9BJw=xU#x&oCd7&wPu1OYY%!JlGIs> zeWJ%0YY%`Vsk8$!#@YiQNowtYjNR}RX__R>a=_S-ataM&ap0?pBtP=D?kC9tLZM%N zixJv~>T&rkMlShQv!5hO&1PnVHrvdMtoAKwKgpt9gHLMFy4b2+w2E4z-1m^C(x@MM zNK-+bDZ=w-V~N66&`S>bDZ=Ysm)X z-DZ9wE?+Qo-!U{Rv@%`woz|kC`IfQL_fJTqX1je?ghWR6_?mIxl9JbpI7XT}F~oFg zwUVunL~^fBn!KRo6%BJEs%Yf4#~mPPeAAm;rsSHCv_Z)|KIs6-1x+&AsHv^RQV1qA! z=)u0C;0;>L7knQwL-Jqxqz)@9Rl_N1mi`JaXNLYbuciZ4HXKPs=|a=&kWQUg1!ZDH z4c4orl16%~x4uR4xK>m&;;qz_p0V>R)tV{`j`SI?ev2f{5EyBerLYUSlRBn4oeH|~ z5<_=miRM=sO}C3E(&s(nnX5`(*HB=jL(T9d#+o58+FWgn(|E7ehm*cuv`L=Qq%m{E ztX+w3X0y1OUduMg&uh|SGBk~@U3v0WWAqF32}4=<*+17aF@}&@q$#^S-vvvRey1*z7XxepdKyXqKJYrI5tVs_E<5>@p=; z95}v8lGQC$&AgZ37uE~fEqKy29BfI_a7^$>URSqRA21T?kM{xVkHr;A#*&TZ6=lP) zYKf5zh0cdUH=z$36)O$ysI+xDxf?8zoFOjI{X>heBsfJhokOFBGP0R;YSO8%}G!OBz<&Fbq03!=M`&Sl?G2 zZfPiAa#+xM&x$K)aTN)9Z)jfB2WCA!xao*g6Ul|6n3oGGB$1>hvJ#3nuJVz5gmy42 z@FU+;S!C3m;TYZ=HsIr4gfJY`?r8fN^+9#<4uj6kFzC$O)>?SKMq|Nkx*^cbq0my~ z4a1ees)S#-7TBwUXVGU1I`SRUuz0OpEi)XO%6=h|awGr!B5Z<~j6P$CS?0!h^%X-& zi~Nx{9zL((0Qf?OMPkQwMK9P)sQr0Ns z$~$=&r@-92+UPMt>B+5iatt8#Wze(X#a3$Q=DOrZjXtS{cq^53 z8CHzkgfJX5a#Ohv)V%7EW*BsChCw$B*M#f*nlN$`O0~hu+Z857Sl+Kn6>B>0kN3oR z2W@at^0&Q$9cG@?aT@DJl7CN=aJzX;Xx5&J>_B}Yw>_R)vhEvegD8dg! zITN*=67Q(Lk{#+@y~wblLnVaapbnMFt*%iEGcyc29}3+tr&WWCwKN$9jWzcWyzy=( zMc>shJp(YcV0b^1a$%U{hBq|Tf#DrZbzru)GPe|ZTSJ+ElKx23(7;Ikm4~G!pk#Je zQAsOg9)sD4LMV&VJH{!{PCyx<^hAqqc#Z+24Z#^IzX4RKp__m{Y7MhG8U|3MhNj8O z43nc#`Cqqx9yE%hvx(W@kOKHpy$6B+S}9#y$u@ zlK1<7j2VBTs7-Q}COM9btqwqvoBM!_Z4E$@MT6s$R3oF5u|c!qJK4Yew_V-p^Fxe; zSNjl%jE$2W!vtvD@FLa5$)2UrvN(n%cr9K+UJMhU$LfI0C_TV1GwULyVpKw2mXig; z6ss7OV3kK&!B@*7wVL@EtzlO*#Kh;s|Kf_L209^mbc`$+CO~6`7ti}jAN6M`P*igk zJw{Fp6XF)v0W}SEVS|J(et)nph%R_;ICO=d%e)gdjpk)gX1*E~*{C<_awy<|Y9`SG z)r`?tOhqj_QXr+~ScIyohcP-Kcsyd65*(wd1jp!v;6=3r$EYg7F*+gG!=x;|A)ihb18CLnDX>MqBz89+XnSpIJLMQYb9V1JI3D8)? zDLDkiumrC~k5LfA1ZZ&`P&2=;URa@nF?@G!pf@6PLhhI$%W-8nz|b-*!E4cD1Tjp2 z7S{na@%f6IYASib)IX%D)Rkj;@mjfK0;?u@F)X@`ycia*m3cMuW=v zRu{aqJn5jMx{L7L&T{3b>)lk|qDo~2ir32OE~=-l+&^Uwua$wJCVxpA7a!0$t&|GCHBTJ-|TGF*+%Fyq4$~RV6w`Cq*x+B|1h`iH^}p z(I#hEvudUs9-|VK49_KMwW(qiqY|u4P8JNI{4Ylp7Eju$M21x!kzQwByRHQdA)6$( z@v1idnEfC4>}`_AHOXzvF-E2-8wLJpz%c~)nHF8O@=||L-7_L-Pr6rbz4K!F_J7}acF#? z(Pc~hlI5x`?ka9*klgqzle#2Zn&gU&v91TUNgnq}U6QBz@-lYL1KT7o`=l<(_xtiP zcFP0XB*(REoq~)#p{X#AB>k1RahY;ce;S?k6?IyMM-WJ_RHZWWj|^!#Do5dT7}@KA zM+|9t#R3^QTL6-#3oMY4n*|_gy1)V%S*HFFy-BapGz(;8-UI)UA-zxpGIF5+Bz>_6 zWaLHxNcw{!u;0@*=I+y3a)Ww&v#+i#lIzuaJi4?-8Fn>963GKTsYTt-`J|Vr<$FG< zMUqM;UPu#EzNZayv)5&Y#eE_qv0$%+Bo^WQki^0Yf@gvtM>P@H+c@eW*2~krUgBvR zrSEu;9W*K=_rhKv$r_7SVw0p_GxNi78bb%m;SESg1JcYbouHlu3{|Ln!<39Z z{-(o7-6efr)1Vp2Wt$vK4(BMj+$Xh2-qR#uM*4n$kzB53f*DEbo@#8th(KLY`&R{3 zNiOvQyQh^rull4e$!k8TMUv`ape4E4E8ik{+9!2Mp7BX7k~Fbm&_1J9ozrjx zA8B3p8$CwsUGR=K5bo(^sG<&a*y;$pZ0W*^f{mQl^*FUK5c!E^evzE z)gEbvnfY3;Tyey2Ce*7Zow z`Lr+hNFVoUPxnZl@@Ze`k!H0N{mNzDFl-Z-)SBwvaTs(y6mPs_QZ=|$OOs*H_$a~< zyqjH_1K|olB;W(F$_94!=UlX3)NtumL|iX^C5Y&i7ZjyRaG)P zBBJ`%K{tm&%8<1Nm}55j0K&dLobUns5KhGr6gxHNs74DV{9$}NwPp4(D57eOL<@SY}zFE`lM-+6e^tC zUWIuNY?C~#Ne;-^6%U*yS=2Q?!kHQQqmH{ZyVNPt)ChheNolF7XZe|yG9nXXCP^k( z3zE;DC_1@3B>uR9s_V}%XgtTSJnQhr!F)wusHMp;XdKKRg17O1SAW})f36|iOmh7< z+$Frti{vJs)FQcAlUzk+>_ZQn_M()K`f^*PEmznQlRv>N^q-8Ene<;R^J^6N-BZ3O zVbAXal|hw?*Xr=Xf#h%e9}rUJ!}KzbqJ5uKAL0G6+C*L`A*%9c-pkQ>Ry?z=`Ix`T zZex}xE0)M0>+qV!60(YKJ`}oPSn@Owya(P|X?paeYE*^B?R`ZttU}{HzoHAgXIVqb zC2mZsgibusgs(3th{h#A@^&A><`j;1WBt7Mo<^<}6U%y}bANw4ksFC|?!C&qPjVet zf}3e{OWaUz%e?SCc?Dh7&>C9@mJ*443(ALl;bXe&1HF`RJ05v4C-w4~q9*0MN%hjX zzrUmx=SE`LxJKhtN^%`of}3f)TjG{#J-6k19of~ee+sv3pSyZb!~Uzw)h`=0?7!O8)P>~L6Pij7_2+d`!*33f zny%jK(u>m>YO+GP7Ow>^j!N;uB;UuLJW}+1+Sv-fM*zhE)@*Y$$X-6uQ}<2D??GMJ8|Qq|K=qev@F%H3Q61xgkf^ z=fNddMppT5G~!!@rdDgT)x4vjyv0ySHYg;O+X<51DK!oxk!OEM31n9+(K6rSwX%TX zwSEaW8<0r~CG8Hjlm*mNT$K(KBa;n%%ClD+No5gsNwh5BcJ34PACmFD1S}FDsr4 zdijcm*6roI1J_G&?%!Y1i*q9}_UEOP%tov;?)Po{S5WvVj?3y(?r}uA<6li&FuJv zU)M92y|R*tXuji@FF<1$;fIv{82m0mN9_}mv&gEY>V zt9qSIO5Q#ygVM|z5wmfe@j04YKbnk&FdV=$g}c*;9M;I`E{0gSz=?f-Sxze%riJFC zyv{Je%$TKn9rxuLg4w-Tv#ci0n5Oa}-?Va#nz*bcE+3&>A13!Wnl*7FHRYNn`-n+x z+i81EW3ygon8r17UT0VrH(+mtY#1hbPfX%fw+Gl@wkvKz!x6NM#I}lwfC;Gq^dPCN zx>C!)q*Q{cr6OxRsWC7iHGrz6nkKI^OqYIE6PMS-xgJ1%SN?rRe_KOnPIBqL?=GPi zA-PPGn&$i1Okr$=PnFFS#;#BK?2hRFjRm(Um^lY;ro@>$sm$rklsNN5Ds$Cl%A9)Z zJq`OeHMXihR;vg4ueLPxSn}#wO}&`BdRbHHp?=Q&4mNn|(->-cTs1AuSE$LPaxGq~ z!wa*d|L^~9;9iU7Cm*JldB_s(QRySRkEu~MB7)~xK26ezKo5_5_`CZhuw!ii;Z*%&V}tSYYN2vH2H&?70{ zm76JN)IXt8&tBIg*22VwkZh(f=S79v1^g1N;>$HmuIkgd-x=@4xsh1*U!!qOCH6_K z150o-jq@dLiJmz#)a;2WyHc=}NT^C5lP`Qsm#tP23Af8;%1u@GZqe=Kyh*pGbHB5s z7w1M|?9baN$#q}}Zl-ak#4YJ|YPPD{?J+DR(#$FsPH+YdCh&X-i8fcUnKB&OdF-YR zXiZ;?*i7LJbyYEukuPZ?b`(f*K3B1sQkH|w6iQj?8FomL@dGzg%52^0fSjpUdd)Cm znEMu;kX#|-JQJ^bO()9rEe559;#uqxv#QM$8p3b@&y3d@0+-xOp}`Cj`yW}(s^G(< zSMpJR-Fqe4nK5RsTFYrIG)r!#)WaDwsr-l^;E|fRtR^lWp z9>bZ`D!@taiQ!DzTY!_Ei{VU~FThD3kKs%@QGk;^6~meIZUIjEYz$}8xdNQ@#Td?{ zO9eRTD>0l&R|{~`*JC)7ZWQ38Z^m#Y-73IIe-y)+bhiK}eLsdX$!IIE&xREHCjs! zhbl#K^KUy49upzCTa(1C1>Ts6gw<#s6d z18?&z$s)(}T}&LUj9fNBjvsoC2S^q<#@&XXj>jI3T=R;CTbhX&P?;!cn4~b)W z4Rb+FxT0Zo-!lvvckPDYt(M9?fl9YFy>q%GS@H3JJxO{uHz(gpxVjs=rdxJ3-h-^_ zvm~orlMjV%4u!_YT-9jSj4DmCq0l&|J_K)*Qv-&HN8_-`r7RhyKydd-g`Lq5@1i@a zWT>()m&-*eNSt$joO6Gilb~}drrM9gpmQ?}nwp*a9Y_7KhM2mLyrfBP1YzvG03`Wg zACR1jVJxLhDaFj~sEceE%6(sjR6A@KbUqYsnsZC__^aRtl6U+3z}US2B)Rh2j+^r= zIhVs&QadH7-J_)YUQ(N6QBv$(N{l6SQj$7e(o!`5_i#uSB@G&mjfo{qq$EvvNx$kP zO^_@~8Z=C&Bu%CyO(rBwrXhy5p?EjUyQ;ytTAB=l&WGaN=gUbKTdg5R7m~*` z$yG+ijt3ygi+w=GE(IXTTYbPjHPR8qukozfB`lM-+vP0UGnRUk|pIwHiYLdAuLYobNFb^3KG0nUkQTMT-^_ z#xSAm;>UTBVJ%Qn;F3DLVo;Ko8KG?q6MAJiFEUJk@;aPM;{z=Oh6zp$!;3e4!FI}p z6NA$B8S=R0c_q#gmO*J=8F?^FD358K;pICj53d#{$fROcwnD22BO!0}a`)z9 zUSycM*Bzr07L1OO1;Z4p7?of(meA_$a!KOR1PWr9V3jp_k)ibK<-Zt}V1?&{wBuz5 zoSBW$qBKU~NM8I2@EF!GQBQ&ofa34I7X30mWc+w&`5&w;$iP~1Y`Qe`&^cB5Zx z^cbfYywIE37&d(70E$NE0IF0)8uTYnCG(jpR0*I;RZNqY87502s|U;L!Em%j3t+V` z*ENZHTt+3nkAQPGB~}R#j@vvK)T{#XO``Np6|R*wz3fd8`k}*ogpiQsZCh z^E1^)7N?{s&n-li7bOaiH02~e=_8A{3(EbTx4KQ{C3#`37daxD|6r~6U=Y@N4+dearyzz2H((j3pqm<|_BkR@+CD=bw>+=Z zT2C($l;)N3GQ))OcEP6H?rMm(J5D+@$!K7~E}&*0D5(b4GbNbx4duTWl~5LIzlc>l z8H-T~R#^MhU=^bhtgu3iSj7fng;+u*Sm6bFQ9qhm)|FAYc{R1HE5lODIlh*Js_amp8w6T`$>x>*M_GDZ#z6P!ltfX3>GTl5&k zFieQUf=KqUjQ^WLZny5-cWj0OVN@d3> zEaMcDXnYNyIe-$&W=g13MY>f2DS8N1GM~9Zl>n+##WZ=DVY0xoda%46%rtjv0nBTd z6pB-VbzoUW*q$nGI2WjwD`6(%Wrj)J@MaL@c38u7)gCATDII{{RwifQsP!(>Th^-PLkZ+f|0RnURImr|LT)EB#Yt`E7febW?`5p zK9kWFhIs!!{u|x8eDn+P=GSm&b4L}puOaT?p8MZjsl>b^bZQ(lWVK9P50>+TKVwox zCs<~lWwRDbRw_DwgXV&BNp^kGG|72Qay5mq%K=ET`H~axpejZ26o4v4lH6UDV(g-q z)h78TKB+^pC_YuC)@v4q$tp!#7*}&v%yweAyusEc63P6=2 zN$##nG4`&P)h78*eNu;HQGBXOE!QjzlU0hgFs!U38Bq)?(dLpWa7{y0sY`>aR2iKp ze`Cn%W?(u0*uW}PMkiR}(>2QKdM%c&beCzr`3ndhi{74eJl+rMPyg}2+3H2tJpQGv2bp41qcS_KL}&9pWJgd;QZV3^>AuTrUH z^hainER9$pp^PiI@Px7$utUpb?WJOzry8FE;yoH8>XeC??+Dp@tj zf?-1Q%<$qmFYncHFGh(Nm6S&o3{&!&yvQ)s$tFP29i*lq2X+Xl^J6h8q15OYSusqp zictwxW06(~`|!FubvFCF0XGL?*wMs2ga%s+!-QVAYoQ`HYKUWItD+IPT=0AUg-bcD zA&en;{(p3r@N_N7i<;zyB*ymqPaa6Jt4R*X*yR8ud9@G7*vbFdb9BU@U#fq}tKTNM z{4#k=lcXM^RlCR7aj(@h$z>|v0U2BFwQ7?LicSwwk?B^!|XHyc}$f9+al7aY*Y~I_O?V zzV99K5=j;qUOYhZg8B%XlV{#ygl@pO#xrj*vR5s$NJeP3MKbc9_rXDuSBjY#q2)F+ zBdirx3?skktH=b&;4YmI#?C3G#EzPzqi8iGo=mymWXc66-%7aP;yClbboyW^47&#qqB+Ti39Fmr*&da>+ zUeRMAiR49}G((alnwcLM(yY@>^WzI|jWR}Ko90JIrRE{rpt?_a8=~2sF;A%KzaC5o z92_Of8WzbCukdVBy9qitQGHzg8_N2_AcEw_KB-N12YWSk*8^K5SFl}KAY-e2 zIkiY`>;p2kJpf7W?E@A~7(~;w+g`mkN!o*rB$6~nOly17?uWc2Kj(GpkfePsFJr4b zuuYQoIUr+O1CZq2g0+d=?#N`?ddutEAxQ%LGwc~C5IOHWsQ$*iRkFgD2-wsKd z;((0p2|$v23x>tdiAHuIfu_Ch)tewmdoZGtESfgqOnIuVLMB@o>+DZ?cAo&fS zG)a>7xx9>R_P_~}MQh{th`8-tm?%B3{(VZ;E>qq9Mp;W+SyRy(NwPQ}rqUK|{Y6w- zUyOxk1=*Q0Fo?L+PLrW*7{0ITRCn# zq9LSc7`|tw6?nC8WRH3X$zTvop=^1F9VOE(lE&6r5o&L>-uGH9l3({pZIT-_Ny?_x zV{D@bwn)zR0U0|UfF$4T12T3t07+iz16CLmE@_T+o>`kD?LkW>xuL+n?M>Sr@{*kP zNga~3&sAB*j(K34B<*uR#?AyF$xE8#fWf4Jl;YQTRvnTw5M30>qOBco>*kP`%3{7R^L;!w(aZju^^WutEuZ!7&{YyB#V`{&bUfj*LzlvWC$r5*7AlO z4?;-N6fq3v7Zq?e07(`NYei$DjH@(-vSo8-UKufW^@h!f_gvR?T0=}SNM6+>rzc}K z1CZns|GndZ-6E2EG|A;H_Kq=470!CjZITq~>HuT61CZqByb3LnEuS<)a?)${gFk+& z$5>Isp&CwJY3x!uCk;T!qq}vrd|kF3wgbzHHddFI?!be(RGnr z_g}k9s8J;6G|6>cjLioi$#?sJjIH}`0!Jn1G*pfnJNw5TNb-+-Qj6q8O>%h|yXt|{ zBtPy0GPcH7_i2)B9gd^ZVc6eW>dD)|qa;7_Ni)mUL94v)S|lfZ(hSL$eNuTFbpZuP!ykv#5`x+G8dq!tV5 zy^zG>$bE6NmMgh3B#~qZCEhNR;SEcdRLA!<{48c>?$pUsE8l)68~wr^yU@wT@~Ui;5!(n}mr4H2C$*>$J%clJB)57e zwMYhS^yr?mqWs&)%PEXsQT=WNJ#Q=dQApaLRcN!XO05r6;&MC>Z03&Z|(qDO0iH4G77{ki0^pr$Vxz89g161%nCjnK8ot{3Mf80Km)&$oy_F-RYDEuPz?mu&}^BSW2BDwvayGy8gBzJ4lz*#qPkmH|tj%||n zebNlcBF6zYN*Z@Hn^Ec3=}M1lID)4HG2$`0EF{Z7ShToE?^W0_4PiaW)_+9nXGreW zBxgNiX9BRux=2&ZaWAG#@&`VtMUvw1kvfu;;ie`<)`6xFvcb6ylH0wCU6MtP@oghx zK2p8zX*i&wd-3N~#5FIfMRMV+Lt(p}j>Z*gd`m9f-vqh{YbD*dRmSj1dHs zsrOVCdmt=aNwNn*og+z^f32O-dToBwz8MZ$;cBt1@x|ArAMf~9*ClyRlkoJ+<=<1f zj_MD@ys?y0F9>Q>P`haCyThj(GGFF*90Pp&2S$gD`plg-x>B zAq}6ExYT%TMQAl#&Ou7A&QIStWWBaJf=x*9>UnI03><0 z59nilKHF_7xlTjJF<6tPsO@equ}yN$Cry*2ey&4c?2HGtNm6T+G|4+2b%3O|!tP)* zMgtPHq+mm%SX?XLbyqfO2%nSO_>bKsa3eXXNzOxzoen^f*ZY8s-3>sJ<3Dji97o1Z zYAQsNe76tC*qwjkbtJjsKP+-&jHNZuHASa52Kb`8I^{%g4$132sY~($pVXRHLyvib zTO^PBq%Pg^VMto9R_^f*=+e}yA&KONKB=|$v{U++hUlJdsBb>-K5CJqS1<`*r|#OI zVWN+uJ6w2DB|M>QGqbjLPU$O!wEN2N%s+McGV`_Gd8IED(%w`0iceeH`%r14HD6?q zUgFcfrhQAlevDDS_1^rs_eyHouTN6vs{waMRi_E~Qp2s1MmB3xRiR4BuUSgPVyVz~ zSRS5Gadchsv*xl-Ab)2PKEI$0Xq5P9X@xIoLD82qz@}MAsh_fR>=>1WBdIJKNi0T+ zmaQgr86`_n!Z7G}d{NWx5*O(*Hu zC1ae^dxqU`HYCGtm~%L1*|VGtlS3xVgxRojNVLy;-|zQU)pPIL(5?1K{uqwL=Y601 z{Ca=hw{8{HcbjfHOF7!=Bt;bNqTX;9^@h7B>HwVAY2onK!r`wmd>XT)z`HhrB703l zdX0*ROZ0Zuka=%sMd7?dhiY@CD761z74m21%b4NjY{W8Guq;2_8l%SMlpzHpV|g}6 zE5-IKWkqZcw;Tz;_HYV_NVg~I*mkCH4~diV^%QwSBbBocH6b<`p>#%;`kBH4kBzPh zwxg?D;oPZYt6-X>h`6G-8AWU;=BW6PN6*=f@hUxM_rM?mdm+MIPCE;DXh`8EC~pL| z%&{^Y+!-&kn90@SL822kLf@E`*Mqy`WfpmR_4RVH2#U;x(d5M%W6+0)0`;6i*fJKj zjO7^Q6noJoHd~%9u*gL0D;j#tplMMv%WnKJxaHI8nzb58@6t8wit?b{ zmsor{5Vf&*5QutNWQ@B_I0o?o^UEyKv;4^AG>vntFp#`N z;t(*7h;$g=^rSdb!SMI6$S7hT3$@1=>PQjyj{=Xq(}M^P%V+Z+`pC@LP}B2M9D(}R zgT!Ji?gpX+n_mm6a+DP@^{QZSV=QK8O61#k(}>RQkw!C%>>z|@N`B*X z?Eoi;#y9L0*;rYu8>T41VhkcP!DDl*jb{~EoXJyU?RHj?#iKk$){3#+%M&9O>mahB zS?kRzvN)Qj$l7#Pk;U72imYv96+HvtpdT->$j&nlw$R#KkI|n}pug6@ z-(?najZeSZ(qUWRu#H7#B^wlr99p}Ru{Ifu-!&Fza>lQ1joKSWy?w0^ z#k!o{ZkuB*omFI!Lu);<#@>n8ZO;@IdIj%#S1^DL=!z-Oyfw=5ZOG(J#@e~+A#1Y- znl~p3=2&B&J>(S^oGb8xPGB32Tb9`z-z`(-)U$3`V?*dRNE-$F9!nuossm;Hve*WZ z{7Jxk0RulB^ke84D1P%E!`nFAlX|n;6^lnBRz(ggESBH2BD+di+a3!PS=|3=E0W!O z)nldo%emI9HH-(=EKWgW!?0HTGl3$DB@kIf)>eK#P_%`--#MMY#*YMzzr-S2ET5QX zkJ8)u@bb3tg(Zofz~4YoBcQu^kX}V#h5YjRF=iu zeryl=F&oD56xQDx?18SJ;H*iaeAK2=174U1fG|8?zU7ez8V(0Qet9$vuaxD;%XF&1|qk~`BKuMtaf5A=mc zsE{%{Sggb(^7S~Q8Za4rA!kNCW`i$WL4`|0JhI4U`FeTH2~`%6c}@$~qFS)#6(h|O zP~x$e(}FcGq6KSSL<`ouh;-LN35Ero=*nqO9xAZ-Zy}P$OXbYtPlGl3m2z%dgTeOI z&i&~v+$xMIv%MCq$gh-dpzH-J@+;-MDR5kjEq4%(fsyGpobe8kK-rkRCR&ABi}fPt z)PeHEpG77wcfyJpB*;XKjL9-lUq-)*i|D7-V0evrsph_Vfes0=+)4m#eEFyUq} zKFism<1jJ2j3!&aSR!Hr7)wMd{h%6-(H4%;7LL&tj?or44HY=!mV%bVSY+eQdS9=Z z3x|&B(7s+cc<8KsR+3=j7PDa)VJR55kfph`(}G#b@?|kE;ZRHcbAjirAtLE#y{{I9 zFRa5n;HvP2dRh3wP^>_(hiC^uJ3qrsrZHI0@}~?ae=}(NXSi|3g9-W>Cejit-I}=| zQbZvf{PO97UuN)F5d1QW*?ihhlaCCx`~e5o_hPU))y%O>%0RNX0X6v-zrx>xB5OYRS+9J-%H+Lm7TFN_Ea!$dr<);)x&}Ec4Rdk5qoqdyo8!F<x-Ga6zmo3!_!&mhMIbn%2fJPrxbBCGF?PV zW-gZDp^Z53uy3+wvthfL4XKl!Nl znY)cD9aLcs@YXE%`iVc3HO(6mw;;;7zfNO2q+IWblrzrh$ZUQOS*b=)ypPKz-Zx~{ zext<9-EVki^70CsQ{=r>X0Nb8T|aA6$zI`k;LA7jwe(0H$`-@HzMya|uVvc4&4$Ca>eUg>~__Dwm@hFRZwgz<{R zwAb7co@CwqsU|{Yhh3dxP_a+`lGK$;N4C9NzwAm9xlsP~dfO zBsqR(&E1fp$dJHmz`Se(&w9gOnv0>*11INVbgaVH_C&9VTa-7)3-nNW{?DbA$YwfoRqW zXf`~S|0rm3j72VRIhlonq}Tv5_h}6S(StbzvRwK_Yhi-3oNaV>xY6D0+BS4;f!D3` zF#(uJK2um+W1vh47AFGHB^G}fqBGvt%JTh~+6=C8JjGX736g>?w6hm{zjs5P;D7in z`KW{7BeIRYRrE=-kEWndhnJWS%RcH~pr8>K-fcG6#R6j!gNPj$*s%LLFg1eTEUrzA67!{_8r)w&5pypmXw{cV2+iN;Dvcx1&Y;yD8^z9 zMA^-glE$nui=Bb!GK(A*lMW}*XwK%z`!JVv)J7@I^&6|3DEl27!!RP!QADJJL~NAY z!|0IDD$M*~`I|xWVl47dA{%8mNNA(P_XOoN<}ZUM#odfer)Fzoc?YpgJ}hS&-5qXp zx6a4CQJM)={dGH^>Okk7RS$(iz0FWif(to&Rs}>%IGFuRdqg|4$>jX@_pBPku7bMk zMl8~`tQI;Q&1&U1@{4BAVvA`RY)#rexS+kT-ifp(K-se(>KJ&PC0bH>2mvnb%`1*67xXITl`Y}>+nmet06v^2N@$5<>6 zM3-3nA&8>y$h?IE4CSWH;bfNnO9xh}@Pb6PhiVl0f<;6uW*c^z*Ct}fG}nW}XgiA>3DL^UGPlf( zv#*jqtLIFC_t|joe3oIeF+Q8?H^0m%>dv=L69vrcvaFu_FE~(7H~C zLfr5eg2rd$TeMg{gk$-R&JF89{m#JQE+}Ub7U@GiZ0D&T)8aE8Z8JebUSl!awpZCU zrV??EIwS7rjIEJ-GK;j7V_uC)MBd?=$4Gw*e3yKv?V*npX+=53Lm>l3v@5GL45c&P z&y=`bQ7hsuBLB7>T%4GgR+N|(;h0)0GUgjtP8ZsxFc%I?^|yjy zj)j%Bad9tD3QZc%qtgEkrRdJpS`iIBBMES|jg8rC9+8jD**3^aND4W1-fKQr#5T%x z-GBn`_{&!I{&7qBKuN?L(w~Km_>-XmuMsZz=5xfSqP+;Eq)tjcGk~Q22$XLU4J$=y zMa)_4E23NFdtQ+G-FqRd_4SHyURoUEe(RTu{aZm`dG|Ov@J+=1ZQ?s8`W{ug&?VZJJqM^4B z&vKNJ@h1B62=tFOD0c-Z^z@=QkrlBxABYlc$yOlhVUgL&Tw<{_m~lNiag#-Um&$_y z2wLGhn_VB{vZJIcSY)vLKFfygbA^$&=0bt4F%YMYY{D$=Lt8%GnVw^X(dDF+4rW$1 z__c8GLUamyB;wFk;4zJjpr50fQ80$fQ-NBrSeMlFum}}e?N}IjOFRE()6)TZB$Kp6dw%x3KJ*&v#WS$~Dhsjup zz{MpN-wZ^TS!6&H{?Z(4j47`+St+ ziY(@~A-o)!I~i_6dsG|RgElM$5!+eJZ9{v|hW|6G$Re{gZD^lk?d_~0i@9xRkKFg? zzinHv2+HDSaTOvHC48?lW;Fh-!1xl2xyBJw`^+*-NQuj?%p=r_g9tGeXCQK?7v-oX zaCC{qSdODhbF6h_6h^CB$nnDk{F}{b0=8T4#Ll1e$OQpaUe5d@f2iVAaZ?VqT z);CrycR`t}EFK1;9u|)wI%!_kKrbG+h_N^ph*-T^Ki-c9KU7mx3z z9VR`I_j9JOc-0EX$iz#aR0>8amEmIf-IP490+%^<;)}%-hOuxQttBJgt0{b#7s)g7 zJWv0GwIW*d9*-`jf?f_kt~kq!WW@WZUW8KUp7E}S>4A)B-ox+VMN*nqqMH}iifG=W zkI@Ag5%00@=0!5XQ|bG7k&N*4z7OysDVdk+%)?p{@xJ#%bU{YM`%nchk`k{%#|vvk z#QW%zbU{YMd-4Z)k(7AVI$l^SB3|`5x*#LsovYGfTGS~ELbW%EOtO-H)qy*vx+RH^AuSd%_`>RkS#NtogkY_ES?Q)V=U60$>!2r z)=O@Q9=8IImszY2JYHon*JJc6h9!4@Z3iJD?|Fp?R~Cegu>;vZ5o1;0)j^**M!vs5 z51GLE)!bePm#ZL>kSyMY$PO-Rt64>qoZ#jqQ=G*XD9a(JaE_H$2#aJpzu}#)ET0Pp z3-8W3VGB`~{h7s8h)nWPBPRz3|D!*m2GX)7>#QEdOjg7qDgDLb2(-*c+J0O<5B%gD zCHSiVIcUaMT+X^=krXW!Z-rb^!X6T37FV+_Q3@a@T-8c$Ut-TYXwZTQ&*kHF0bX*Tm(J!Q}(PCkQJy`f=b=1g1iRo zRO~`M0c!hJ$jKP$?GF7kKe!SUACctU17;&}! z46e_E3*aKC^(kNCb^0Zh!Ql&5a0C{%*m@CI3YLM&+-roq35C%~$U zR--|&5%tsB(~s7t{Ive5Uyb-RU>#Tw(w~lZT07d4uJ+!mKb;T#Yr5jiU|d!dS5epg zsZY*BZ{Y-et#_~S9<)94T}0lu9r?TTPMiNp_PT$yU)EjYv4y-36^~Fq1}iX+NzQv6 zpZ>O$J^d8IPZ6l?X?IdS+7I(0UHQ>J$vnuv>wI?5ZwIRXbbFa^G5WFmg#OfiUH$9w z%YG%R?lay={&oNBJXz=bWImd%{Af>VI~~6X?d(-dIoeNsvK4x<6ZEy-y~cac_RO~( zc_$qCyYx<*|4H_GJhWfdUE?u^yvcdg7aZ+L|AdX00Y|}cQ0KD@`7Ll2Tyy9jKu#W_ zenkBjZG=Lw2rLG5{5r_%!4+`Bq0j59xW0CRehaRXt*FO9olh6!2`~+gIP|9=p9W{a z1&4kM9&x6@5pbK2K2<{PkSD+~aNMC^{*rZ20ak-GU_ICXs&HNx$h?J z4!G{npM-o0oCOyg`gJec4C}!L#U|9dz!f|@UkyD&w|;t|Hx5pKli(p({)+AyTj%v- z=oLb*2rLFm9QLlbjL*0g4*O}uodFlYWl(3m3i%yy4cq}c(NA4q23!D_!CT;I{WFfs zKjUbBqlhyOPJuIy_)X}i7}yRbz+P}0)bVKFitAkIdKv zcnoTPm1uVr*opV>y1)$noM9yNXARa9?Z`CjNF9&s<__YmgPWk%FM>a^81+(6>+e8* z46fksMs`81&+DtWz7B3W^s6B!Yf!H{L0{{&Lcan1+Ue+DUT?(p7BJ?}?}Fb1m;pz? zF>oBz{SovN{Fj2vL+kT;8T2Z_YEbJ>Lp}p8fJ+YjRme9K4^Gg(gX`}~ z1Y5xv*a3Ee+MfM2it7{LltcfR@=sV##b7C@{ntQV2iAiPU=!F5u7IoH-xq%|M?TEE z1J~1vI{z+QPl2O~T7MnaH^5DB3)}?{!TMLNhX(NPi@yWpr}OcUXE9g?mOJua?y(-o z71TGuZEy$F@$THCeiQO&1v|hlFa@T;5pWco24}!oa2{L$mqDE`YkXD^cNM$?ZaeaM zQ2LCc`^V+qrN53m$&C~8FGGKngH>QPsPo}G9L4oXaLS>-2KhR;32r&`_aQ$3kHBMx zehv1Sdc_#(WV>TOa@o_LZvVaNH>x~N%7^-7ld{+Ouw9+dBQvOzBdDL&o_^k`enRDO zQa;otdzHP;=Qggdg6rTWxC8Ej```gs^l9s{7%Txx!7{KCbj4>LI-d6LvUlaL^S$5v zT>ja4=#XZoz{ZX_Uq6q z`i#9&4pxH8;66AGe^a2#AN_8?|CZu5>Mnbioz{2xeNgQ=M4sdp`hnE>P>=E1e=Evv z7xg`m{j2@`UE8xAq@EwT9Xfy7k+iQsyR|;$2d!52cN63-U@O@5fbL zopBxd%xe_anb$b-ngpl7X>bPQJYqX^KHA@D^+(~KWIiX^vmIk-&p3GCXg}rT5%h`? zU$nHi^fWJ;K1>OQ%;J+IFW8erl z3oe1T!3UksDDq+acEr)GzTftaz`yo40r|9px6nT;ptjd`^YF9ih&KcItkR?Y6672o z9WQ}AnAe&bKRsTnCyW>UrQjzGj)G(0B>4Bu|4I4k{-b^d?U_*R)B30F7xoW14ZrWy z-@V#vedeR-%Fm_8`L>RBalg>}QaQce2v~_KN z1p8yK2=>KbIhX)TyFLHs2rNgOMlbYrFzJl z92`TxOn};6+r{9g1JwF0khdy5>UToU@zM4*$b)%Jqt5Zu<27-@c+p=y{4{_qU@O=G z{(bX*Qog$XsNab8w5#@M{nPdf`-kj;-*@WoUhTC$^U-wW=hEYRn?bvd9PLX$ey{o? zu-gLn9R3+!>m51t7a?C!eqH)CSTEfFxZiOd>HeMQvXV(~3Y-RK!Fg~ITm#p^4R9Yk z20it2zwwqF{#GG(<)gxTET}%N zF%R^8Py0W3#!7fUoQK^4xD2j?8{ihW1MYzb;1S60v*Gu*@NLGo0H?tj zhyEhuOW+E)3f=*C!9DN@Y)IK2X#sWr&_79k>#%p}yYitO`JnALkr%mz`nDrqm)?#; zpK_A@xextAko~LMM>~!O^+>Jn@_Um0fy%?BPd%NtOTQTNge*b5)G>ctdR5*F zrC*Lb$qLk6`FG%Y8XN(~Ks~oBb*LYh0HsbGr```h12p)lq-|2`?f8-t5t%I)kTJJ&WZz3+ah5EK5AD7;aL!a_p zT-W`j+eh;C(i-8ub>i6^w!HU>B(KJ-|799C7K_rC&H;Jrsi_U@15a z&Vuvc0=THC^U>FrpuY@i{k=geIdD+xm!_?REJM8d2kWb`c2oZqy=mR*T7@2@P^f^eABW9)c%T~mj>6t4X_w?^rP(? zaJ>~&E4Yag+a4zLsK0?TjO>lF@ae=D$C1=qn1Q0tGv?;be+IjgY>Cca|p zGvEg3{fw2Dfc4<=&s+HlXlvQu&Vb7*{vzTt-WK9AUK!$LJ=>DY|04Wrea5|o z>nq?YxQ)2GU^(JefK_0%BcC<+A@||u5Uhh8`%mYWf?gUNQ5-{k9MtxEh<^Z9qF-mh z2H16h%wxgPo^i-0z-e&Cq0f1=j(F9dw;9%e{I_lk5x)jxUb;Oy<5sc@9)O3S*57o* zO?}B~&V#o>oyRKLRrgh^-vM%->v%hkca{UZ1)cCf+`ZwvAr@Bln?=(mod z-C(DKX~=c^D!yPP>~Hqx!Gx9bpQYbLzwUw4llFS$&snO**Gj<#knLxFt;jD1c7R#Wwp0lFBCr^w z{}k%ISTFC?|1SLPf&1VgSc*7hU^&(~5_KJ) z^S$e5?UmxMS+d_aZ$>d5;~?k%7Un>ucb;Lw{_{de{ID!0Mm2@*1!OjDcNX z0_+7-;50Z3?t|8A_IJro*>WjZ0ak(yidjor>caJ2Fa>5ntxx#~u8)Hg4*dnlm%wFk z)uCUBc2fiP+TMs;^p7c6M$4kLJ4UT}L;EbZS zU%~Y|;2O9AYJJK#aeW8eb?AFIHy48?U>T_WH$vV7#=v%meg^U}a2#ZRYX7%!{$B;} zfP5XO^$#(AM_?h^S>$MM9pq#K>WvQlvR|+f%R&B&@x7?)f2aL``cpbnTW^G%Y(jkm zZ2v{8mj<;L+L5&Hy~lVlhyESN*T5}s8{7vEK<^vKkW>jzKt2i1g7e_AqB8eJrmZCN zOO|8c23YZrth{(eTiQD9$Ki+e;9X7T-*2Fqdv#E4C6;usqy7Fr{SOD$Z=bMT#p;aiR5^ZI)BEkM||2H!2coWIo3xb z?3%z1uoKkrxZd`#?({s<`t{Ij02{$3Frm1Kd`azZ7yHE?cno^jFRK-`eFoP@z)^4< z)cWg?Z-Cq2u0y~5E$g8JOn@m+`@aME8n_8=gL~issO>i}PFvtMxC8Ejd!V+jz`Upg ztH5fo9&7+t6t%zBU$GK0hI%{L33h?KU<%a!65q6vUN8-gfLgz7)=J933a|>?p10Tc zKwHcHPD3vPj)CJ~R@0W&A>ROx6t%whPpqU0tOjeqojH4bA3Ow)K<%#=b}4XFQR{Ev z`Ziep-&ze)>$l)K8AH7t)cU=Ur@(1Nt$z#GZ-eFk6#0N!e*=1(;0`#6{#kCQr z`ukuB?8q|I>m2<}c|EQ-fh`XG1;`h{C2$$M1>OdAds}|hN?O5ouoKk!dywyg2jCG{ z`5V@v4%GII3s%wswt_LR1MCE~{XFDL;4N?u+y_hlduv$%-T}40Rp@Vn9nd2?QSSm1 zU@w>gCqbA0O^1J%zl_5l^CGF|ioc7vx_=HKr`?nzUKQlkV7sDjZ~3oT$?T%#Jh%YX z{JNFbfho+B^lxfUwoZRt@S6ZrVCDhGYlOdcFpa#~9-ZX@^bWxz@E9!rXV#(u4B10| z2v#B!lyU~DSO!*tRiMsicG*gnz}w*Jztozx zzJTkC;2O9AHo&gYVNbnH=#M~;)KNQey%$V@X=UfKXFE#%2kSWnE`vJW8vL$Q?v~Z80z1G?Fb!tF5m5V2!QTit z1x|xne-rX8@K90fPa*C!I1es5^6`GhdME@-!3I$KpM-o0oCW8>1#l76_TKM80v3Ul zU=^4E)8I0w{WU<|2)2STupR6GwLSfkx1qNQZh@u0XDuthE>Qd1hyDS040_Nn1dAN@ zvye~zE9-d)Z2BKqVg+79wi|2 zWqzfO{Jh&XVj)-rmV&e30=NWjfp-vZ9XtS!z_S0z`X|d#uLPSETTqXIX~hicqu{LK zJnDznJR5bMOXUZ{Tze<$g0LT^Xu(@y8Z^;?GZQw~;uTA%w-FRrJ-3^)Rg zg4&+#OrYHvaNMz9G(g^>^l7L4^K=B=SUHa3|n+2B? zmr=h3u7IoHI=BIDf!m8}E3U+{BGG)8Htm^BIR+bMln> z)SGhXQ?5CEN`30hoKpW5^lqP0e-?W4r_^77-r_0s=~vq=ozi|8dTiGU>Z_-;XTPzX zdi?dc(C?j7`e!?sC+*f8_8b?sgL<0l4*PA$cfegm-M*q#D=BtR>rX(BoJM^H)cTaq z(VcQgGR6gYz6NTXT1V% ztsrc4);r@JM9R;4^Jk;<3%vv8mUH>6_b%`Fi5vlnXT68KvX4Z`ANEEnqvS>2a#fW4 z-QG-Xl>9y3a-{qbk6($9YjxHu_Ll!3S7OU&y+^&(Ncnrcqk|~@$Gok-ijtRj)kWbB zJ?nj!S9E+PWN_B|Zm&L4{o}X48o^NGh=Z^bsZ$Zsx`nj#<=j2`eJmT>yNsy+;cJZr8w47g2 zqUHRm5-sOfmQZd-B)pComtUDe{SQmQ^e5%@m`2p+SD;Y83HmiZY9*6cX4L0bq)?yv zZ2bu(mel80sPHP~df)hhD40Ac?}UN%|6N{*TBlZC;(b-^1I*_@v2W*(<6~aQ-=JfF zl-yRL#)bXAquR^<=Sx0%dsPCN{-?YWx2vx~erwQb)+3>R4*5aa$_vr1e+T(t#>yMu zr$lJ{^G{AE-*2z~Amo)(wtn!iCG$V{OIzn}=HI2}&u8I>@&*`i{!~Pc0xM?c(F{@D*>svlPT_Lg~+pM!t)&$46Q&OF2(vj+d^gnrmj?J~zIGk++r zRPCyXY*(50FIE1wU5|N1YX5&+mf_vTr9z!IzEAZ1{YuFzAde}zjT=5UUV#3T(!VHj zvp?{>$KJDk!spUY`1)b_DE#jz|JG0V+&kg>3Cr1U`+tRw&+Gqep1k_c#LwOOlP|TX zPybsFv!(XR@0{Rg><{R{l70@9AJ_O&ze>%AZ~Oi5n5X3?N>sc4$k%_|<9(zIY3+&J z-}hFnUfjj{}e5tGRn>O^k#ZJx*2 zt}*DhBf(ACcg)W(L(chDW5wRGFAu+t_+8(BnHNJo9GCwc@)jlk&+zYk+dAev`KXMW z8Q;nmtsI|l@LC|R`E4ub>zz)>m(gC{2Y(6jdHAoeX5PPnoUbF;Z|{?WKd*kmDsq0- zQhvqC*{(6j`8tJu{v2|?wOA?f%+I^tZT<5tO3sH5iQJ6uBKGq#tM2td&U0M}+}U*UtUG3d9vo~zuzl@e}wfmq0iS@Z0`@h$F{5F zWvjU-^V0nMuE@=P&ifJb{A1{sV!$hK;Q;bw^fO{`tCq z^Ycs4AG>Aswk^CF$n`w=W60CLY85M_o#y91K)$i+SG{Tr?|sEKpRRvw1w0@A0OUJA zVdY%cpMiX=#mW!h=hq-lU$lZM^h2p^fTq2xKX2s;$S*_gVc*z+pAnH4$a4ezyyfSi zKZX5m4f=N6!q2JxiRgc~#O3Q6&hvle%VC^@zi`OkhM!xXvdVlNJ@#Jfzw31?uY|8( z6#0iuT+G8`jBmkXMnC-XL5IBBmp|fZ|3Bu??|}Z;w`>fyH|@|L7x{<7>3IL0L;sdT ze^ca7nDaAUr_{k`u`KYY_WpoF{)|KZ6ApQ&FPDCP%?3;(?t(-A_Z{*-bIAYNA%FLG zMYro8`tnD-jTdbq4Y==giae^HN1?Ctza#P|WdG#z2kxK84nOacPLAwnhrG#`KjIz! zxXqLM(rb{9VV-jw|J>o{dmfLD`%#CyQRLEu(9atV{jWIW|H2{v17H4#H;(mKfkc5c0~;TEQaL(eu7M z)GV*hA^);N{*N5;-*U+R7hfKpSAXWvFOVZ_RR4d#A;0dBfA)jXex@Ayzv0Ut@%R;; zg}Bc?BpZm?PsVT_lWooac}C=>|2JQ-bsS&3A;|e0V;}lI=gU#a!94Ug;#PPE^f=Y6@%XPv*u&3%o} zlm8*|`CEsd4>-o_f-jf-_L_CTe&}@Qzu}Niz>gl6Uv=o;cF6z8A>V<2eO@|t=zrjQ zqx=7d9P%b#F6;f!AMwABy(h28?Af+Hf0sje$ImqkH`B4`v&?lUOYlMlT0Q1t*&HQ@5gC3viRU|W+>U+U!NMh z);u&cIMf__vFCHmPfIl}SH!nlzbSd;`n6N)8;2JMt`3IOThE^#OeY88eOKa%Od}XhHFwuAQW_)=_)$Bu6s6 zuf=N5n>sIhHn+ieI++~m8#Eqs9A2=g%kalj;?Ede9UAP9rw4~J@jmGWm9HAI{?x#T z@6jJz$*ks5t3c3?zrWcswx}zm^)j(w&MYGJ`|I@$T!gdItN` zsbnUZFbg6|BYsuF#k+@wx^Kpl1DT%?FD0>D)&A>4@?UTF zaIa~2Dj_o_UKg*EHpJr}zx?b=&GF`!o8obqMC})&)`47jxmI`8Q^Ofqz^4D&lEcH& zsm(WxgIC)!wI7SOrDc*_msygCr!zwrV^LmPUw$SYzcz3^-ZL^%dp_POQ(5Lhs;}o} z^ZDjxN=k2bVFP4dQy+2|Nn;AJgC{ukPkxF_^pFB5|yn0TCZe&EF4h;_u zbf@|iC3lP z63v;scF0V_j&3G)&Gmsk*@OL6^o+farn?8^LR}(xwflN1BdME><6>J)yqO&wUaWQ5 zeJv*2ZT`+?GJHTI(p2NGA=f?sK}I@nBR!zRYwO}K#if(bokPu+Uu?@fWA1tWt;vp% zIhe@4=5N)q;n`cJy(Gs4-p;ZMvHju$%1-)CcILZnhV}95!^v0Ln_Fdmn*HC4H+|~m zXJ5MbJi6SyCjEYlx4-m!a1(e?lcBao`ZST06Vu?$h-p!u7&Lc}i?1|Gz^CK>ZJ@UH z{FUzEz8-VT>KnLru}3O);loHzfAp&_(y0kWIwDVfx$t)jrwQ`vzp+$Ta7kNo7wO7#!-C zgSwothU9=R2U)RdJ1=+Iez`x?#67dI_|rX}PBdP8?$zeY&$Y#C&(-=bhX;F9XXWH- z&YJ%6xMHS>x#2gO`S|=xVr^d&tCi-ru6sBw+hXQwuHST~*T4Dnn>`^eEARE(tFn)# zk^{MtxSS=d#p}tN@gA|wB=fGzxm$MKr*hBmvL`1mo^)Q94ZJ&kMPBg?#AWsO^ft=e zdG@)B(x3~TIZfvVNe}g8Qn>;%x%$(&lDx5fzV^Ou5|`V|OPuauGqmxm-F%@cz2 zHSxIg#^9TA>7{F#-nhTn%d35xiJkoZ!pcoel9e-cuEg$i_Er~9-jG*lacoz5SaWy5 zI&+|qv)I%At?b$1n*%+~zU{Ewz&T2GT(1x4kE=2Hza;pT#8QwXUp{kQTO@*!2g#)i`#V+{uE? z(w{7Sxl`p_ZLMckW4P^+yM%eY{IVPc%-N^=O5cszT5}Fc$%OSExA;fT=G=88%h?Z_ z>)*`dT6rmrc|3Scj!%)(*uPaL`iAn2BcFUdf4j0b-?jGZ1Kn3r z$ym2MiD-_Uw=>)9V!0Rm#bfq2^MofivY8V0ft5Y+-D(4QFy1=cgBOR+22u zGB6J9jWVt#qglD#@;W0q(wBEX@Ym#1aXv`K=_2aoj0DKkUa&8E2F>#B?!PD}I(aqU z_EbFfq6`OaS~!S3WBY=eX?|y9TQ29${HA}}93Q%Px}XNrvJO*F~!MNvY~C=y7Nwi{_QBYYmMKCWc}xu*|ipN z|B{8QkF)+xF_iT0()n9YZT(CB1Ns(uK>u>`x;*JfosYeEqwh6WXXU+br0+39iHMV8 zTc*BmaM)j(brBrM|l40LI0rTpRk7c$SZf(ih2s4Ke_VT9n4%j=u*qpG2i{g`GPt2nYVPz;tUO8 zotz%7r?V&aD>3uZOYQR5sbBNt{48(A<-Ls6y0zcA1Ag?g1hvt=ITTt(7u(I_OwM+B zVrt&eYd1$=FaC*vH_Z$A%gN#E{c;O>{&{(75`J$x`-tLRpLaeZk5cV!+I+b`?__xH zyc}#C`;>VapWUa-8?E_=g7~%m!2$DFR9+sNxBnt{J9C4}zN;M?)Y^~vtG7iCFW3P3 zy}0SB$c|FIZ07kXHe8-v?(0QvIOC@h$;)cb$~!ZA!^1t@q3NmjP_ve7?l>TL=Z0_g zXS%Nl<+-!ZUX}(1Gs$!EX6Lyp*ZWe5AMQ(de$Bim>z$KRsaRUd#|!)`@>vPsS$V!1Y$=+1O|=aRj6XSi2BBM{WYX^*@{9O+4> zGjT~&Ca~|rzG-ZIux$L8pyJX`&>Ww|eo#WmuXBEU8|%vOuy;=09qE^+A2w~jt>?^B z_`WOhbV@G!@3V>P?tyFBs(ED?T)J{)D0zdml-#{pmY!r$Rwj$^l=E4YcT$v(ZF%NT zQ1CIs;CnaL@cE}o<-AbU&q@9Nef#Y}+VlH4$YuD!$GGr!{aGjVQhY@Ir~Nz>$(a1T zfcY_T&7~q!kstYZqyN(=zm1&s{JszJ5%nQyq~qI~U*_XLZ|CIC?*$>tRsM`anvbvj zZH_&^KZNXpy~*G7GxL|C|C5m4<{JI+dq&85b5VYD|FQi8a?PkbXO!fJ-$z33A)v9B zkJtwBX+I(|lcM~&mH)%u0zgLBqA{CQ>1 z?`a|1)d1-E^Bc;Z-{(U9XT&9R{1v$%e`1rJU-(>e(XnZj=hgVXv%eUhT$4-kCjo&y zzaOR^_SB;X*2zt|U?OpT^Y0iNVShkFkaiURUs5nrjQ0FHwwk}O`KQtUY&Y#Wj(;w; zx$*gTQuA+H`xXWQX;1#8vgh~L?7_Z-i8<_#ls&)a=ID$~oO!}LSih|QtrScy48y;V zE;?)N7x@PfFwp+aN;6GMYjB;Qy_){MuFmNpZ z*2z1CHhE{{MaR2d(n+-bZXZ=!NmgD~|Yo*k=Dw@%(?GruC3t^SpkC{olM~?#gmMnXq>J zt?f-cKSQgz{C`;c+ZDF{5y79x|6Dh`|ClT}cde%V-TT+p{=HA+O0)BhQgeHcvcFMg MC;sPE!m8^1|JT@4p#T5? literal 0 HcmV?d00001 diff --git a/vendor/cuobj/lib/libcufile.so b/vendor/cuobj/lib/x86_64/libcufile.so similarity index 100% rename from vendor/cuobj/lib/libcufile.so rename to vendor/cuobj/lib/x86_64/libcufile.so diff --git a/vendor/cuobj/lib/libcufile.so.1 b/vendor/cuobj/lib/x86_64/libcufile.so.0 similarity index 100% rename from vendor/cuobj/lib/libcufile.so.1 rename to vendor/cuobj/lib/x86_64/libcufile.so.0 diff --git a/vendor/cuobj/lib/x86_64/libcufile.so.1 b/vendor/cuobj/lib/x86_64/libcufile.so.1 new file mode 120000 index 00000000..27b289ee --- /dev/null +++ b/vendor/cuobj/lib/x86_64/libcufile.so.1 @@ -0,0 +1 @@ +libcufile.so.1.18.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcufile.so.1.18.0 b/vendor/cuobj/lib/x86_64/libcufile.so.1.18.0 similarity index 100% rename from vendor/cuobj/lib/libcufile.so.1.18.0 rename to vendor/cuobj/lib/x86_64/libcufile.so.1.18.0 diff --git a/vendor/cuobj/lib/libcufile_rdma.so b/vendor/cuobj/lib/x86_64/libcufile_rdma.so similarity index 100% rename from vendor/cuobj/lib/libcufile_rdma.so rename to vendor/cuobj/lib/x86_64/libcufile_rdma.so diff --git a/vendor/cuobj/lib/x86_64/libcufile_rdma.so.1 b/vendor/cuobj/lib/x86_64/libcufile_rdma.so.1 new file mode 120000 index 00000000..ef3651f3 --- /dev/null +++ b/vendor/cuobj/lib/x86_64/libcufile_rdma.so.1 @@ -0,0 +1 @@ +libcufile_rdma.so.1.18.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcufile_rdma.so.1.18.0 b/vendor/cuobj/lib/x86_64/libcufile_rdma.so.1.18.0 similarity index 100% rename from vendor/cuobj/lib/libcufile_rdma.so.1.18.0 rename to vendor/cuobj/lib/x86_64/libcufile_rdma.so.1.18.0 diff --git a/vendor/cuobj/lib/libcuobjclient.so b/vendor/cuobj/lib/x86_64/libcuobjclient.so similarity index 100% rename from vendor/cuobj/lib/libcuobjclient.so rename to vendor/cuobj/lib/x86_64/libcuobjclient.so diff --git a/vendor/cuobj/lib/x86_64/libcuobjclient.so.1 b/vendor/cuobj/lib/x86_64/libcuobjclient.so.1 new file mode 120000 index 00000000..18bae933 --- /dev/null +++ b/vendor/cuobj/lib/x86_64/libcuobjclient.so.1 @@ -0,0 +1 @@ +libcuobjclient.so.1.2.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcuobjclient.so.1.2.0 b/vendor/cuobj/lib/x86_64/libcuobjclient.so.1.2.0 similarity index 100% rename from vendor/cuobj/lib/libcuobjclient.so.1.2.0 rename to vendor/cuobj/lib/x86_64/libcuobjclient.so.1.2.0 diff --git a/vendor/cuobj/lib/libcuobjserver.so b/vendor/cuobj/lib/x86_64/libcuobjserver.so similarity index 100% rename from vendor/cuobj/lib/libcuobjserver.so rename to vendor/cuobj/lib/x86_64/libcuobjserver.so diff --git a/vendor/cuobj/lib/x86_64/libcuobjserver.so.1 b/vendor/cuobj/lib/x86_64/libcuobjserver.so.1 new file mode 120000 index 00000000..b66a9d4a --- /dev/null +++ b/vendor/cuobj/lib/x86_64/libcuobjserver.so.1 @@ -0,0 +1 @@ +libcuobjserver.so.1.2.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcuobjserver.so.1.2.0 b/vendor/cuobj/lib/x86_64/libcuobjserver.so.1.2.0 similarity index 100% rename from vendor/cuobj/lib/libcuobjserver.so.1.2.0 rename to vendor/cuobj/lib/x86_64/libcuobjserver.so.1.2.0

    Am~ojy#ZA1dZjuIobMc_+p(U<$hDipdNces@UN9LNc0_FCV$)tgBM~nbqvcFAz>?8vzH~SH}T)~M LATd89Zf(wOMt5}Vz;vODsPe4QP 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%0AEhu2|c~0R;2=-s=f}MK1lO_0!+7CIp4_x8%~_ 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 literal 0 HcmV?d00001 diff --git a/vendor/cuobj/lib/aarch64/libcufile_rdma.so b/vendor/cuobj/lib/aarch64/libcufile_rdma.so new file mode 120000 index 00000000..f3ab9939 --- /dev/null +++ b/vendor/cuobj/lib/aarch64/libcufile_rdma.so @@ -0,0 +1 @@ +libcufile_rdma.so.1 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcufile_rdma.so.1 b/vendor/cuobj/lib/aarch64/libcufile_rdma.so.1 similarity index 100% rename from vendor/cuobj/lib/libcufile_rdma.so.1 rename to vendor/cuobj/lib/aarch64/libcufile_rdma.so.1 diff --git a/vendor/cuobj/lib/aarch64/libcufile_rdma.so.1.18.0 b/vendor/cuobj/lib/aarch64/libcufile_rdma.so.1.18.0 new file mode 100644 index 0000000000000000000000000000000000000000..df86c537bf19428f8d4a292897a12b834a9ca959 GIT binary patch literal 139440 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

    V!X*a?*vXM#x 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%0AvId|b5sVWG;J6#y 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 z�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

    O}tfZj$=|v-If>e`*J0r8j;u2A9%_;SYd< z!fgCPXNK}+HA#2{wmVisqh4`1OKt)|>a*#XA|BW8U}JC{wJ&hwN0Y(qnkxv2 zxhtdLQ02qD)86krpEXinVZK*x08PgLJ)rnBP`oq_*+Ji*X`1X!;0z8^A2hc#NvC}d z4=$fAHfbG&lHMjX}HuZxavFP_AQ{pVr-1X=~WRXX?w z_mCe_i^$0ySK|tdGcSI0?V1P!chpPFw?_?KOi~W1GUVdCEH!)|t0tRJjLJ8m1a+GU z#jD{6RldSTcJU9sIJ>42K(VHBDgV65KM$JCe6m^wpHD^IHhgXj&x0MGzeh2?_*5(v)`ri6 zaBATA@VWU@?7lF3o?NE!c@B}z!ZU!y4h~vmeD-0IS@^u?Ne)m=eE#ZE;PX3kYvS|! zX+%^TK3{x^4WIWurBj3W+$xkBtG>XO62kGh;z{O@t1J)V^IOQn4*T+1=B*u{*Fr;L z`aEII+VHtta@C2?lT4O~_&nSsM#SfyhJ-RhLOFje5g`%5f8?^`^Ooz6AD>@3pZGih zLrZ+VSAKV^+xc4^pZ&yA$FR+h*Ds|xVMGpd9Jg&ZA;}AZ#8(#}PmqV#i zK2#gR=cC}1>iGQgdB9W~J|AY>hR>TBx8d_AjN9<}1I7(LuVJ_vKDPt4n95r_>36yvuxYLnID

    dMWTZR+uQYP`t6b)oCVeI@0LFtB%iK0Z)L> zZmj26`22NS!RLKbfzLCa<(t^?`Bd_S$940^7-zxf?6JV-3Q^DYs3jnmvu>|6Tcs3! z`JKX8wcUhb)MgV(P#>F6yjqD+efTVvng6VXV`!DNp%>#atyIuIo4O@YkKuVDDSl^v zbS3fJh8PRAA6i8$w2Fe})F@V=lc+7oxfomrdk)@a>FK)XK1m@C?NQrgZ1Q-nomjlwgg9yK+ch??+dX>(m!F)CAIP1>FZ zI6m#MNF1X!%>do3j=C={l|LPfFk8?qBz4$2+9 z2Pe`!pGB(&Y2Tb8>Jj`u)zce^JrrnfrB{=W@uGHi_%a`m0oAxaqh5aIdQucTGq9Gi z4KE8oJroJ_)g(|V;i7Q(aR$;H@i{hqs6}W`u})m8@%j*T}G9CFZmE4@3U3NdhAmc%y__oCl({o2q`6_1e5u^}4+Tr9SXa$&Nw zg_~w-fy4aNws~NHq`HHUE>8&QmzReG=v%1K2+(;fsV$Wx^>`-;(0icCY6GXgNk~?c za19s*C`6>34M^SBk&G+mPnw#GEAZHQ8S8?LgUin2z6@o^P!By$GOvK$h13kr*=dik zNZiX$Qik%?)NRPa-$!tz8D*rr5^Nl|wqAnoF@>|=lChS~U_kV}LqE;+?0#U)*Xz6%*UMIeoa1$i=LRfO!F z!3mV7?J?5CnKm-wmnEuJ2mtI(QV+k%4kPR}VICu6Gb|gZ9g4HyeHedse*z=Rp_Az; zV}mPa$(NvnkX1xNQDwYZfYHc;?t7s$qIG?TdTR;*#N+x5a{%%;1CtC~|LQ#=fB701 z$IzPu6401BaTeuoc9hfKoCeZFa9RMLPqX|B(7kVN9WGDDGfsIb{tmzE8pi(+nqoei@%S3^cs3qW{X7{1 z0z-ym&j&N{w>_F$%5PqP_PICcv?olOQ%I>Pe}~YN^EVqgG=#TToh^8KPZ97oo=SsF z{_atalleWapFhAji~L=4H{@@Btg;f_)9A>@?H;64jh4#IL%@&mOQ$9C@GmgC^YSOeY`qGON*CQD>dZP^s$R<2WSy83# ze~8S*k0D^g*$&nMg8U$oMEykMLaX|@CQ3ROM1e<{q*w%>0yngfRCU(Fwo!u6iPb_U zI5f>@abgr#vMffig1?qHkq8HHHzx*i6)_dHB6ACi&?B7O^W_)%K6?o9Hu%6Jmqyf6c#wrzKYAV>_#M96tyz@sP!CN6x_Ml0 zy`K!+cnlND&s5zcMj_N{pb_+1;yb=Yl@aS~r*(+HyATZ8&!ILUgV=3jurEVpgZ%?{ zAcXvGRObiwpAGs0mxbg;3gZ`s;;k4zGZb&g_(`Goukncgqvgm^hWG05 z39#wZ0+|`EV=!CPD+p8n7G-KpWgM{+D{zO@b>i`WKV76OVKC2xl2lIJ%06t6lm zT?SW}6$xiyu~@(-V}#oxf6mG6a?vux|b zHh+-g=Uc5oau&CeneRApsfNuH8TGi1yayV>VRIu2v5oPNE`-g~HEcd*t1B6WG0NR> zSV8-Q2D3K5V+`{MY#zl#wiMc+=l;-CJ8Y7T)s2%iY)-?6Bx-1RM1E`1?XZ}BGz=IE zHNQlKH624S>is03=9BPQhCA+K)l27*d5vQz7VvjE?NP1Q#;dPNks5}Y_~H#w^BAFz z`jLg23I?H4UbGI>EE3W*Y9wrT?{4Lz1Vg+NZiWWu zPrTWhX@JARu>yzBy_<~r{Sqe1WTr-1O8679P5ik*JY>HFz7FBxYJiU5A-K6prGl{o zc%cv;?qL2)?09%G=ndqC@a-JNZTNTs<2HOe&;oHAK7PkI@e#oE8^b)ej_}_wEYyn+ zlILB&GdvSv;Ndxg3B{{UCKRjMnNW;s&5*}+_Y(FO@v!er zz{9Vl-aTp+6-k4Awc+75NR7Ji(CCw2-Wb#;Wk-hSfbBFe?q8sRQE<}Z`f)Lc2?xd{ zQu>e@4)C?64$K znEI?3t^Y6e$qu{;K15$ceX>1n8zon!khp(YpWN_(ZImMDlgmYitxunP!sIFf14Pm% z$4YuF`sCFnF`_={GBua8X6Uo?_-lz)i4clULoR_zenSVE$nS1-4doc(n_gy5L7%*w4*(7^YVSsbaDME1YaRhYFB>fo`X5ZnsQd>3 zp$rN=^2k23B{}L8S=O~&Sz&4KTjSG{Cu($PtoJ|Q`@WuKc7Jj;rPifW&6*1={f*rO@H{B zX4(O9D%r{_{_tzq+Hv{An}bZtAHJ*=L1vHIV6Z+LYwwmn{9TjwHqz9zN#dSaQ$%l# z_J{vK9;W;e@U;Bl9#hkiyTL#qe|SDBQ@5D3@0n)&;j1TuZlJk*C$vs~_*L(Oyfc>= z+Tu)&e$;5Kj%4=N?{s(?J779@svJOyBHGjC?&*NA-%$jmR`=Ij8F#F)!dElvV zG59tL(LT5e_KM9uxX)IXu@72fV|bW-a3%B9ZXbL#!7c{pVSH5|q~Q36Ehz|Bhqzl}RY@yCkdkD zOEopVi5jh@p3l+mbh=4wF!^@mRq#}}eA|dZ;{Wo6$+xF$by@zeud2znG0aoDd^?n1 zL%!VzC}3mL?z7=2uxbaf${W%D1xT>u+n1;?l6-qVj{Yy2=V2RH;s0uZX6*9q^iw#P zX0hR`0;C?7d{fQAZVEj6|6INe$`7L{qI?@L!T7&O(7!9+{upN)mzwfz7xdBk<=YC$ zRf~Lk!6ZhMZzU!%qI?@^8n0Wv^*}DWe0$u55&v)G+nQ+ce~mZ(FZqT43%@q`HgS+O z)9C-YQRLfmb1eBbnW>TF+n>O;y5-yIiFWyx3dXKazMTwu?egs$#%=QL1jcRh?LZXb zHu?4)<3_&y#<1o8g3+U1B%H$k#qdmoX@A^@M`7}*#tWgT$;gRRV@UZg5ARd}k z)DKXG2z49ap6Y%py&T}PRb}8X`3nmUucS-O@3@6|YKKF0cMUike6xnbNkk&(jTMB! zI^l2xbXp4z*P+5la5y&>aQGmt?P_rN_{nI-4u>aTT!V19eiTw8!6EPK<+uiy1HOjg zroO%ht=G96aQ^@Q<$$ca!)OY^;W*oJK#wsR4&5ZE7C8Kr9v&=?N(cLndpTg&y|!_w z35Q?O-l|vKpC`F$fx|~lVnjF`V-h36;Z>&bGQ%_F{H>wxcS0_K!;7?!>$x;L9EQ$^ zX|#&89P-WZZ^_pE7Rna2vx04}XE(pdK4drgv>;xD;XFVe-#>oc3k>?Cdjn({YuzFl!`|Ub{7l_>H7hb_5;$?d$)idoU1AYH>Fh@jv{~eU8OW%Kl z>Bp(>AH3X}c0u`e#;h>;cH*<(sc?P&2Na@!^A?8b`>)yRG6Jq2_D6^LvmRic+67#b zTWbiod|&|^d-^ULkk%>SrT`Nx0r&Gr@@Msf5HaerrVwzi(%h~l;1)JPGj;*j4wh|D z!0o;@OqjH<-JkUrEI0KRc(!f<_b;q>j~E$7Q&7O!*SoL3TMM{bNKh>T?*F*n-RMr+ zxYQJIf70NpSHOKPxoQz`@0i4h0&a#$j40s7na1lDa08LcuJ59L`>Si0Z(IJP ze0v=oLHRaYes`-`>=?w2KWkcVYoBvn z4EdIF7aoPlx9c!PDc^>O{Ym+jXF~C+rwPTXbQ6kE9T|fE?@3F(UE2%tEgFh*SO{(XcU7*|4&sB5m)z~~_+VTSFXbOA8#`PFy8lW8@<8W)e+le7IsYz)lN{ghM6Q*J@wyesgad+j{o|$SvaKz48nHKjj$W9)5q3>)luLfvk5&%}2=Z$mwCt zBS2{GAc4?3W+Vebx!&D}sgc&ZKY-AyW4-%PfK+I`+X42kZ~x@>J-|F0UhZSuhL_(k zZo|vfj1w=-diNWQoAvJH44d`tk6~x1{F^y5T<jAAXk%^zDiNVVC z?q(*Gq#Bw~f;tSzAXc~9!;r_-{V{eH?Sr#3fuFBJ+hUJDEJ}Rc_Q9K|;W+SfPDbtc z`9WD2e!lZ4hzVCLOQrN7l?<@9;pYH6u7;lnS60K%4$M^K+PnLHzVz2P%#WKc7W0_3Uu8{=dY} zqr<}Ji-?~`Zq)c0P2&D#{Coyi4+cjm0)F~Mv#k$5wfru5%s4xKet-UdgP(U++VQh1BpUIvll?Y{dtHpJg6|@L6}4HIIOw zC-oKlybzO8fZ z{Jev4gP)TaHu(AAAo z{B+_4s^jMwxB)Iq|D1l%hM##?gNozA&udXkU3(2$|6k%KzeZ-GFCu;}yH4Zhs;fcV zzl@*5h~L&IMZnKI(Ru5`&+|>LB5H>b^v@=eUJHKy!s&v^77;%;NaA~X%So;J=gY`t z$Ir#*{x|s9;b%L39zl-~KM%<7ZdJ)1LcC$6!Ow4`%edb%VJjZtD(XwDc?A6Y)Ghe= z>w^}4e!|p9_}K&Eunzoe0gwveXUXCE@$=eUz&sm%-ov;JKd)xohMzqdx8di7j2rxP zF>LVj^8J_@f5^;mbz@i|4E(%DR2@5hK8J}+{Conx8bAFel%zZ+l%U3&P`tXEA&+Z? z*TT%q?ss39CbwSPJl6-C%@Irt~-pPnNSE&DAi`4-3JpMD-> zTK?%i`v@|7)G(=NkJ{2J%x>A^!Vn$`AOzCDz^W%;LDn3{a32{kV@ z_YX8eW$KVfsy*s%rWybApuwQ~xct+B(vW|89c(Sq{gSEiEYfXm63V33fi$m4ihe$ThYP=6|FrSPT-mvHc{sW_ zOdj4awT3)QlhTLO4j522c^Hky)#TwEY?}@{f3U4no$~P7fi>jeCjbOGst*jYA#L6M zn5~!qmOQ)+HAa$$iTEtNs=B47JUnqRa{@;*WAaCjBuVOP5g|?%0V(e#g7X z);xkdd@mEvJg)CNmONa>)JXF1VrYJK$is%venRrFV1NDcu@GR62E)OI6vrk36wb>IF7lz^I zxg;jsp7`q`mOiA)At-G4xeAY~;pfeBtKsJ}%u~BR=Ip#0`04AZ@pJw_+sv#RKWBnf zEd2Z@mz^dnePV-KTl9YV4fwg@hMM^KNo6(s><&{hh@VIE!tkjM{5%=O)XDwO`v20N zxHC75zKHmF`yh><_w)sE|1y3yBYxLmPaGvLBYh<;1&m?^e=UEqMCecc%H%3yY6N>? zv8306pHG>@i1<0l)LhP*(f&OCTJ1}O?GHgNJAQtD>VJcu+rGBr=j-SZ;^%Dn#rhw6 z2=V#b4Sqf-T}J%Opo`n@7~kHSN5IdC05Cwp)02~pKV||`BjM+Mh{HPYb2UIJgrBKk z|N8vdC*wWr_<0WFHvBw+aT|Uf*owFfKfhz#;OB1)8~pqmwuO38W`^r`hG!xS{5(fg z9lJfz4-=XA*&DwaKV2r2q&k^Uf@)_%@v1dL*#9?)okf3k-wS}BUrW8%|0f!D-Tv%t z5JGj~r?vmDoi#+k{SimTYuG$dF9TLi1P$S^xeA2{o3}zcAZ(iZ03Ni}W%fsOe9eMQ zb05IX%v1aRh~2&Iut_#nS9H^`Igx;c30Gkleg}WOk@iF10E5Cp&9$h|pk|pAkX67K z^_Bu^dZArtFHGpX&y1fnYWCNF;!kagfi z(Idau|3?XicqjU+{f;}%vt}B=@a{_l45wqN>HQIRF*VZuh+U9vb?=9s56}@jeC8kS z{{v&!w?E?8CSX`@XuYmE=(pqJ-%PjR<4(qH`1mQ~#76+rHioVJe>=eQk6lilcWr05 z6k*_Db0|aM`eb)ZQR3kxwEdw^V*j5BVgH{AVgH{AVgDaP*#9?<{U!VV+5!(hl6tZK zkJ@HE`s4;kjk@qq?gR7{%SC|l^$u>2z=Y+ce}2c@L~HQyrC{PBzJH#tVKPy}OO-lKPE{}4_-iy941&SOcfT_&jqb^<4_ zhZdo6vcE}4R(JlOaS}J1==%VFfU#v#)6{c4!!QXrIZof3(uMCw1H!sDWgd#Dd0A*3 zIH{+k#>otBMlK^Q=IWGdWUsXKOm9$@0`}WerpX69%>^n+p$k;3d)(J@MBU2SBaA*^ z=2o=iES_!KG~FymV`d8yhnEC!Kc>6Yc8SVC?imK5(%oj)v~+OjwkeUc)h!Yo}( zmWbGTx~X3{0#&TES0NEraR9SW;Il9L!XNiK&nyRzli2r9*LJ^Q!RN%!K9FO?Ps%fH zz3oc5hWLSB05o8k7}btX5QVpAXFm(a z&$k)3;pbC~+w@Bh z$BVCS?@73bpP%XhPz{wCq+!;LRyFRL+xXUT&ifoA@77qmgi()cD9OZCtN64Rul4JY zBE|NouOY|@v>P>u{(ZK^6V75Pv%HrTJDkm(s{~ds&K718q}_zdbN$tBUcJ)Ajtskb zbv3pglTRy&ArX)^EjY`9)42jHWNDeJ##yd_7F7u>PXx0yJ|=~_M0HmCaBbI zpdxHt&>$^eheMxWA#E=dQ@y&Q_4<%Dnni=?8wqLU8oil>1ASFh?MVC5Wt^XJD|-@5 z<(gMdhMwoIXWIG?=#{3?E7)nXL|3g30}D*9G7=L30|!fbofvqr$r2F*<4pbYSbwb; zxCb*uFi<{Mbxqp`hfJyR* z0C=_u#jBPGajL&JjUDZ9oM|yVfH0(-A~dFD82vCob^NNDZ*umQAf_d$>(fC+7^a!Mw()#FU|R65($OfUMqi57 zfoWwzwALPziC;y0V6?|ngK7Gi#xyAqu058rh{m+q?<(Dh+tqCJ1$~nxXv4aJ@AGb2 zd)$%^;%f6vZZ+ED4k1(%C0!oU9wXgVdJi$x8YN&}^}9;17mc+(-(**lOL_#gRKKhA z3`wuWH+hWH1S63VX|L@Ml33r`&NAc@%+%jHi<^zz^&!kG14MBSMZ(MMHN?v^Tw0E_ zkY9ZN2fv)Tt9Mv%d01qRWB;kvlmR6EdA>km9OhqC{w(N*e=s$Y8}fFDN}Nv$;vl&t zupy)ub_D{7Uictk@J*b^3ls?q79(R6%h~QHy&#C6)ZIP=rd<}YzaM7YhL`s-Zo|tF zjN9-smvQ1H>Kewd@kida5woFXSI!34wG77~4BUKJR1Uj-xB`=xLSr$0IgDxQO%qB| zvrQ;LJ!wMmYC1z6*Y_jYYt#?lj{{cbbi-5hcnS-%v{z^W9H5@+ia{GGuMM%+{c z$R(I*&L>Pg3KpoLXV!+B%~smibG}87P_x-2zq{2Z>>f z$7{{4X#^a7^IXBv4L1@Ie3(&hFf|g6wt;xAfupwjoev;Aw4QU*Cg3Qxp@;12z3A)k z`<=V30Or~7a{%Ku{JfNL8-BK7+=ibgF>dhlEQSq!UhpYq#%7rruCp0lk1+6afT%Zi z{4B&oCVq~^ug1?iO(;o?Frfr>l?lbGehhhB&y8Sj5kDu#0zaElH$ac?qb6Dpel|l5 z$AO=XQEzSQ;pYwy!_QMlOgMfjCrjgdXAu21{CpdaEuHgfjh|OyTXh(I`k6=YGvfKK zlP{`)pA+yUB{nv@lWk_!ji05EXBK|`+JT)`b3J_XXTZ<7&@HOt=dw?$;b+HBZ20-x zMW7;*&ME#~OoO1#c?{N?I@S@b|1a@#ScfqBBI4&Yoi%=5PvZV%{5+as8>I+3=Wn9t z)`y?#Os?AS^JPh|1wS7&i4pPhPE&I^kr`YxkG~dvON98{8@cTGdEH+r3eE*n~SPr$ItGV$i&Y}sH~!k(o_c%N>Xi1C_$ZWLh;JU5Y~ULWoOCy z&xyd#kEC9#|4=)v2R}DJ%G8CQb*=wkS;+EICSVv}IKdi5XYpE^l|IM1t2MMPX4K^nPZw7d5L@=z{bN>=A$5 zqyskOlXZvMzdyBQA?@wg(I>>a+4771KkOsK2W=$Y5$3$oYjjT*noztdFrfrhnTPy- z$Bj*_*#i)~C0;;qDy9z{l(^uWpV_^EIV=aIeYNIm$hF}8n?bvrgAxD-S>Fqp4bTxh zT=fs^@;LBpU@=0#q{es;`}Z7AXB=9HweHe@aohJCD;FSc`~K8s#{bZE_b!GN!oar_ zC^x9SaupzNMthA#;+Mq7oDZo%m|5iMKKRvGmuW)D>Jk%jE6zWrW~ep{d0h8ig+39i z8`v0Fw~cL}x7SdU1lGw%WaV2Rn;1QTe-`r39JcvAWJ2ZAkTVzhceVR|Yv3I}r_|C~ z?_S}s1}V7S{nKC#aiR}-T$_i2yl{wn4TaeFKtL@a&a8LeYpd&K4RP@gSP*B{yZbSZ zKpa=sYd~B@n;H=3YNa9WCW4DKQ*98J5S(biNqc!p2;$yCjWr<--@p415O)u>gm8$% z_wPQiK^zb)bsvnW;ClDmL{JgJtM;|8cdtY-wX!W*hxS;`scQBG!8vNJZENWIH`lvc zw+W*!h^O}T?z1k?c-n@<0gV&>#r5tL=i5dJcv^kEd#-4#_2H@4yU*`7Bn?eDgJ6;TmnHLvr`JHn5l;unFTQt8 znTL48Pc1x6#}hz8OEr%UafIU4dCcT@v~FO{Pk`vTEd)e+V1h>FmjXb~VQM4*oe5EC z-S-m2Pcor>y?X=@Oz`tY;^&stz|X4@3i>kzZ%+#1Er9Q>xxhl3{k@9uGefxg8sj$o z@lnR9KbrOKiHw`|9zVloz5A*6Fjun9<6Ln)#BdtIz}r=#pV;-uJ-~co>~1Qb=qR_^ zWR8)+c{QvpS!To9o~=PeB&@xZ?}xz;?k&0k#ncrEXuUqHy^eZ&5Pu`Bc;gL@ zb8pf7v%=^LVlBVyYU!?TCu*!++#1ByhP8kH-*neO=h{Xo0@n5veYrlYJ)RLl1ajHFXP2vW*L}){xE7w(fwyt56K^Zg zFT~rO@{997>?h*wi^N-=|G@)(&+Y};m_Rjl39|_9-nEt*q~m3L^Ip$Y;O=Y91b08~ zM-V9j?!L;@NVuB-ks6M-vqS4h2aqUuJDhlX)BC{ND{J6wj2&;gy#|c5;q3s%ZFqYr z<2Jl)!?+D^Ph#BQ?O6;PyuDyC=F4W8FRrs0UXL*SpQ0?;@wO1tn|M2x+OFX3ohFo~ zC_nftSzTp9Nva=1@PGET@OJW%WcWW5@f0Jlk1p4G@U|IhIDWk4-lE|CO@p_<-b4)H zPk&oO=qz5(Y43A1?W5uLT}C~w!+AB}_Hz^>0*;03C)}>nP&(6AS5pDgRM!LxZe^dS z-;vKe0=HkF`WmY3pYb)|_6Dbh+XwMc!$@!&!Fs-cMZ=gxh4b`E*cG&3ZoqLn)~H&Oei6+O7AuCZ@6~TJX6b-jN1U$p!Dr4j5fO7s?ASV%m+@Iv(x^eIe zlO-Y!E|kRjaBwztJymZK#K0v@%Vgv!#Uycc5?Jr85%^Zr z`ncMOY=Va?h=+s0wSk2QK}qZN60oXsNUyw#ahv_#gK?Yv-kx!r{oaysW52g$SZVwH z9x5n)SNnGWd0Wol>{(M8vfm%Y+#=TbsEDE~($xJXl&r>@kXzkpLK$iVLmt=s9CV84 zmX90+)}2L3kKT5`2xa|s+wZMW$MM_mZm-!-X??KXGUNaHld#2o?BV+<<9lhqGy5rH zNUCi=&KVw@1w)&{(q;^G)n_fOdraltt%+;O?gu>`++;n#UPx?OgwK0pRXs=nvs=m#pT$ zV}rY7z}@+82hl7+?P>`sLfF+lXvx>uPk9hloH`hX*6Y(Q|IPiBgIjPK#*J!4_>}#W zolev9`Wm9H)qg;}>ia4CP_QGtg1veu5A?hj z-m?I2t2`p${r-{#cpu^!zjyx~KcnP#EZlD~J@9TxL&3YP*_baD-gTJI92VZ$_fuW~ zD2ae~<>=XfZ9nA!WV7w3yb*j`Z9iq-a$uEB-@Bf1o4$8B<2HS-6XQ00?@Y#xzSn_a zv!8PO>11A4r#HdK+fL;)GPo!EDQ97lQRjISzr;Pa@|sYBDm0;FRbWC%>UM@au4P&1 z9KpS(_5t_WQof`2n_Z~uxAs%Iko&*cPnky5ADY}KF^W3li?;YcZm#c*#8P>{H4UVW zlL!EhJIl*VN-|T55aCA5_*~zD#F-`~4FkM+ug1s(3)=KVcl?o|G4eyL6#mqcuXTaj z-(fWh@QrSVen50=s7>!_d~9GgTd=T0$~}0b(UFc%G$fJ=y;RxbkGhU-1&!LB=>(jV!2g;XPhER2kju15z)n_SW; zY8k3)5pp>IKZs5X1~j#l^Vh0HBFwc+a@C2XGfhPmrlKA8iX_5{MkAMi<()!cT&r)w z!BX!>1VnKTMe;}fIg5DtiS!Nd@dF7^AzWfYvFfhH7Cydco+YSOo!OZ@yjNzPC95vi z>St+cBA!vKC*ld!r#mEmNVQ}Rzhl^M)^q``4nKxx9#;{j9B_3YG(60+YnVe5jUf!t z9ryw=*R~$M5}gv*60)af6UoxEqnv&p708z0^uYZHh4!Z(dnz0+o8$fMc=Jd zxs&nlLh(--{}ge6=Qf5{YCWsB^GE_W6@c(s3zX+uE{uPk=1)D+7E~TOg$OfdYuEf&Kno8M_K98Xl z{PVPFb|d(;a&br$$$5l2)`M!*Cts;dj?(Ky;ritIu3`G*l5U{arcXYMVq}GM=nh28 zk2DxwjmH*Zo`6RcNlF!j%4{g7KkgCN#Qgb>*ex$O3{b4xfxW}%Q);X*hQI-j%U zapL3a=nqcb+3Xka*DUED;N|Em*ippGQanPSrK+Nj8X>HI;}O-#-}uDuxLH{|57@i) zFrIl_Ud$fA-UPrNrofHN5lNl=7Gl)CkFp$Z8o=mT>)x*eakL(}hPZbo_%*OB4EGx2 zJ?!@L>5SX#=LU@1?B~iEh}-Pv&5Zw{ac>vH#(qw5l4)I)FMxq(oW$v4*CPjEa#4@$ zgJ1TETVO51dPP8Q;BJ84HnxFYUqdYu^;>%6pFsP_dSu;r zC#Q1#jxT?<#v^q9MHdZbG;u*kWjg2xUwm1GLVTlJfvdzb>;4N{UDo{E?}i|HUaGG+T=b z4Vsmq0Rv08|KcU;e^4AWn&G&NT#ON`X23J;_S?R9+Z3Z}QgQ!<14M+OS*`b9zy?!W z8>4lgSrME5e|G-`ZZx;i1aBji#A^3noT$Bxy-Co&eE$Vp^TBb6aQ_9BUkn?Ew|0D* zE4he*fJn1At~(9j^@vG~jDIE(j*Kj9pt6kZ3^BHcn#N`50gmM)qJ|=RF>(nwn)@$K zs0atgp#I1?6A2#|K1_V{0gEViJ@SkDFDO|MAJh-Oxc_3OHPe86cLPN*x29vNnfou8 z8u9)M2*i5szX0NhzwjBtURyABz4u>~0lRWTe#GXWKX6$n{x{QY_V!N3&kUu1$~f(9 z>VFJd_g_2%o`0+fdET|1;ZlUT|M3Jo0%nE2ciSCPluGd>_$4Od{tFYr{TC*L`!7rg z_g^rC{g0{aFWLY2BQWtJsTcbnsV1WSy4I^VKsp@n`UyOSCxwVLL_75%6e5as0bCO@ztnIz#8%g7c!Zq) zTyH_9tmpb2otQ@;bBBSaL@oFETCM} zEQFblpvIaSV1~M{9GE#6nnbt;=vLQ1YtsN}FmHJ}h?&Xi(J1o2Wl`rRVy4C|4P{7E zqZ^V;`vS@++_4`HXE3|{p|YSex}>>!EYJ2>4P6KZuG$|3>$s$ z90vy8@A`HoAh4tX!j?WL`yqQ`suBCT;+NQ$rcz8OS)Fe}ZgrLkWvCVmd0Zos(JO*| zJ+=Y+Hn0u!@i1K;@}2e-R$ot9e_^=&+YzMN?O!Pd`xh8Y z@Y|@t?`k}@>|e8OHvbO(f)<15RQJyYQ&Q^^aHr1e)U8U{b2td34^lsLHoDHddeIWQ*-`7 z>-E{c|K@s%1K07>{*4aVzxa*`=kcVmRG%vjy;O`r2Z80N%)71n^2ReE@joeu@#yVF8}q@AnNPUC5{lt{<1< z&F$+cvw=9a^^}(2+iL46#~uJy+4Q^Sct5*-_czn2-&y`Y#%=2GO= z0gK@OdlZc9Kgwxjw}bm&l2HZv|A>1VIID;L|9?}fO=UMMOJQ}xR#ux@HaTo}I%Tol z(57NZiHfi(H)(TrX&pzKisHg5H@PZuS9GIIQK3tbgvj6e!Mj2G=zehY{V7tY0b$wYiiMEH`7+)0YZLv3g|;3JkHBG? zf=L`%#|n$s7x9IA3oR~3!StDr&e8OHUt51m+MvJ={ifjz_NUHZFzL5bgKe;r5$8E# z=%Wtil$*E7S8AaPDJ1mUBevgsvEk@8m*J_acm8ncCrPdFTzIuB$Q|@vJ!oH`-<#kb zyg}PQze#~@aDLqo{hmOMhJK~Ef^mE^)B{g|egk1dX!_-v1DR^rbn?SYffFMxkiPlx zAOO?U^gkisxXcADWseDYU$R3g5L2b>`;yr>Q_bG58K}Fo-p>MSZOn9W^S&gJrv}sX z7@(XGd|x7CfOF+0ps)JlJ^Gr=I79^#C6X@hOLA15KX?y`%?`K1gOYd3-{V^(ti}4I zqpd~I%d6jX1gmbp7@y1JX|NXdFk4F>iO~4kXr$z#$R%6nqVEsKUpL3|c{Xw>c5{&k zbMcE*HERQJGg*|HEH=1VNQ7BgK|hG3xj2Ug;o%wJ;w&);^C5}q z@ccXpEOW*K|6<&+|9)WHvHw11oc5pL6^?^PC@PY4P=_nCcE!Syk#n`;WTB)NQ^w_2fi;lqZH;3VGY`9L*6Xx7K{ zbMm?wC&T7H(AWCFk1@AEY&*&b2Wb{onMAm7PZb~d^c~seM~nHO#JGbh|#x; zfzfLb0(bR(KkQH8`$0Z-KUnD4o6j@eEM#9k!nk8^-o?0MZw_YM*qfsnro9QE-dlve z(sCdBisv?llMn`PpBE#>9dG;;>}T6uL#q@u=2gp0C_}wzLTTz16G~CfG34`9B(ugi z-uSQeVC=v@k%}kKg_bE8Thn;s5adwPcw@Nz>CES$#VN)ntj~N2o9R5XOJTru#M4bi zX@Zk^##6|TWy9QCyRb68;3KiBVmq9!fxMJapQnY~3n%a#gR^-X|AaL_4jdX=fDtZ6B5W&Km5v)a_SF`X41qd`voZ>d;^c%mMp%2+jH6_EnD{zk2}W7&LF)E*UcFa&SwJ}&> zV`wqsI4it*GqksnDlt-mF^ezFG~lbHk;*qx#r(BW5+US{uq&V=cn5JLPvx6#?EkaQb`UUi!Pmmn_07`Q5C#Bd z=vi|qq3u&V%}|lc&xFp5qxb3(!62d#WF1Uh!)8@q0G74a&2VC-WEglN0QnlEU7Z3q5E7 zx*9nefNo${wlg5-KLmh23|mD5G&BQpS^=(Oy->kmAibV12+(ZxK0gr=qG4Ni2IL>2 zd*I?)dv*hSMzvuF$^d(|lm#&F!E*__g-kGPY{655Y5%twknMirJtX$tMJCG($j0SJ zK`o{e<+c`KBbvF3!K!N|)@^MwAS>CFk&BccxtMvB`u^|$zBk8<<%X+!_4BSs)o71C zVKS0Ohlf(e3@wc%!sk5(Qbg&+g3{}xfh2y;Y5n%)&T#H0$vzW;Qpn!?<4)R}A4|;; zn=4HyK`l0+BsKam4bWsY$E2mGStgXGrXWOsJ}keL>iRSd&~b<(Ih(J-vH#C%+d%-( zQC|o^A4MkvK(EsPy_pix<~(kNR@LLQLI1uKRZ;$Z$iJUQatS|Yke|)azRUe#{5%%- z>GJbb#vOhh!??rGop&Ja@N*O6hMzw%Z1~xpHVWqdJb{${Jd%v`1!S%LKW(L8mHRDuX*0%S7^)C@zcvj z5;QS`_9r&rGgy)NVYVUUorP4ztUmQEJe2~$(ob%ms+ z>;syzl`EN&frfRqB+M6DlCm)+3-7%90Zav7m>(f5brcbnrSEG!DQkiRw;i7=OJBb9HYid`v*P^yiQDl<}h zTq%iAsve}s+ALx1y;9J`iC7^}v<0+%&|7CiWtrGplUB2jMdNMZX!3RtbrjcK_mu#_ z>ouVSb!4)&S38=tWOZCyG*LYA6qRh!($t@AbXtaLWYRL#8|?_+N_7xV01x7G*q9u4 z+leR{y^5yE6UF7ied~o=dFb+R33hZ?J`>Bl6zc+U3y^O=^vGJjde-eskF}@6OKz9hk z3lWAL`wC5+fM@7E=n0LtvqMJAKVOR;OAeP(RiGxvt3@W1tLB?fj+$*k*=i<3K95R3 zwFrmTEC+}C{>-c^)J3#%kA}m2kj=j{|2%TM6%5TW7)r*IYmP!#JJamH*0ZsOsM&w* zLKZlD@U<~cVk>wXrUGgDfd=K~Wud&{kc7e4`#g5=wY`>kgE9issQa&V_=c5g=WMby zsFIDk$*nEZ4A^6O6iKUJq}eViDeP7Y&}uA9n;^%kgRhzDuloSgO>kDU$%=PEGHKJR z%I?8+0%q`)6Oj7DGc-rj)Cu46X!r!AP9cE|wHKeBpu?XT+<&d&Yovt88ypXH_g~w+ zO^=7}`xd2z!;iOv1nz%j|FtQ^D&Q#<2kb>oK$=K{8pm1NytOj^+B%g8>vW)zDmGFj zu9QS5)j_0cv_cb%NYqi$ee4b>%R+ONQuitn;Z@c{N{E@Mi8&05M1t0-;bl@ayu5k@ zdD#|?iTr9IzdKY@HZJnbr%@TF8c1`ayI(2w$NA@fm{79%xRr44$9HXu2lsY-B;2cy z?gQ?b{nvh=gna?;j*bq5cCCH?wH6?cjE}A){$`-f+Wprax*4o;<{Qmo+OsdPBA`-wM@(rfH<}USybyz^Nmv23;?!VL4x() zyTgAUAt~_Rfw~KEX?`zI{P!_(3jB1uo98N=bGySR9nVCLddfOQf2=1?lkjbAPNvFT z(41@}SyiaFpuY*gT^ep*EVj)dzMzdHrQVx?ByCP!rG*w!NC@~FvyB|}Y`@txC(F?O z)w57ntga8g(H&WHuEtT%d1yD5fbqz&>ZoV7+J83)_!;~FO~72kxE!@L57z+*@^NvZ zjJD)ecLgDc_lNSu32SU(ToYDX$B=+m?fQx(?T=N<81?j0OaAf&QoLhrbqr5+Qi{8>tc_ zwa}H42&K+5Qu#)z*p-q9rQ$@Yno-Z4>>(&lsmWr4n}tM}#RrfQ4obrhB#!0s0_&w4 z4zh2A%&m~0e#KCCytAn^Et-u@OejIsH=!i8`~gkHWVH{~h>m@(>TM=prl~R{bw}&W z!B9BSutDPcl~;zwV^_Xq`vefV`U64akM+|WKYaxyq78Ij@Ld%@owj^=6HrV0@2V~d zCHCQL0x}Oxx_oAseR$oCU|X}$`=L7+cisM={RX9@+dm_Mx}P`F@xNDCRC1E0JVO0wS9Mp9kKs4>HKd)9Z%u zu`!G8Oji0CXHdyL28~ZjZq@*N&B-VUNm+r^{vCpol{#smM<^te)DzVsmMS*f$jS|y zsyTiQ?ZgUIvRU`^J*MkOkHp_N?rlLtCaYigfr$|B+6G_JZz1&29D+*~55a*`hd#sA;cJ&jp|!7_N&Byu z31(39Se_b8`@bz!ymkXipE&kQB3GssiKCtg1EjUg zqVX~HI+u@!P$}%p`&c<>WILsj;BU`{oyW%+r?wyofh5(gk`+kH@dKUIOf^Fi+4vSu z3&bvX&2}X)abc-2alf#=F0V3_m%{07DyKK5qZ;bRBJ9X>W=oP0!HsSNY|Ie2&vtqkmcaVuK$ zcb~H_x$`xjMo**1IE}nU-C+L<6TY!2thEKf;7`CEefZA_d zuJgC^H9e4yJ})Wy`yToRv=_7SEB>)whYd(1;pxQVQr0EzKpOdDJ058l(>W>rQ8OQ@ zC5sjA5+7WkUESUdnkF*NOHm~8ry7Up}S(n(%M|zGjf;wKU%6z2cPgr$fE^**} z?GnFD$k?t5qs5{wIoKbAz4ocELa00PF{`gC>V6&t)UAX~5sA9>x3bwf^O3sT5=32w zs{8~;qoM8ssXS*sQUXp>3ID>?YeU_CbHCo(KMpHj(EoPlBaQw{``>r1N8w<&CjS@b zBgGT7_9+2{k@Jx%#oVn8s9zbW>VW#L9Ip|mPZ*J?p7%W_|Am5y>gK-pgOmW(%tz`l z(*f#H%}4qohyM3G)CraK9Qnom=d2^d-yC9bT7(pU;v`k}7psq8z2;<)G7x+FKW(1^ zJ?~s9^nCp9b^rzU>%D_VEje9>TS3Lz^*X`v#uD6Zx$}M6H$kq@e56+B5Vg%mIx+wZ zba>hX_viBTAdfpd-Ojkf(@z*TJpGPgGau=fo6uLLOJDJ9Wq2~e;A|6EK4h!2{t;c9 z%H=}*YPP1DP=;z@LTTz$6G~C>3}OA_VOE)}e|!aOT_^cs{Ugm#_tCzJ^v9q7khL2&3+edfXme<+7Z7~t*c!4m`r}PEh44EOIY#rxZ@wA$ z?Fx%U<2N_xk6$?q*NO1QSHOKU0-0)pd@>^3AAcbv;8lY^Vo6uPIbM#vfRCkX0 z&4jX*V#w#o*l#g;$_v2cY*=IL`;X8-JsN-fd1O1v@@;~Fpu89N#}3=4Il7#{^LeiR({i*U zPT<{r3pG!U*3+-a|DJ7|Onkv*nxnH@AW3tS^Xzf4Eff-t9xn+I+p!H?>2h=r`j7f> zvF7NnWD)v08xuK~Y;Ga6yhu{m!#+p*vL5?|$kA|AdZ2w3e&&tf=s~z6nxl3yQm#5S z7uP}l#q7MGVJ@8Zad7htM@Oi1`7VWd@r#km5pWp?hXk_KNguGJ91+FQY__HoRw5;g zqukgbzJPDH?6_vaTFuduSE0b*C|)Y*mpgL9#<_1`oO_+7oqM_M&}>d|TksOyEIpFh zoNq{pOx?k_G>eLY6*gN8TI0=I7s0YGMk*ZDdcToc$eMvvDSxe$L|FOP7%8bgNR_x! z5}{O@NY!YFHZ~c_V?#z|ZblMeMmx~egr;{&F%$P=HA9f5!F87GJJJ02(O0@W?JP}< zJZ*163F;gZN>bn5VtIO^NlQ_!`&ph=qKd(Wi`6xl!AVMFs$EDTVsFAgI1&4;#P_R? zlnBJGf6n$7Aa(;@D5I0@`ArbpTO;;kN<^ER)D^nc@$dN@%V7Z9@y-)THsLF0bE<+H zz}I|)Li0Lry8=vfcshx3ho`qP?(no9L9lRaV~RRC%!TfJmLBh)`kC|5mhLOEj3qF%P_wR~OtEcn`W4YRILZD^z( z4PUz;!~ehd`qMMf`5OCc7+?R`WBIxXC-Cm>hoRu`^%*7`L>s<#Jp)N$d>v1r>iPQD z(kgr%{)Xo3V`S9P@%1jWFU!|2kz+Kzt{4oyJ_UCnlCLja%hn&x*HZ>MeEnjX77)xB zz8;3ZWB{D4-de$ux_o_ODN<_T>%#XnUl%QB%lq&0wQng)R6SqWUwM2F5r%sgq*`(Y z`P$4#$&Ev*)CHbI2)sYp_K{by$*aVbk_e?Xh*XVyU0^cWU@|ImGm;21dKgkJUti<8 z1^f1>R=zgwN%tdU;pH^TH))X zNFrZeO_T`4j(*Da7w~n=JmG8cZkMkkDG`mYKfGTfU*9CzLVRtBrXIo9 z$i*>zV2q&@U;`InSf_sfAIC0_YjWcYYw_5`I=1? zAbh>dghr@~O(<8LZ$ddLg(073{4UGa0kgo@AH-;?P#@8{JsQ4lL({E|ui@|CgY!S< zn+f$;><%kczlz87Pj0METh^GhG;uiyE1L=D>vXP5nmkj(HQADp3uG`BJ6CDAn*G*i z?zC_nhZ6|bGhtm2uKTrJn#p7X*K|or{V54a8m`xBp{5iPxN0-iZnfu~ozi*O`Q zrV$yA793-E7ZNTYmbJfQ;|(= zJf%-V$9@cdiyWSkl``ki84d_;&klxmbcX|y+~I%>Jn9RkMG$qpCh9fYHBsMV)aSYE zXG_#pIDt2}9+m=$8mor`etq0Fnc#51v=fn}i8?|PbsdGOH&=VV?hH zq!N0)c*5w<$>yeWgMCd>*wn z1iZ$eHF`EbZV|#`TX$_z9o{9iu$?mB5ofB7Z=wu=@U=-*c4u$LY6dJ95+4SZr8*o( zpB{~phq>`)t-G^NTgZDze04D)Eo+nRcnc|bX0zVLudPK44473#!Ky0~W4SiNb*Pb& zvLctr-PyaDav8t7Ksw!V>(@=YBX67vLB(i8%#!JZblMeMw=idChP5N6M@8Y zu}UV0RqWqpOulGb9de0lueOyo2EI0z0Qs6^LJ8_$11(?cnKbOr-p%rL4=NT9zN6}C zW`ky^?~uf|S&64|x9m!_9&zqo*F(nTW8a%%`wI}evP2NO?FT{Zwi*D~(#wHxCOU(aRS@YTbx z;cF2M7|eg_jb^`_&EE3Wu2Y(ezDd58Pz9jEMyMxDC|f;hLSFTt31zDB3}OD$Hp|zS z9|K>{U(BpA|B2Qt_*(1!?Cp`wzsFbmev0coiw$eS##?Ey&cp!#Hq!;HjJKAUGctf= zZOUT26_VWn+z$fw!N(V@)2#jFJI&f9nzdh-S=PQwS={IiFdxX;2AZ`GI$3lVvZkJM zJR~)1M`_j$p^&h)kt9S6y>6XXg|(N@)~vnjb%zoTYoiRk=Afxr)-FSiRau*(UdRG# zC&I-DXKk+X_a>)8tjz^$55rRm4!tg!uLU#|_0a3KkU+MY^%_g+4h=jx4=Eu$;}w=3 zdfkkwwbtv5H?;No^a2#Px}kyN4Uk3Q7$6HLYaV*NknD8`8#(lPj#$jK5w?zzk{d@2 zv4;l8}as6io?bnZ`Ziv;D zCWQ5$CWQ5${WVOn{?nvk{ig|G{U<`;MW#BI!|@1ZsKI|qQg`(^CKi*lBOybZb`|0z z?Na=r!}Wi}b~uoBz|%t7ap-X{W_xMU_N7EL(yn_$jM)NIe@sl!o@FyA$9ptu&rT!h zgtvv{Z9TO2^83Pg`|E{Zq{G)bs1KK~zwo%j*UuRzU(NXIGRBwb@z?bXoApSi(!2?H zKJO0RPIwhz%Ue6&Gz0yUyiKD@K&@q~vrTA(YGy*Y>I4(YQE?3UJUQQ5-d`JuX+IZ__D*_+$g_V}K#Ohp0F&`Y#)~!s?uV#TLme@NBM3E!0%*k7s zLR=(R9K)E4y=<~=4e1dN+@=_E`&pdTXajgp?g?q@=9KC31o2)#i8!?*+Lm zUytJaOb*VIa2inLsr5v1oSh zuny#LXK85UaeEWO`!5s1`>!i4k55FJu=iHX2Idn_Q87j=O>N$z(=ya9R5uQGSKW-5 zSAB&f61hE6ILfdNagw^u@yI(6yQIMOMUZ*<3?cJ(UkaHo)ntB$646$OwuA0A@3(?n z-hkRFe>cSCL)7oW@$?cfr0Tyl9PRR=0QDdDl1|GICqGXQaP^IubC{wwN4=D*4>=D)Iz(7pS?OeG}ZR1s1T z!2H*LvHCdw^==Ab{_8~Br-0Hsiv^{Re@0r!{8t{0I{)=$Vl=|OEx}!uL-AYt_DvAX zng5CoQS1EIbHT!MfpEjkCb&O$e%C=Bcg7#KGw#^OpD@nx2SD^YhRbyLmrm#_)1|L? zwlX{!Va|UQ+b3-PE4nt@?uE39QBhu%YC@R*YC@R*YC@R*$`IziZnS{ChR_G#WuY^cD9XUoL?fn;nv;$zUU9PluH+NZMJrh8>ZpJ6n^s0Si|hX?IaU`hm%Jc7MwRb&5`E zrXFKbAh!O!wsV5B$N7b`ZO}Vo^77HS8t`Z|&gMgf2JO@m++#VivwZCbhzVbBqnY|a zXYiFfpF-Z*?-a`%j69h5>^Wef!`IgtZx-V1Q;a)&^)c@7brj=3vE}R5@!;z% zFypA<`p~?sg|DNLLpWdiU)|3eIDITK%JR3kqVUJOi*3&MY8 zur06Vuj}<=xAwlu-#sCDZk@4B=ElYsuEY~zyICdr%AdLo#awc#G{tm3d?l9g8KVml zi;h$-sjrU}nPZc1ObveGP^CXZ&6tI!S+v><3>R#p80v5DQ>-n$Uf_Mz&*b#+WO4YH zG|`!LM`r3mbL=%9^SAW|Cd8>}Pomt+?hOk1J7YJ3ykouo`jy#n-Zg-nDZAI7+M4A~ z)Y;WHW&7zxUB^R^_-;j)Ij5Y!&<~F z`AwhsXe*o<@VxMFs~B}T8VBF6_rl8z);av=+3-zVV?}i>EQ_^UPisREu7t7st!l z`&BX=GU~-ltrxo>*?J(H?18TPGv+&My?8%!3&fsIncx5p^s8jM;7Be5&j@#%oJs(+42-k~~d5YGHNmduJBIGo!7c4;nmL%sr&F)I zi~Vo#OG->TNdE)xMUP_wT27qGXHp>cuRCo&f;K$t6K&WGoiZlx5p=0TJUVGLFOF^z zx_qFyqvZK-*}B_vrAw@LN<%;urgWGn|Al!1z2EPkj|yZ}+JTNMQeO(J_2I zvD}1G)SD)htX?spB=sCa*#CRA)rbGWr|i{0=n2+%7y6yG=))n%A(}oMhK!6pyh!w+ zsKbZO)asD!rAV~l=^Ueq)P^Tg8?HkAiZ(R!J^iU0QB123?}Icef*Tz%NhooNe_~ipO7?=`fxOvSF1kkX{7S`tfT0|bL4n6`tUe&FseS>JyT!5#I&M?{I&X6 zBGj5|Am!@Ao`cW?j#?jHahj_Sn?A1f;feCQLp8)N$+0Tk=);4kGN{8wYLZrmzl^lq z2~A9jHCBmSZ2!xvL)*M|?B3LWO?!>Nor z`tV-H9ep^IaYr9!F>dtX5QdFDycJHBI*IrVc&=kO4q@oSsbGA#K3pLl59XIrqoIy6 z)B+PqQFBZvSOlMQ0CUTnA zA9OR!_b0!;#kPm|f`$Uk)QP_ks}o@87Mbr)zD*(FYSiyfUND(l4cpXc&I9CXh59(4 zdo1lCa@CH%McLG7A)1io>Pg5k+W6by6ma!Rj6g+>zimGo*8x|@5IJe^tq0HvwA4*3 z!qG6Uj@N!hmG4iUjnmZGkKpRHjlcajzdu>{FiW3U@)*%6n;H%E>wfJganS&z{=h1; z{abL*@;*9bIKIKuZ<$LRiI6x~8!7hMXzw7><#>%FV<#Aqs3T*4un(XV3zmA^#-aPbwYwJqobOLgN4t&q{^SEEfmsgkrZVpE?q0?n-VJ5k86V4H+>DP6 zVVL7%;M^-TNwEJf+$Po7k1%X>*$1VnTje{4cTFf+y=Fpb>O~VuQBO1E z^Xz=bGVh~dVBXc#?WlbZokQer_cIy|>6-U5(&J&nkV%yBu)-6y1F%_;DjvX6f;`d# zh&mp&5k(Bz|L~7kzJOtK?A?z2Z;su8V+#9Mb3Cl@p^*Jw&bEts-1cyo{cmzwIyT(? zM`r3AbL=@Dv-W=h%1!%!3A3wdJnU4Io0AIR{IJMvc*D4SU&$=?x0J0{X#ClJtrXdfM;qRT!0KT3j01Sa@?zqx(FwipHTg{ z*l9f8)*g=-4|DYw2gInR@J$j9EBQm)H*>G5p+jvCj4x;hwSy^6li$?(E16NO|5_ya z>yKVVo9sy0l{krw_fI%6RAIyQNZBb)UgJfDr7y$E06kJRo4EyI_uXhUSQn9aONbi$ zetg~}*E1kY)iz*(7i&N^TLL>8EXo_CU(qeB2J4F)qiL{6gmzu42D=@jSR9lRt?++*gS09?tbD;Y zNZgCtzCl`v0a=d6uXzxKgPKl`_OAXoQ>Z=CZ}jlpQM^GKTIf6_=*h@;_5Dc2TJ>bA zk&+rgE|Kr*8_V$;_2e&)@

    Y{k08Wt&M;1wNxDS<^~f=P#>C5lFHIf!`s)}-U@yB&KS{`Tiy_Td8g>h z^fxJC^`$$G)&`bbb@~!Mw|&2~4`Sj!WFN+O+OV^rE-ynUIG)BPP>%1>hTbn-(il3= z(U*M~cl6~&j63?W1>@A0=6!!7#=q5LXs0v0L5JJGzfzl||9H+|crC&Jav$i3aQ|T< zx;xwRIPr9;OGlefh8k)@X=)T<&S|)g zOW#xAQU?8pFYd?DX!Nb(Km4487W4B2T>XFPKlHedrBBR#Fz7$Dn5g^x<>a!}UQzsq z&UCbD&b+>ye= zwF`uY#($VY3Cly*e>e>^sg8$^|F9imj{ndf?KZ-HxFinDa{Pxrj5|EMh;fI9Ef{xr z*oblCKb+36@gHuX;S%t)fV-vEKY(zU|KLX_qgCX?FQ2$q-D5(@>UI-KQ^QOsMGa!e z=b1O(GVhUrU|u3E0M!29VmXKWhg3+{>_3E$mzejjCnL}5-oKvzO4xXFa~33g2Izqt zZB>>)xf5*W{p(63Td5cFON4jCRgoK0zD(&zy2+jY;Esf zzcf<$d}7EY^8M>#IbO|p^Hb(vCZA&D`_~C3XK4#S??PU|qE{kB?*K@-si37fW zy^lwu4LJV>9a_Wt*Hs`>XuLTc&A+zyugBv)-0|kK7|0~aG>AlXCGsH zf%)Fjmvb~)&G(kpyi^6P&)_6#iyp8ah}I9ZGd|qOD^A?;^oE-(TFv*Cx>82a8ufci ztL|{ox&iH8rH#;N%^}pR$>W%eDZ!o*96j|+JQPIh^T@HP$(X5%P5@eOg6R?NuzS^* z1YF0Oj9i2NBRnsI)-*NyP9C)jNAox)owzO}kfA1xWij3FEls=wDIppMeQ5W4OB2Rx z+WGEc8~X2lZ|O|Z)>a%i75TlTcv=HE&f4a!mASN$2x(JJ;}=rJMykY>k_e?%iBydi zV~G)oYBBoERW#(P8*v^2DIs5`_N1p~I^+{SP@8Dc#+!dS(j4~UQq&1~_on>rQ1e(v zi2IhYu86r=Qfo99Ug6Okj^6ik?N*4Z^QxT^|!lQ$0<{ ztJwc|G*fk8$mj9RwyeAHDzI)huYubBf>tE*5BpehmG3Q8pnXPuZ>j(A_=-}@!SwA) z_WD+&pc%x(x31SRzBR@q$2M7U6XNRT>yKbiARj?=-$Ur94_$(05=cF+5-lJr&}#9O zT=;Ww%a}auM;g2B*>*AhjKa!^O}&0Um1eIZh0cFB&S{THmFv`&FY(BWw)JRVDg$5d z@tR)$Qi`fauRk7P%oOb8Tp{E87cs(!kTCFo8$P9XF9SWwL3I2I-F7GVlyAn|PE zU#v^f6{Q%&Qlu6BIWgTxXZfcw$M$%65!(lkG)or_B|DaP8TQpEq*0k+_{l*8tw%(lA|`>%6mxMbw_Z_;kDZ|E5E$msYU1!v%f&F z>ejGVqn68f8Pvia{#vV5BGeGi8!5Rca>>@S7WMt%_#|^Y-{ey4<{}a1GDxJVv8^vL zS(KVAHn>?xgjpm(N|eYTw(&sX+Ka-JNIp&?x!E_O>5*p+G>-}LTa6r}#~+5`mt-5n zU(q8?z+i?FR8NzZq}Kna(~{MRi?kf}ca4QYGc+j_?S#Fl0 z+0-OT=<=bBhl*G}*PZ~n8%tFZWGT>RX zA3DL&C+iq@^vN5HJNo2l#+~)71&nh&E0oC$hPP<_vTY0-wCCx1Xxu$+V+V8JW7b9Y zqnHeZDr3p<(l+xM6+LOS|5 zL}=(ncpdTn>p$h=)n5A$gM7SqW*8rDeL9?v-EanpwG-Ze!^cKWMuv~CuZ`s6j-EC0 zam4T{eEedt=HuTZ*$R(}k3XQ{SUz5c9Ha5^y!zl{1KdF*9}{EQw!``O5d5jzAgymwbGE81EtRlTkrFPPs+%aWTnhYcUERUq-*IosW}@R0;7Dg^xFw zu zOGEqaEG>?9_Fk^X7e1b2(y$-PPv9NWlGUoWS*Kj~|1LtbJg0t7q{JTVZo3xv`1jSq z$J5cbLVP?xiD-Ph9V)dpK6VC~96ruJwhAAg_zg^R`1lIr4j&(9+~MPWj5~b1iE+cn zu?!nNuB6cs@Z1LzQMI~-9n9t9c62}T@f-0I$;XW*l&030P^MaLLK*5!hJ2p7Pg*|y z&<%VXJ&O5OsH@F5u;pVRr2i8>W>AB|K-AWv-A{#kqfF)z*cE9!JYFK^gQvyjNCuDO zBSM=qIV<9e0VkrkVP6dRNUWsT4%0M7mof_eKf(KJ1LOV}oWNWAC$u{OdW@b+@Nrk$ zT;dCQh&h=$W)-Gj=;?67w1N2&g~Y&YEC~_YR-JPL>t3&<($lcoyj^yy=h3n(Kx2`k0jP94J?xvKcGm$w*J4aq19XhxW3Jj%c^Hkujy~uw z2K0beU<5{}x;LUA5Ln2rZFaP76B5AwkvFlV?zUBBxkw2y7sC^J+p14dwe}VN)|*MY z9qPv$QD6*DU|58v=%d<_HdbhTV}(j39R0Rc`2;GkDW`?78LY4|w19DZkD-+q@s?H+ zVYT))QgY*{0AZVzk_e?*8mVHFR|$Wultd_Xgxv$sso}NPHzHEon919a5`>PCr=K_@ zEexTVI^0T2dF!HjF2_>lgQgNIHx1fQwC%2ol6!q6{nxSdxQ@hswzTj6 z8UIAvou@Ngs_o8OXsqD<*FkV~{ZNGMz9@FTs>$e>Y~%SfN>NGK>TVMnp+=cduDa2L za#RjOKF{2#7Of9o0<@lRGqbKx2Wgl_4sER3c^uQ;=AV}!u`dE++*2_Z>X^4)f6dd#3BZ z%W2wwAEBBILJ_eO>5U{dm6fWv4k`FOg`jspo2xzVVAa)U->en1+t|P%B^L#*BX?k3 zX^z*7*r!FRM#PRc8Euf7D`;89U(0HV@Ok%zlpuCA+e9F-HLF3LTT!yRT{b29}sE8>yMlC2CP{U z$M*sdN4N7_WV;LSnt8e4H5XkD#%o_V_b_8RQz9B(-+%^o-k+7?=E}ba@zqDN319u> z>+gpSSC&r-J3#Q&*$$9761H3`*OIu(WJ-x)7uXV;o?+WT ze8E?myw^_FwgsBJ>nSAU z<@z~(O@N&~xFO(`*SO@3!6CIYOOtmyX@cIaAyMOofNRn8EP2mGj)uHt?0(v?#rLZA zgS-{+a7bP=4q%Pm1HWtdmhc3zPy^|=z=;eRzvm1T5HKBQ zs`MNb1Mt-d(SxTWNYYZdMx3nS_8R!=G!0)lAsoJId5VT_whLc5O~ZG*ntnBk7)X3= za1g$C4nztb+f&y%6$xyP(eO=UYaquS5z9Ja2*%P*Ok+yjWTfPx$R%<^!0zUF2@7l8 z0GrD~NklGZ7^!?CRm@*2B@tfh0DBr9eVLKk<4Q?{QlCLe_**Dk1Bbuv8svgqtlv}F%IFOD|irOm`%kQ>~ z`&45Z`(K;1Oyzq~%X!s0q|wst11WmY?@GKvO)Y^$AoiafZ9f8%7xWM$uYXvOe5pqA zTuMaS5AaN=_{i~u4XCX0B_S^Fq!}Pw9!)L}{u5jt8ph?zegI3I@qvMiJNp54Wqeb} z&TY%Mvmf9|jK8Jr-c}6H)pqY4G=c)2wiW0PU$8$!a=94&mRz1p)qyGbjm9t`A+KnLy&Q zw@Nq14TL7a20Q*pXjBW=PmyEQVb^T6crW1kINTg<*5(>;=BQ^YG+Fa;aZA>CxR*vC zQ?2jAK4AA^&4Z!}B>oQH$q0DW{QfMd`@PnGW+Np8V~iRo zivnZR03L@PHIN%NqXz%s_gZ_Cw0Q246-a0n&;={(B6hf1>2;EkDq+o3%gbNcwvku9 zkrG5!;pJM9s%FS_p2?!rWI;Xzkt-3xv=CAP(_9VH1zgi)jaf6Vfqf&|ctPW>?s&mB zQa!}zMiavKuS^Kvzxqo9HCerB(o)nbCWP-_Aw=V~C&)-*PLcS2b;?I#yymyFodTrv zWeO?hpkv|T57DH2fD+L@(DKIslCrxq-+|Aoya`BU<~yt+p@fsO$;pmr(&aP5IC;i* zU|Ta>$oTv18F%d2(-?Q`*}9B7_Ux{25vM&1DE`eb*9TzULob>v0Z-juz{v&u5VoAO z;{zkm15^lg^_%MAgyh}sT@oIP$%7QWo1TZ)|9+(Y;1aegmegOuU9l@d7TsF3D zmm?(%vvIhA_<~;?%y#LkG28PBHq0!14Ax*)?%80rIiC(JU!A6{T)A^txp*o(M6yKg zRJ2`6WU4RZ?FZ}ZbM)vShH+~N%)_ElBCOd3Myh7|J#3^($i`}6e1nn7H&W4I+}TK# z8L2(|wdIls%asTz;jQ$HK;qR+!;II^OJQU8MdR*_Ewo=pQXK*caq0#WN>Bq#C`mPj zUB{!zsvFV}I9EM&k3Jzyr5UjdwfQNXmZ_SVG_RVyS{t?5Dh_GHaxqefdE(8@c?C zo!~Mz3bgip!1K_TV5wuj&SKoLUms-Lv0q0r?%1#W88`OpFouo&`Z}$hfM?{7;Bw-X z2uE^x15^gP%37)p)NQVM&xFRSw@he^`lktvP$dlE`?vR5E`OQ=E??V+Sy!m8v~G`v z%L9>3$bL2JpOI6v_0O9zZwn>dEbN!{&rNx`qg(%sat7Bw!&hP<14fC&c5>D~n`3w2 zn990LuYc}^x0q%>z~K7l-XT`LuezC>mSzYp?S6nAk(oNj9D9z(?E2@PC^zVR6ziW+ zZUFEwToD$zji^+tf0oQ*>)wl_Rn|Wnne#-Z>iXwgTszQs?J3Us=P!^u)<0j!_0MP= zc8Xh+_0KrD#`VuUUfud}BBP8C-AW9iqGQ+ut5vk!jZ`VsU6k>mmgaZ~ zk5{W=k6fj%m2ae?tJp0@s?115SFvwE${ioN3=59_t?{AsjnuCVrJZ4X=okr5(H@W* zgL`)cVjpR4`w`S@paU-G^DG!E>h)5sUMEu`ntH7SacdhN`k3}+Xng2m^n-}; zp|dwYCp!AI6XTA4ZO*u(UmG&+=-1yrMcnAuSROO_wGVUz5ZVxKl6sr{!Rl8#Za)V7 zmfCBCs4R{TU1vhMs=o>4sNN=&tuh(%d5ZI_e!cxH=+}e14BGh*@=oq3#_j(?Qw{1@ z%=3bNp##mwjw0y(qltfiM*C9rO@C;;%TRo6$6)6reM)`IkXBj#7wWTh za-ZIuF8LTN04e{@Yu+XPy}Xv)SgOO9u*|FDhQLpC%7U`FF#*JFO=S9|8MW0F@-^&q9b}uX)`w}jJTpmc~kzRqzkkgvH z#z@qeyaiEn?tb+$&*Oai_=083&fl?R`L$A>3CZ3-k2Ks>f}9TRtxq3oPvq z&#a=K$`8V6$2|64=;F8mj0dt7O6@KBUhPE$6`$wz7VRv@elxgiCayaHm+gV8j@9S(vPFL1o=a2x zZA9c@^v7*pQS?VS)&rm|O~ko9)9`rhxjprD9}1mYsqT^Mev=p1tLXdky|BdT+MyHN zgF@pG`3K6$O}yrL$&=~9b5JF5QhIfP$>LOR(cqSGY z6;-b-GUZWVzFf127L zX6grCKTsg~#|HDC$2_IK=Zy;G9dGh}n0W^p=RmyNxe{h?dMJ|mg@ zctYO5U`&N7TKOKc#>G$mh(_1<-oPl#k(rH3?B&0L&)K`=n~saVd~j>iZdo{#oE6AJ z+Y04hwAs7l)BXLnzxed(Wbeu&CwN=`%UiUESH|C!2QEbc>U&$i@4e+S#X+Ceo7K-> zqo#|#&niOKR;`I>5Gt(~UKsig#K%8;Ao~Mg3|pomari1SD|81fO-|R~WKT zacOwO_y`cwGB{>}Yq}pkc(ju?KhnINzSkQoBXf}D1u9r}rmRjCIz3s^A2sROUa%~e z5KQ#~W4Uthb{yP!x{R9=bqQTQ#2+kA0&v%KZy6`gd(vt?)vTg2r*orUQo9s>CP#iL z|5@ObFY9Fy++A5+{#;XU?D!to@ck@Zw+To&Chw#k zMU`FS7x(XcWO&!2{uxK4Tr4aq2{0+o$5rh7FTC{N9V-;i1u+;l=%+ea9ZRVlAGhTDTt=#CkCQ3VEfA`|D90 zzv$tUa16cc53{*_AThfUR%W4Z6(?!uDDMndAWKKIi}A-4mQHNqE&2+$JHH{9hpADo z!XRAZV}|@UXq9ty>I-xI&v^Z`;Pp2^6a}m1`Uj9Tub<#vzjMU(Kfp3QTz}UBxjr-G zzbe;v>=E3#Z&ynr@O`FaN`YF1t>_O~@&K zJlI-rt>hWI>Ws7)zxUk2b@2sWowE1zG>Ei-i0~+om=?Nhb6mD)II04(G3rb_se930 zTzEPzyaMOOsB18ScZL5oUag0JLPxb3Dx*uMHSq<7NTKdPiH_&(u_)aB6WLva?8;Md zy6$&@#5$-^Jcm!QSd5Dre@L{?AsNlJ5u|+?xU_DqOCY2#-S*It%KW9&k1=^&{XW`b zUO$#omewhfNYOD^+Q`Sl_6Z|HfAAsLz+pxtIixA}_ZwgM+1Pkwf!7J$67Y=+n49?N zhC*a!k}R-X_@}T`e&Y*2!tJbh75AZ%e@7?QX5o6oagWyw(^Xb)V&)3GB;d0=5qF8Y z8_6YcuU-5%RL;e)KVc|8#VnSC;H)q6d5u5uc@1cV3vmfkgM0w>;-}<6*yh+k=Xfr2 z9OCA96>}UJEyse6I8zM7Mgw3G1(uhHRF4>yhvBp}J>n2$bKb&V{6nxz0urP(!++j2JhY89ZG*h=U&%DhlEQ9!cmhYYGoAhJVpcDnq*34SxsHneG2n&0+PRpmpoD zi}|p}n3y$%WD2|9hlLz^Kps8#Jl?D?t!_+??){@qG_7uI4>~D@7s}9ZrmcRj-!~KI zng;iwZ!RKrylY|(A>a6d6|f=8$Ky|k*k}ZOh7ut?z}omJe?gv$a7o+-$D$<^m8)Kb z=p_m#yj*@ik&PL|t+b}et{oDK%uc1&eV=qO{ zGnq3UnQCJ6RCDBgqRD$AJ`(_kIenyLTE1xq7bIuKSUa(NJC+UOKK&1qu$+8ez zu{ZQ@2ek!l5dgxAdMfXlp3;ugm`t{i`!dyjj>ZR;mOy?``PVRAL(dQApM~?UhMQgG z{4_a#LZ(_Q=P&2^>S>$~w7~X97)Ry;<_L=_e21VN#Ds zyd@LMxY^`F-b4L%v`XxUAtfmfY~#iLfe%S=^p2g$8!&TOLB*8dFlm__fr&T?O zY8p=!4GzJ;Gb*w@UKVjWb+t+Upg~M>IxG|P~A)@PIWS&WYvx#pJ!sO z9T2>(F$M(7C11>Eg$iV@4Is613oo*Qe-`r3^ZYZNe;($aB|$!MXLWpk>yJiJ-?t^A z_;kUCvkB-gj?ClLj_Q5e4Jf94-_~#~dk^*xkc=wSi`ezU4n;ID$Lipi`nHX{Z%agf zg&*Qt0_qN-f?hTDzWN+0hdB=7{vkyb_I=yxHSlT{n`4*qn0eoJ;<=Eg`B&@rw_dqE z^u3XXksYrx%;dQH7nD1h9Uzdt5}JU=dYNMzaSSyR`TecqfJY3D`09jSwl!LUTmzn# z%`iCfG0Y75ml5CB!hBFrsiyCZyustOeQ(6@{p5zW*TDWJ(EYKU2Ziyy?R8c7UI!i7~elSE|izy`|X%p9me;UC{sP(&uLwS@6&(Pd|yUV9v$DGN1wKQk428r_`Z7` z_`ViSZY19~t%=~f_d|#8$F?D_9loc9jwUH}F3afh{pS?QC)P;|@_jXASb4iro%@Nx z_iv>;)yDTlB2^>brx}r`e81ZqjLP?crU*6jy#u6NzSrf>EB_YX-(Ez%`|*Iucc1+3 zQ1|hHBYqdGKJa~1oNZm;`@|hc^LeJAscOF8#-q{r{!^Oe`^W8FzI#5Z%J;KT4wvtp z7DC8uEP{el_1mn^1xpYC>^ppa~_b zs~E!mx7S*}KTschZ-9Ga4ejls`Q92*N6mM@J#nqfP(4(P>TQe+*)e4ZCIdc{9fF~0 z>;1bq?d5mzBtGDJiW!p8HEPWXDc{UEL zLY9~1^!@585Fbb`Y^N>9F-W#n=p#583Ox}M$2D1|F*oRc$_QBoh=ksG7mW#vXt<+wH&8?0J7W$^lP$Y zngc27-c_0`xkN+?s`b~EL9(Q&`K?F_yK#fw_3ZPIK$7wkC1G$WYROX)UuYYI%gvDC zElp|d+!EkortSvsVv}tp_v`D zAHgD=`4`(SN>O6+U&vpZzeFhYIi!RyCu{rhQ!Foy&KI`9X!hgPZ;&r-@tDb%7V?Yl z-|?{{ej*18VPnOq2GS5PbgWja$6#L|_CQ_R?!cUe+l4tz(Kll9rlJWR5n+XAuf^|AIWO2uSpY z1Ts}OQbPy?Cp44Ku}d;fNgR9*Il^00XF`U*JqacBP`M>=#Oy~EypIcUA3V-_;6=;$ zYkROn*n^uGsbV8l;z~(`QafpfqeYGhQqX3UPkD;0H6p-=d57b;s`KPvZ3a^zq=Y6J zY-WMPS${e-k$zSEzJ`ro4V(Xux}gj7IqL{@^|90yIWlP-=z%*)P>W4klJY#IDU*!v z$FjL#{EI1p*y)uRuaprMFy`g0!kEQq-Wct^1Kk zc-7ivK+qhhaE+i`b0Ay2wuA_>#tIiL1=5q>btts88IclN?nDa3h6J#G&Y3J}f39~B z3hhu!oAQ*z&CN+6SyexaGPtXis>Dbw z`F<5QkRNUH8xLklSQe?VuPE7M3}{4G;RUWrSe1)Q+^8r5qmt_ zY&3hO@Dww=Z1{K3u(IMHq( zS`aq@X#}H)xUNUzNRV`pLjwq9s68f>t$sEkulklDpXb~wERq`Hp4Ai0nRSJFpriaU z<2NC=^9x>Y8UM&?qh}eK%F9n;XfeleFa^WEcqZCHFT5`BpN#n?@spRcX#fwC&%mS3 zUojt1RPyuq>zg>fPJF?W=6Jyz2K-al0JHo(@d9GEKdFkd0w=%BtbT-a7Ali*OgE4;*pj<|@Kxq;&{TdpgQn*&MaH(CGkZ%}@fGd^5&tjT@sY%JC)w(nO^YSxO^ zf5{cRxc|6b{yr(*I)8cVeALU|E2E3=p7C{9NAZQ5(K>qhC*_MYX1^TZ)I6_$VoI-~ zgkD8hqtoetH@+u^`7sA?qqpc_`FxxZ8V?PBKSEyvmAiR=JJ6~ce|K-sFn@PjZ#1Rw z4=5~_(=px)tHkkl^O0<|gz4#x+s2@7x zF%$9~cdfRyX+rYnagwfMWIKj-?pJ5e_@ptiG)P*>kbUD5uWy2SdsYfM^_ zdWPG0N#A-?&Z|_N{p`50FYK|65{y~Q{X~48HE7-;e|I(|qWQb0p6dF$hY)l8-BD;h z5&rHq&xZ5l7RDW(T+TRoV(iJTjGq*Ww`9DY=1n@o#^0TE3R`f9Hx=qNv~LpPW&HB4 zGu1ODl%b}XP?{<-p%gWdA)n{du9i2iR)9C1l9+FWI!jE|3N;W?|0!=|cmv~WV`!%o z1=rKfm+g``lOY8M$IC&C($n89K}4(o9LPtQW{vD-H&>)E`xFNz%Ym$x$vAki7YW7Y zAQWEgx?k<1jV~BR&($CM>m?do*D&hyZ0*7urhmMgvbfh_U@DO{L;J@MIa%x#=Qp+O z?U2;|@c~JRy@5i4EN+Ft?Lg=X(my7O)DMmLFsy$pNmqS_c805sBP?*Q+I0-=ayKHV zhLd?e?0bVx3n8l%IT~b1&(}kAUNv_CkmZ9`*T@qG3X!PLmAxF^W>SmD^Sa9 zSrojLspu&|s^OwByhjTgiSUL;8Yw9fq)J&dD`^57*@@Ot!*PI*w&-jK|`K$`PEjQJ@-G70Kt`HLJ8`46T<#SCX}p}ysfd8 zqV}MI(W^65&(5rAy3pV0q>EMm7CI?YUHg#Mi|^wQjgP0WnHHh&I5*V_#LnAkdk4Vx z9yj{%dH#j&0q|uAV^UwCM6@00l25_}h=#Pk#h?BQQ`Xe|XnW<@b;j|hhtCS<*FB7r zUxsgk7#@jN`U{YE*@?`$LY>!2e(6sSh2T;6(-H3z!g*)M_qx0LBRjy8 z{fvk%i?Mu!gS&IgWLv`#GVPCYZIQvx*0bPlB69q(i5F?GUCpS^6Dzkxu>FV=ct?-I z2q4(Z_wE)j*<`Uj1{1>jy@hrF@Jytk&t9zVzJN7MgQXFYx}(mgW8oC(br^L|dKF9}4`O%! zY}+sB74xCcD*=4~^fLQt?xaLCdfgZgv#nTNo`8oX`~qPs)iN}(ax@l)UoTAua~yl@ zUB(@I>}kdwo;}XE!?Qfb$usb)kl`(wUmF{(Ec&*F(oM>k4(7yu_1%#yJrDzw*o2Ys8m@(fWsBrFLoqlg=#qqyHT2#6yD1p4>= zp1QpxijV%@f8IBrPx{`fTXpKxsZ*y;ovJ!zx8Wuh`#q=>?ZsNT{WLN6>U>CCti8@Opy7`cc(GdjhFJRo9p--* zYs;Nfzc1G2I;nnNtWA_uzbn@K4xrx`Yo{PpvcA@Rb33s{JNUun+M?QIeQmn5J@mEP z=MM`rLWyG34DaN0{cuAb)g;VL*i579gQeT zy!*t67_|>Um=bSiPd1$UmoH+h4T;yiNhIEJ=pG4uZ4XoYmc*NM2=uk94@D~`^tHFZ zdmZ$(`WncnB>DC_!%6b(Ifj$u+dmmj($_)^JNnvOzB~Hb7tj-aCGRrCkc0IPnqN@= zvG!gHWW0^EcQ|iY|8U;0{=qk_f1DeWcZZ_3_PnkHjr9*Pxrw}6f`orS-r=CaH!+=! zmmjTzO=awZT5OWpt8bQaDA;#?MnLj+%Nf}e48Y`_mr$W&o9!CTkKh5Z?ZccJON z4`~oX{&yMPC!mzosu(V7FwOcFZzHCagtzh|1^xi_D$^aklx1_zD^;ah5B?wv{hJr*2%8u24vR_cN@OhpSZCTv)=u_${jw1z_5=V zE`(w>O2 zB5R>sB<$rlf%q!YQni`slmkOJI)M9Z1rGika7qlS!*T1d>;=rh=bh6kH}jzacjEFcou!+~rGJ^|St@TpO1>{6(%O#|?+6M7Ko z?!f;TBNgfX3cuF7_r9+H|4*7w;YI>Bi?<>c@UeZpi_rb$_Z9X+cYL$Qv49HFLe4XS z4lf~^bhyKT4^LyH!)XdrEp)9wDn4Ruf)29?=_o>4DN|0gTmFu~a-K57lGa+SKFEWP zm51>7YWOj!h3>}p*x9Xiryxy!8iUhY!5NVRrx{u7D+%W# z2aayesTP_YQf6J)oz(wc_-a^=ZuZaf6|MDY1J~+Ccmja?jAppvKz|62Wl@&<^UXln z@CI~KzWa?Ol*0b5ZF*ReK=`5lX7CBb8sR&U37!>-aM)oy>a)QPZb{K+z8aUTp&TiB zFb=k2dDsYJ(2nlvUzDnaPvr-z_-ZWfBl8eEC~Zs41qA6c+Wh8H;)g!fWh0ZgkHo{T zl{P^D$*a|ED>7kG{KpNLGx^Q3fG=3&s_^?w_psB>a+R8cr+UpiZ}^9*qEf}3p5UGo zI&%2fGeXzA@AQd|0IV(Vp2!1o!^%D7SXqA%AU#9vzw=l}aBYd-e2%sE_SqGgfv2RCP|jU$MC>b>=!=dU8LfYW-^$J-R_>h;$<1fNwf+{SPB;R8+&|3ADAnI zUfRG9F0sxn@RIjNA%VSc&)yh{1|!hUk+DMcdF0f*U20J ztm18}68t(ES?nL9dvSCVi5)l|2ToT9P7!wznC@j*Sro~2go5)_5}YFl=NZDuKw<~Z zo_7>JO_)0qpDLWJ1f1Jqa6X{KwTee4!Fd~5>}v^Us2s!OcvJk61LqD0&IpCiX)!qW zD>z3a!I?!kM-fiGgHK$rEkQ+PkbO}Nvg8F{QL|P<%TK8}4*ng!uI$Q~yL|wR#Wec7 z`Qbl2%F5wgtDnQ&6G1zrNX~_8Aq!lOQ`L~duFys;bTfiv`vyj6q0!POvU0%C7%MK= zn482xr-B^QPZhpSFEw3g>8hS(#ujxno$ji@Ize1+3Eu1Sq;#0QPpCe{T@O~)FYhq2 z&??V$=~`)<-|Dpp$5+S8Q|25fx{_6vEob=WnPRO{xw;M0KcW1%ei+1y@v>U zMxYCot_Q$Z0oPMrW^D3Yenp=s`p!jLfkbd^LF7|umQvDXQhIEB7+x1YC9fN)ku6qD=snPz;_85qdvM>_{zfxci=yeHrV}@rh#acOFwG|rYgp_6j%bNI3kZPsB0iul zkKxyEiU0!zP6npv;?=0H-w@%#Jv7@naHEgvka-m+fXGLjqV~{`ygw@PjzJcX_kA?1 z2ul-^R0+(;2cS-$#>g|+X&&ECg79N)5?!ty@9rW;)BzhMF~Q+A&Bz#8ik}V;2V13Q zg2~oSIU2|f6?NfB3c@ljdw2tp>yQOs`V#GvEDCL3{=fakB9&&Fq$xofzd0iSP6J0_ zRhSL?65dd~^G~Kz103fkaqMe<+8Z_d+7Io*V@Vxi*tqCuYq16oPI?6obB=2FM(_Z| zCcgf?Fc)nOR=5K69FHvta$=m)^y(vXU3|Jgv7w;(@Hf?S6VA$FrNlk{om^MB{Rs|! z`OJ$cVd){^X#0YFkX9z#jbWG1P}}i9FbrJas2WbsnzI=+3xm`LtK3z&$(0N3l*+C6 zxkKf?drT^~8IRwn+@f=nDrbNI@ygwGgsR+ms0=GN^$qp>1(jswjJH|212~}Cu5zP( z`Hjlm3W**+%HIsG1q**}|LbE^@Co4-@;1t-Ls^Px5~ImUXvRq=Q4~Pn@2cu)sxDv^ zz5#^5rx%KCby!X$sMzm)Pz*dt!UcnkfUD$9}l{6C95O5CRH; z=cM0E=zTIm?lGt=P$`4Bz-Wtst=l&zg6KslRVO=HJR`(Q2DqSMG+{cL})8IKOSd-Tk*I>J!%k%LV374QDZ1B?z>P-shRB!e^S-MFTOyURCRk{ z0w3oS>Fkl)01Ndv6cup3M9u(-?fYKFkA)xX-}777Kgy}eHe6T1=eNAJ0&Q>?Rs<7s z3yx3RM+XGHc~b^83JF|3ZuX511-BNzgIIgB3v=fd_bR;e4~ZLpGx4)byhtT}D3&<5 zHhoQPlFOS~DbMOQ1JqkqNpP5Q?Iz0>*WzJYZF{4?mHx@3^dnXJu}nV->65_2{;cY= z04yZ_00&Fr!ck$AA^rg0#B9Jm4>AEF4f0zz+9b>FZ?)RhTKz^n7)`0b?dS(mDh}Z? zqNW!$<4t^+urjN3AZ^bB!B-98+ue9eLZH?&+;h3#`b(zVK##NXr|NXM$5{kDCK$MF z`)7M91e2V~_ZjQxuxiQ$bXHZFtJM#8RS(P5jREPN=Cm}lP0W`{lK%zFEIw;JH7<{J z_-jhBgXRb6|!sCN;Ro$}_9nk2-$3n7HZZ*Sv>ekXcc`WC{2r|wLa|Ou=^4IS3UsgG+ z<6Sp`@-V})ZeaxZFvBAyF@MeQHS*41Gdxz_`D=#h=*I~17n25g=WoMJ_+kHPkKdh$ zt=#HVzSikq+0sV#PXFO9kI@J*v--a$QpbUk!Dd1uC+!!-ka4cZX!GpeRI2GMo|$dc zhr3*N<%!#aXgta*>Y1$CmppfL&8+v_uwe-wWL{1R9b`?n=fd zg(+H+!+-7Y{T`exN&Y^kL%0ayEBSl>4&N{9@co7k;dwu|&wnNQb~3!XJA9wtA^d2E z@RJ?FMIGREgnz^O_T?EJ!q0RFzuqAn=@3qNy*<1h9m4q?!q?#fs^t1k>JYxGL-<~t z*-uWtb!YqV?hfJl4&kmH%0Hn)__z+`_398lszdrd9m1&{(s%6;&gu~E2=DL?-#ey1 zy2JNVI)u;Y5dNY=`+Tu3iC%x&|Emol0$~>O{|fo1>`@q13pfuoll;HV!g9=S`G4J; z=#QMEzn>%&vG06ig&TuJ#Z+JZR=;swZn`hHPn&YSZuY}VO64h9z1LOU#c$#Z;{3+A z^#09hr*d$}H&QlQuw{4t6_{=Mj_>+o!_<+UejZgMp zF~E_k=GB=i3y{R#gK@>rTu4~?5pt+_IKj0)tIx`b|PB@34x*5DHx=?prl z#bULie*lkIcAP(R(lnPL%~dQH>m2C{ggG(Ot`hJ+RNzGZO>o=V3n}Q+HU^8MIOXgqM<(PfMT~% ze?ct|QJ!9}X9}FINZ!lTJ2u`NtUYJQG#I#}!z8s@r4#*slfUDxtS;&4H#_({-VSM? zLjZu#|C_(#wMZKGcl-+T{V9LP;aGOE(o_V6Q{=8?R5zJ34h1)5_zMxfdJX<&-gnY&OFk2L|-51fcQW1cbwwDbo?Ff z+@a8_Pxw2o#d=iyybXk3lKlFAh~JN5#eS3DqfjjWAiuwlq;Y<4VZJ}b?{j0>$?w$& z{5gIf5z9_~_eu6Y#P7$&^2vM(fj`0TUv7)nc)R@p0)K+vpGxG7+7BY|XZihl=1K7T z2nWRf5x@6vU^@Js>cDKz?=ntfj6FiflumCMn2r$=1NB6_!#vKJ*OBlMh#~ohilcS2 z*W8}a3@~hB^&s6Uj~c_%G4sVh5|rs8_gT8(pS--?GbTHj(g;eUM4#DxFxc|-%8HJVK>(mkNY35abR~LY^&R*iiH31XKoQANz;a0mp$P- zC?H_$#b}Xa{j+g;T>tz%|KoRb$YvyGqh`|HZMitaEQCxDy%+S%QZ>GCdV-z<4_EZ; zE-Zrp=)| zaQgQ96j{KpOTGbpPgOO3<#1_vhC3^mX6yhv>VqL$UJs%(v zyfn4H=R*M=f*gsPK!|hFB_Mrbu-S8S1vX}hBY-I{0=Zb`J=1~lfb!&vKosDgMZ7rI zggDb;h4Cl&BBY=S@ivoT=o`Z;Lf+et^*h`T0(8B=HgP|Q0{Ks*jolvNP}dcS0^ykPE0E?SL0CiA#^35R%s$Zb0dqo_mgA}4?C!j{{lM#sP9K8TBcBcsH z??L?&cZvvD@`wGSh=Am)M?eT1@K@KwNRqcD3Fok6J9`y_(BvJp1X~L`P8_)x6;r}# zD7HU}OM{NrKxA3SlDJA`zWmk9|1WU z?xD;mOEqWzJk;?SXbg7MIr%5&9S8T*8xK7T8y9}4oZ&(LqY~rc#TZm$`u#Q!zYdwV zvK&Q_hhIa0n#}^G@^F6-YUUO1s{dXWVQJIL80S~LAs zzmLZJiEhu)Ct-=5(hZH*f-8oGjPQ&%^q$QnN0e$kMEb&|Lr;7MD7m8pCN30B8&}+( zpf?OEA3mncTQX5;t=^&7PDigx@#5)VL(0xqtUzL{k$qp;7`&+)n0cDDz?+ za8M?}uwJD`|Fq`*oy(Ymx?J<1BV##8FQgoH<*+fUm`lhoO;Y<SV@UScIzpX4N!@#pV!Ijj<6IZA?QE5{zb2_=CKO0by8B{FUHa@GaC zObb7VH?97D!4%iJV4#z0UGjc?txF#6!9ulS*SZ}0C|uLS`qlSC0JpB;@kVv6OG)fn zmz698RzF0jYh56Nc&!UBK1Z}JR~O&{-e$M~p$V`A`|V`L(?DkPqtilE;Fexr(Z@8q zYTi3@%Y9Y`hPyqtgEel#sp+C^h^8mjq9$$DEhvwBx1ag|vfo0t@EJXER{{KU1F@oa zwNNn<_&AUQA0IG)Y~-!HnF?0SJqbRf6D7_7OX3&Hh{&`DZ(*CkTR{9`8IhCrIZpgo z9T(1EshcQKvp5FvttZ6S7df;Znp;aQZ3_ANmo=@={HidxUzZ@-eC;VK4R zRTVk{(24`SZWj zi-r}5gwY1Aj&K8`jE4%u3keVvCmXhtR}1-&EIGe6XkDZbapP+xpWnQ(z`iY>*REU} zi|%V*oru=vHnu+R)I$1dG;BoOC+xiFPIZrNnFx=O9mN?H$_2ekX&msp~28~p~*>!y44_~PJxU?RF#^QgH z)OJvXGwm1QM(asPnkORRquy#fDHX&899(Ns4!_>6Zv zBYgRIe&`wQGxqy&Pvhl!Q#8$I{FnONPdYB+f+^N#-VE(xc&48Jy}xL+_P3KTF!+p! zFaP7RqV-zvI)L;U+lE+vH<j(z zgxj2Oo4@Fd%C~$lYx#|xdj4kJcu#NoB@JtQRhf~GkqG-!TCo@DZ2|WK?nfN5!)K0Y z^98qM`W)jKmZ;KwG2INDnUOlDtLhR@RJS5G6PLh% zRH~vzS)!i5kx{A$`XH-Z)#r>a%TP!Db-_iB@V>Q9Z`z**9>SbloBcUpWBAmy{`>Wm z{o3C?VVF11+`|{BfYL?0eZJO<*5G^sBaO{|Y>v)f?N5P-gnq4?1>hftzrb6d7<3AU zzitJ8O#*+FIQ(^M8m_$LT|El;6N<@W1n?~hRTP?)4;EjFW3T{fILFM zHBdta0j&W*Yk;7IaGS4ad*uh1(&CKH&dRKaiKGr+5HCblOu-5xu=%878(OsHKyTHe zA0i<(%~_M8#$-;RDmS1!xo8lxXPFDBIfNGO$+jPmAt_}-^i)zx77{H-147Lv26Gbg z1tNv%a)su@gd3`sKYy3qmtv5eq0G1*ogUrI@PhK~Rxo4rm*(GrdDigs$XrYuRak=4 zsBi2brwThq{0u`-1yHHD9U40VbHP1vdJeWSy8DXW(L&>>+2y|jS>sFD-g;E5yx>69 zo)k3Fp1RpbH_q10ThX4kfr7iFJ^lNg_H3V=?OB;#X1widI*{hi->o-&m!_v2z%qSB ze?9*{I)qZn&ko-m+Fq`$K^qTn`0f%k@Zfj@>&7MEyYDOC@~6D*GXOsPde!-nw?wyd zI%*XAtO4B zAF(@;$CN!WjcdeOXoJKe&~DMY8LS{gi(m3Pp3GrRgysf|)NZg-+^)#3m9Q(mAR))D zm?D`*b6Y~i1+-w;V}L7mBG7sP8({%;Jxy(D@E(heq1?l;vM-@y>%vK(0}T_+u<#Xd zI{;I=?PHP9NweFIz9(t4&^%=F8K1S*!s1b&o1>h>+mCS)ldv0AVpv6t|3oeXCc<}Y zd4RtLgc10!#j?-{_o$QQ8K3cKGE$TONb0Z&so1OJ8XECfG zc`-~2--cSm6J$rYOcU!2-t@?&$-#`)f5%gzlAly|09DZ*)b+`E(<7H92MMaZq;$AE zQE9I8Eou`ARt|4RJyE5%_yBKdR+@|LqR2>U6twFI{z4k{8c50fxol8(Vw(T_oKLBZ&kM7vQD>3N_38! zmV4v_XzUhmwqPj=j5h~~fUy^(57(;Kv3OlCui^Q8SaNNkZiF|eP+w#Rlsts^B$M!2 z;yiWdS?)YXI#2G#Wx7dDc&d7atNFwqZaE|Z{KIP<9x6k4Azt~1*v0CNuZ@Y<^@-O_ zcy+RENyOUD>rYw_ZvlS70YvcG;5>KW37Bno@DHy7g|CKOQHq#Mz;!?i0adyjMyc0= z#4Aa}Kc8_%;)Y)qn1>H`4>YSTcM>w0ZcKny3}cbi&7Onyp`TrfIxql?HrzNU@_3bG z{Sc!Y8+c{fZ#M8p^M0>^y;IT9I@*(DM8yJpSYc8JA<_aNR_J$Hm;15#eIy=yj&+`s zoaa>alvY(qlUsE@zv2(%Jb0@**^*jygUZEhTN1CaRt4^CzgXjXCy>x}Dn>5kM7A~r z9k}vD5V16j@ei-R(WJj>JaT}2`CDi_F(U{(+)Q~d8;xy<0~toauNzP4=c^h}kbMMl zv;7XFI_)R+X~6;e4-!3f1UccLJ+*y99=t35vBq*3q2>Qqn~_Mrro7!7!cdnJIEqSH z-Z+(TgEajiw`Xz4%t#Imop_$+JkP~5F+WJ!ii;WJ5i7froKK%~xC;}faTpAq`v(Vu zAs7rcZ{uK)R@EN|gyMI_-VFbWkosGBOWVDVQ{Wd*Lk{XIN82UMC>iI%8Ig4Qt1_FN z5Qn>YJ_0*y5x9C(WKMIM%O3I{=rIZ8IG(BXYGc0)Y%{k?ufoVtj+uV$N>0jTuFszm z7`rg%)YeDzatWvFHzu?e?tm$@d zDw#53V+gxgKV20Fv%XuKbqx>{?P?h}4he3c>{?t@X3t)^7j}+M4NPF*&(YJg_4wWY z(e&2f{;t}rAnZ@U{o}M*_uysb{_j8%ZPq-z8{f~|ubs-!BM9j$2VXg>?}zJdK9>s# zuGTzfo)+ATtRJDonR`{%Pvl)?jN%<8CQgfYe`{-cCKYM})K>U4f6cjuF5_U#T&&&gghTRary|@S~I`$wP zJ2U`~FqNX|NdHR#CPx1o6z-*`g4*~?$w z8!gf5e*n$(PAWYyzP%hopWRBL2atp4mcrG22g<|Ug~#}?1MN$y@62*3;#Zeuxg6rJ z^k7$nP-XV~RF|t7s!xpi3jv?hufx+`j{ZR}NeuXlzT<+q<93b;-~tgD4g>Xr2Wa(u z0}{*X%navy01?Zg8moH1u5JNH^zoWU!TgX}yC0+-EyVdC#LtP}i`>#`encMI-+(0q z_IsR+4G1bP=Mor5Mn=BC`felZEA;QC`w+u^NVNX!|h z5y9!%i}zwQQrwjF2pltlsZ!Q}sq&tnpj4Ig7wzs)#fR3BK*i^v5)`Ay*?Srp;XaWO zNn%tBpA6W^q=c`MBvK9qobj*+MC}H!0MoIaI*97rNh>msM9-5FxpZbyzHtFh@0XT~ zllo{#ZiJY`T$x%3c7KE`uyBaZP(nME&Sk-J;Hia3URn>v(g-^#E)|=*APZyrU6`wG zp`9cxxnwPn3c`UKT52O&3dQ6wVTrLm@Xe~gTP4QZ*x;7y(!4wRG|qh6iJ5{Y8k;q)u8f4g?&tJgB5yV#02xz&xu z>9EgN%;3z^zH^n6LwH44usIDI5XfSY*^(&$!n&-H?g)1NMftoO$Btw3Lu+K`NNI=g z%Se~_-X-!xhj34(uSfe<;}knP2iY_dK;>jCjZ`4Ldi%Z&Z|F3x$XLe7+lP#!q7v~l zPTp2Cj*=nLmvQp;0^-0e7t9rIStT=9_x0a6-0~vAcFhvumi6@~fDn6I*pYa_t=x1mV#&d=9eA{`x z<~*l3&ygLTL4-T#YnOY}-WrGmV>W7tD*fetRH*{i9{0Sjl@2+E6K+VzQ*Oq75Ua2P zc*EU5x2NxqGi$dp#9?u42&?o8R9rfc@D{cTTYq2FZ*p^z+Gu(*KjEHG3l%e1{JuLo!>hZXw>t>IZ9tky*Vb|S#y)V)^21ttagA*2??Ux42p1D=fpb~fB($M_eB z-mBoB<-m{JNBFe@KO$V!O^d<*7-0oJyB+)^V(=S~AgO`J*AA1la_kbr`~ZjIvQBhL z39^)mDi1fC0S+swVH1G2Bi#2fuut;6r+`uf#L`eN2FzqgwuGP(~Vq$th zT2+H!YQT|FR_!>!wExZY=Yi&x{**WfG?9T5ta&d1sta#3V&RNTIHZt_Agkch|ndRg5$Yj zC8e%s1UFJ(o8NFOh|q7LG3boiCTBk%H5P_cL>5-Zs>=oN4v{CF@TnY!UOke9r` z$#2ZHnX*Iq*~Z*wcIMt%pg>vGE4m%~wXDLESjNj}b#;0^v^44TJdsQnBuAsb^99M2 zs-eh_ju1c|Y(o-V;0sE%ZaVTpoN>=81TY;`6>fRe5iIttyHZ>uuaXWy9NS?iSj(rR zX!}vPu}_Mi?83|(l;;kYQnOnp z>nu10fDQHpWcG1sMi0MU;WblW$nCTv+7*psgEAnC4qrd4cP2YHH}AMF{;W4Z#QY|G zfeNEy6HzgUonywN0vvXb@rdhP;Egy$A9Xh?Yqf&9^KAun8SrpbVAkl4{D)1RQk5$S zQ4x{9^zCI8o&ew|#)MCpqi;xcjUGdcVYYw0;xb>qjNFRB@lsGiElME5W8$FiiGen; zc)b-1mS2GBCIJJ0{-D8WkaBy~gjCm6SE4b};RsLhiQod++aGZAY82cq0{3{Jd>-JM z+3=!rm{i#+>}42RdOdQI%WJfNr(Ujy2d@!652f@kp2F4ORl{!XynRW=Gi zN(NT0ClsINeO=@qXzt=+@NS=Ob~K%1og})r=@|_W5Gd=xV_%M?6dWL}?gR8UEX7eb z2n>4PnhzN4P;dY`m@VE1nWazJBQ`4C;MZ~|uv`$Tyi^ZP&%_w>8n6TKfyhb(GX(fC z0N#%XQtjvt$R+p;lpcLaz-ImmYzg# z<6%$ArJCE9ovPbPR~ndLbOT0Eqs3>=6AK8o+L-Q#!pNZw+K-u$u9bcSV@7IJ-@VCq zLi4TxIVlxgy&*{84*=bx)x&uh%o9@6IftO8aEXIXiFJ5I#dq#jRBW!6D!&VELIFQ+ zl4jCsn#kSK%q=g+>iYa+2cnUM_z>gM)+%+SMe@dp!L~WyLE9I z`kGTKqsi{q6J6pYz(L9bv!x#O=u*&$@>vgR5Kl22n=e6shC-9|yeVjXwgg>$Qyuh( zB|bJHK1QY>c^seNNSg}WV<#hs&;u-{f=t)^5tuF=`ahZON5BHpo%SLDO~MTg-C2xty0jGJf9|+M zjMD#_9Ni2{hS%B5$iVf?!gG-UjFtjjT{lU?VOG6YjpEC$;{p!jjrPEYJ9AK*r_sU+p#^x0&`XK*lVEXM z5SX=eAzoVOTxnl-FNK>{!_83R7Jp6`tzTdD)7}Me<>w^!x zi}|$OFLD(MH^jK-RQ86Z+F5yH2QwltFdZitx!+c)YApk^nFrw7ivtE32t#H{ExVD_Xg*+`jgSR8Fg~UF-I2U%%UPu&-Mr3y?*7nJ9`a1#fng zr7x2x!Q#uo$1d!zMMAZe6}w)I+p~k-`%`#6?-Xo3IvYvYL&ANKsN)$uE%X%tp(!h- z;E<sy?G&(VmKM~=STdVZeDB*O7k17x=~i`&;P3UzksWS zrei8aVR1EB!(a4^Hv2@d^k6IPLVv!E_0LGIa5!*o&Lnok62(>;s93-(Nh>pN$t*L+ zXA=Yj0E9)DJWVloh;GgmmcTI|GfegdHaz46)ySNZZtsB^g?8eZ|D`3!8=$N3BuC+3 zHOP0)lc3-^TgUF`c%D!T^HRWgqU;DQW0W5aC@#wVuG9qHl*j-m2K-jASLoL8Mq57| z2OrGq*GIyM@3OO)Eh!)9a$n(*1TUj?7VJwvSU9|;B#m(GtDnPyl(}dmfx~g7F*RN7 zFls50-sv~;!0pmO@yuZsJlk=3pT_aV0Ial*N-%k608L_Ya5oq-xH;G1?yP~glIOwl zS$D(p71^4CZ50LsSH-CiX4~GTFiWX|j$;wCGGmV#c(E_zIS8_W50G_Nu*F<#FKIi! z(Ko@$DPRlKHJO#UmVxHYfVOD=j7=X*tXo6Cz(cTgSsEH=0np~EnGfT-8~jdD*mnax z?R$6bk48EP$xA?gMKWtf!%Eu4(7$B_#Iun^0>9W>VBy2&%z!ZH3y_&>wF-_y)CKpFa{9# zg-{yFKV?N*D=?*OjgMc{1Z5oF_#@br`^Squt&Efzx3JC*%WI)CsG_zIaaSZKS^s2d zKsuL5x1`RI5obOtVrKdNE$C}C)eKveji9Ub%VBu!Humuoffc3)WsS}Nl+~)L)0x%z z=r}A9tiA~2&@E6RrN8)9LxUqOc$W3<<;87nai9AHSuT0*IG2!1xj4h&-gU zufypE^jl$LYewTrC{ZqZOb-~K%$oxq!^;*3cNIjlj&wj@O3(n-NKMZ@%>jRsg9!h0K9#Ez~PTbj+3axMgBFXrrF;<2jPp=KI`N(sZ+0>QbYFx z@2jRLRLE_>!W$TUERZ7`m70gKqOcliHLu|l_z&+ z>^yCFO+8mS&t`eHM0Pt*hL!w}>330Ok*0E2EuwJ{c3e;FYb>qiG_EDg{l8#d)N@LS zj1SOVaMc<=ZE`;0bxY#aPQ30&ytXA?U1$qJL^j-z6nkBd1W>YI-@+>ADi=py>`_D{ z6%8ZYh&OvZKIv91Kl(6T&h}Z?a1)Opf(OgMLv}1JqvImF_#G9!LrTrGZ6oL z72_8WTRez}S#k!t>X6lN+B=Tg)FH@eSa&0VIr0qnFf7n_|EM>8bqIKM5lK%?vHvEr z?D13CLD93_L)I%%)KmFzUx0KXC+u#x@5K~gH1}>mO?4~ia%H-($rUAtEWyS+V$)CP zs|BA!qMtn4M2$aJaA{_=w0PDyJQz17hrfR*0IR4k#j~6*6HEAIO1YMA;ZD~m165=B zd+8)Ce=g;?mcO8Yb+%YKzdR5C@%i#-Enc+zCrg}+PuEF!QMu$=I#wPlCdtDJ$YXA; zJQmc+KhfT@$6C>60dWF9j4#zD&dtO-U#uLyXcM0#N;tY} z2kHriz<*0%Au7W^EkB$I`KaZ48+mqA>k+7CY>xovY-rC7l6%1xdCc7*56gudEI&s* ztpfEFod*@6W~t>b9V?GTljL!IK+7LhtK|=`)AGv}>&DVLaF9J}Ax}U*DIFHu6>VaK zKOf$As8@N9ZN~M$9`8)l_NPCf{z%14IPqO?xiZoA!3$ zXlm3Fwq1raoB}fyCVMQGsXW;H*e2kxY?a5-<9mKpexGr_y4CslXL!UMZUAuHe9PmM ziW3)+3YgF1btwsf=ZX^bgvSpokpkQn0LN<-C&Qo5%?4W{(Ol98&jln9KD?aEz1xVm zK7gN_YZ3KYZeJBuS%;_@i}3>$)XW+(3AcO!>;`;wz}}s!BY-^j=Z;h_kK|5JFHgt~ z+fsD3ig{V?bCd!Ws+dr217ARg08o_|?qe3}ug43t0j>&xJj>}_cjaMQRLiV% zG64S25r377CE4Dm*v;-@FPjD(h0U8o4m7s2;hkQ#paf9}KdE}ztS!jN-hikX>_T34 zp?k7X76OaLsxM+8K>WNs6<@}lHGDB*{?QjPKs5j`%rUAF0qF#umRYf$2IOPiq0AVc ziEK~l%%=5tVWfK2Pf*X5Q`K`;wR+w&Up?n7RL_4j;A!79kmvuNT90>Vm#}$g)gv(f zqdnkOT*n5Dn=;D29`BLksKA-iFkcbjDVB3{ZZ*Gu17(@F(NOI`e{q53A>MW{6tpo# zTdRdubJMOFrr3o9`E)hSXxvilXiKmU=oZYeP)5Ta!8lBFjL*XIr=GuHA@cZA{^Lve zOm`F{rg{*mfC}-$>13Gjj3GSptA)~0lDU)`LeWwpRB=pDX)91{2}&=rsIh2&8;)B( zbW^~~w0I&TTvw083@#xBvM)ZTdA1EPXC69U%|&eFC$OD+|H4aBOVqRxkAav z@5mO8j9lc%$fcB#=r-?P(;J$@tSw+Wib}|>mD%7y~rJX&(g^<7<5>Z$V~lp%ik`S|fJw z2)kai0hf6pJtPr#2xKi=LAx{L+#N7%(y0Li++Zc(BoMP ztZA|Q_X22p0SRj(MX{tVa!~zB;?TKEusWdBR~Q%RMxy|LTw3^SfDs!xmIKGkL>L3^1POQdbFxf17uBMT))X8#yTI0dJvjAxOosU$qTFDMlh zR|Od>CNZvQ53ZVN!y4*(J-8vNpFX!uV)x?Y&lWfCTLB)z45!bP)@Z^9L@on8`3L6$ z;EL~M+!b2_ntDC~m@C#xiICLc34Fs@6JtfKz;1(cs21Kk1b<*?R541}rT3F?mXo2p%MyVjW{euo*nEl*R|$TC8jyOI-*> zc!yiEonC87iQK@r#C}~h-ivwP(GVh8ND*r<3@(D4F?X@x2=5(q+yOF4nEjzEDn-{F zaQ8fnt~)fDE<2ivYN`&*9X<)jDZIQPI-Cy{pY#{9DsIJa4}C?k>ghi7(gL+}tb86# zR9S&r_$c%vBn)aF|6VHYugb&Tua>oJ9^G2e2rTU`TgkWAEK4Lusy&uH=-2Q2^XkVKUyOJcfH{Qn<43q72i_6RGsB=|N zY)fDTrbZ+=D)Oy5UqSyTigv#u^&+?Nd@u7vh*hVLLkCdE!;%-)`jbk)Ma-P$upNI!qN&d2=*$eetLK$GovEG z)mRM9Xw-{7tT>jtGV*bhM9olFKf;A6M?RpoONB<}3K9cp1e~EdXw$cy?5}Did2%VL z`ywrw4hXO313MlKkwtnZYm$oJ#D`n;OEGb(MDx|xwxq9?^kGBv^$2g21bq_xig)L` zWCg=Tei8;zb;nhnp&9H24%X7NfACieb_}8mBF2Bla||y2!6N`&)AB~Gk=vtR;JvQ(-C;t0ef{);V){1hAkg);|TcQ=ZC$M4- zqFohwY**01i!G*&JKeC`3Ne0mkl|DEYB>-F`9y390+39XQ&PekuirRh~SiR~t6Ft1I4lhzCz^7j?Fv5pdLZ1K`dIYDYr)r^`Lx7Ol zH;S!aa2q%P%h0DojuK&RT73$jF(e88%cMS9nEG8D|Iic3DOMnW8ghCUr(V|H30OGl z^9dO8fwAlpCj*aW%#zfyQPmM(x_7bB8THAl-WMMqJ;t%Qv_gUeP<5sNA2qI_WTzBv z^ov}9AE9?(nKT=`g|R`^hOR!Jv^FHhTd9TLEWGa;>Qwgy0GC=(=rj}&n07AK({k|U zn|XjHGc9~L0#4Pn`ukQQHGO+jLQx=LT>NTvJLg6m#wbGS9f(IKI*)ZlO&5(}O-b=j zUyLsaa+Q8#=h~6FHjsRI7wkiwg0ra}I3?dL( z59x0%CC@^4JRZ#o?b2^8Ek}f1zB>cK-ClSGH=2!b8sjc}nmsOS-FP5KqsP{JL`I|u zqJIIR=KxVI-Cu1kWd^^sg0o8=15H6ztb*m>Z~$^bh!WnXGjXKM;%gaHGArvQ07m_? zxg8qZ>9S9shRqHrD2RdxWjdY;G;WV)2Miua)#k0nk&2X!T{l$6qe6GlD6)b$q-e9h zfb<}g8SiuMw7pTc!c)<}JnjfjAV`B5Z4U9-`qrT?-?-se2=Zb#qx*Sm%r!G=116~m zgG*Kocj{X1pRb3vW|JMC&D41`o2eK!g~At5d)O5EcrG(7QdKH}3f+u+<)x-%aSC@z zwm*JkUv%`CSfsUtP$ASV7zzGT$l0?#N0b4Vh`VFSoDaS3VRNXuC`wZoz$Sh$C#V(6 z{}l6ED_BDwSZ;Zk&Ap;8f@*I-{kt+3<9BpxEwl;C=VnPJ>bvF~G3b1UU9?7!B82rl zVifDkHF@tMwzjJ(+cf#nYnJ7q^cJK>Kiu&Ta_5S?crlksF)K)Kd&%86W%)KFx$2K1 znQ9=!-feSO7KIN);i^_Ft{0v*1+tzA26P$=^V{pRj@ss+^CUpvonf zo`WiXU8<;(uHe8&5yAljl3J%F0{ ztlPnhKUN;1pES9z7HUNl1?E?H#z#U*JP6Hq7-wbe8Ar6Tp63+V>h{*l3cJ5vCAI9M zu$%j=@T*pH0>T~~&UzOJ?fpAz>NK5w74Y(m_Kb-f!1Pu5w`=xRyL9-ARl|HxhIsZZ zN=ZB>s0ZyYy5+6bjkzNkBN>1idohJgtn0Rj?FVs?pXIWz`~*?ld$~gJQ_>+O3AP#-)>d2&{9G;4 zpNWSShL8mqg{C7~R?q0}bUt+D>u>Dp3T{b3H$3TD^hw;*8>|B=O<#5jZrR;+1E~K~ z^@*-(iKK-1FN7C(OQY^=x{rT`RPUtKM8R5#9x6xKK>zoU)n4-uHo(4cG?;C(Fr=gG z$RMr!VNugTLDv{c4&2KkWNd6)*lujR5($9viGg_E(CTXmr+O|&gV4r`9IZZ(j~YY# zSF2&Iu(~^rx3!SNuI!9rV!9T`Yj9X26329v$^pn`pKI_0PUZQ|v5@;@9M2jE7G(8* zzJj>H5t};~xKTi|)4s0|GphDQmF{?;&nJ0}LJp}}zG1Zs|t6`N#j|yK9 z6gkqeE7>#PGZaE*JQA_hhRo{jsusnAvi>yoQY$O%0U<&K&Q}AAt7j`(oXz4YPD4@G zs-mjkJ#TP9baDwwxfqH1V0JpVZ@E2fBjg1xAIHg&Jf%;xq3#Hkpxt(;SL}`q+v>Fd zuUqiy^q@u?Jt(C*3}a~2{v7BzTqy1htgLUGmU&`$jM?9Nk}Z=`)dOg(M`e|kR5)WF z*2!7LU+TM)uK~s`z^-xD^Db~NPvwNKBF~!x3d*dz6oOXPTsB6h0T{KrJ&soh&X@7< zaVKb-e$s%x9_{|sWns7za=(c967Bw$vLc9@}t{_tLHuG}gv zBC5C4jCHwU4Qh=;9K_xSnW_5f)F%|vv#(|&EriIKyAmBA+t4A-#1nF7yhMJ6oFc_v zUqUih9K-iTGu6Sod0?$lt$qa++fq<6Huq@+Q$n7EspiA}JB&r^Fh1{p97SU*=!Kz1 zI4Hv56!*v1#kYcXTew;{wCQiyR))iF;Mrny4Pbdj7?RTmn~zc zFj0?cN=t`haSGVeXm|D?7k9!LM?zl0*+O*}JQt>m{YZSKgrlCJLp8l^8L|Su(~ov} zuJ(+Et6!K(!IZmbq_w*39LF=p-I|+Dgps1swM#}27**dyCBFzswZFupO!HE8_!_TJ zjcxgm6~TioID06`SPrpO|4-F|rKowj0}JS1osBbsua{!ZPB*iq#>b@~hAG1z{Cf@c zjKD6#a}P%;t?!C3j=VTBx^DF8WI8IHY$R z!&c!nfTp_VJY268Nk=SU?)jU7xdp&T@j!!`iH6>h2xs6U#Q}ObHlyn6r>KBd(23`zrdP0b;0TPFrsQSLuPqR1iJ z*>xcXAzq$gH`PL)s@gn#m8#9#YUmiZZ%kwc-?u&v2z;Zz6@1k@R;pV4(!h10>3msPQqviduu^(bW0cMxm$ zO@a*CvW>N{3O51;)s}BeL0f)_*hG=NS>!D!lFfUxBLa9LD7c(`$)y>i5I|WUUa2bn z!KG{f&g;`uIU>$CfX=Fn@hC%y^D|z;kPx@>tfTph2aprGTjVwr?#$RZ!+jX$S8_kP zNt+KdNNdtqd(gWeuuLEAt*A78jt6Hvk8g7BLYv#9)%Wk)^hIiL%P(EmSNHFWU{P?! z%PxFD6h1Jv$aYm>0aHL{Ekz6Bj)1<6HZrBK6Q)X)PDhpcJj!-VsXAVzExbNPI;~#s z+ZaiOb;({@l_E!qx7&jktKRUTG`hq5qIOl>1&UqXM^WtYAu)<={D%V10r2P;X#3pT z_X+jSxRc;22gEhFMrnXhHhYYfRq1fv<#BL90hcNb(8>m&ifw;Wslb(05gd+gTUq~f z+U_W3)j}8S5Dn!#M|(n01@elSX?TWZeQ2=Xz;jH&)4Dw`@vY$(8z}t zp8JEc9fEc%%Fc3CTujp%mNebpEnrohbF9D|@Fx&Hluei2AMouN(6D1-pDtD+8Gyy? zIIZGd=wycjkE~pky(pf&6SH50?5(Q=!8L9m7%c7w1h9!rVW@?kktIC$Xaz~Dd5~c% z>)Vln%yZbqtdLn+0cbnAqsCK^BKUSR@(Z5jrN)Ot9r=Iq(Kuxn+0XpJ;t%|6O;#~2 zsfuf{>lsztjE90chEN{@)L0dlu!{LxK~vnST@Q;t4ZZK-$?z*q_@ksJ<7YYF8DFc_ z&#MFV_BX?)AgoEj%Vf; z3bUDCxF9J?yEYj^Dztjs?PO;ZG%cM@`u0~!7qMr-w+bG7exTT=$hQJ*KE|sjJYjAyudJQ~9j9@SOPH&l2i&y^PwOYNo>ErkcWm=F{N@C=jzk6h=3j87V&U6^Xk)@z1~_gD5HdKYb71PZ zuF4~ERJg&hQdAzjYB&6H+BwrecxBhD+#=sAzU3kIw$~4Z+PV&+w)%QbM@<^52P)0u zee^q1AFBta!Zu#^2u_Bpj<{il>ep{xLQbG9cke^0UmvC8a0S?44N{0S#Fb0g_RIHi z&Vdi&x!ntU`LMpC#>P$_Lan8`7siT$%XdPH-Yxy70A>VOzT1h56STW0 zAxf@G@C07Vbta#$b3%H$x6WU*L%U}H)uv$a{SfW0it|9WH4iEoahf@JB(^c3W@lp$ z7W(MU5z?D}x--_BQZ7n`|G`7K8ruxj6>Jl=%P>zvOD=X*z$wCTP#2UfO67`bi|sj& zGYJ@F+Z}I<+xa_#S+o#sXSkop@IHcjC91q&Cv$q9>~w<)L0jX)Z*(JzEtb?5sA=-? zK#gO@+d68Yg*fR&P4>(e2GDAhnQ{+!;PdGY57;lm)rFkYkCh)Ru4QgG_%Pk8BxhPx zKkiD%5!r!-=~6jT)p#<`Vq_her54DF@C0BF0GHci;QV5YXQX}pAt1`Qb&(#RN({a^ zQ0WWDBW_g+7C7t^rV!0C5NQU8RHTKtLB>9&usa%LdI9A4ATSLmxDaj*%E15;`cU&( z{v)Ek-JgLA7L#H8C;V6nqjUbdSmMPA)b+Yiw$Oh1Bhbh!Td25ZvEmLM^Y$10sNG$Q z7ww*7$SlF)htXp}vQff1?&b%i@wFNpVD#W@$_cE04wU+iQJ8%Q zN7xt;wVF#2PO9&L$6;ri*+{`&6*Fhr(^SZxgCr zuP{3vfYs1eaRD$})diS^kOAnhqAczhqGP$AK#&++E0avjSqnQMFHyH2T%!lm3W;Jf@6c@FDspe=PQ0$Vn2g>R z2m2jXkzEn?)5sz)cMxX3%394@t(qqTJs$VkfB^mGDmm1gRQZLsO64aEm1Z%fc3{Iv zMWDfQ%%vl=+{4N#16*VzXHQNbX8Mc_U}UiPky2rYZ#Y(A{&T;>4sm1*@$>Htlvm$kp4 zeKwXfZtJokQli!Gg5sL8i<0}%)tuA#A(Q(=hnmA5iB8tbqf3Z=bO}dh`-twisDM*Q z65iMW_F+r-J5?^!QwH3r>~B?SsSXZ$&?xI(5jk9oc4#3#7?lfUqeu+rDX2asvU3&! zdY?u()LD;W<;aX@!}p%xmpFY5v>HocPvd#C0e2F?j%cy6_VjKFwFpfr$@~H2{3+A# zv@iI}UT5JmJ<<=jIFtbE*Om8aj1{{f0&1v2|F;sm#!6f*op?rrXoOsZeCIEaouGWA z7t}(B91KhK&&Rxm>fJe5*H7$ENxJU^C)q#^C}`=p?;gu8Q{atsVjeV`5(uHn?yI_D zcd~uctrY1cSUV{`!9!)|7cYzz;myML4FLcE$*J?>UQMNC?$*uApu1p^Hh^f3 z+s5L0p0Rjy8E?S9Y+CTk{c35P+v<#A6X3wY7&b{a%QOAPxI1;@BONzzHf@K-xGiVq zccL(UONFuP0b?@s#hq|2ol&r{>rP|XRO5}{mqjsPwE+|%rT4~2kBJy`#oNvaej&Qz zw`pB>P*+?Zmm=@u;VJ^kXNvxShdgY=r)^9m5HXG((~8`!z4D{e=@TkH8GGawx4g?ho;u z)b^LVUtasf>)|3uy>dWkt;g8ky$ zRCb#Z;8BmeLM0=1juRzN)9QBRS}_(?A&U+hli1!%w7D%T`)^V}1XfO=QJl&RHIF$}*3f}%uZ2zouQ1oqczOcM9E(l{LcW&OLos8C>lK}_cZ5f>wa`+)+!a`i z-&8F;506#-$g;1(l7L0g5F*HyJ!H>ih4h`vpp#%n-(L_|br{oHNUQcOG$?~n_*^Co z7Eiud1m#~TrcL)hY8*jH3oxkLxlAN-7YylYIQn@!W?BU)`=Z<`0gWf>S#}TST4i|k z!_RWM{rK*q0I8E-95S|)q!T%ZAPeEog%a7>LxP5CTcBDGywMX4i8}(ZY`*Vg!b7mycCa5|gQDn8~xwP5$^MPwqn6SVJf+|XPG(YKtU&oMy?MxNkzDUEg) z;Zm4#VK^p(4ZlJ+-he6D_}FvB2%42qz(!OP`(rOlg;H`ke8NL82bR|XoXaD#{izu- z_=Ksd`||&Aa7D#s+~ew_BcB}M4G+)kPkv)Vl0(7{#LI+og)zpndvn>ijgeH*awq5M z=HXs*S`NKb=V|r-S`R2C)wtZxGm~_$!j-vDlFh=&7eWEph25KALtoN1lRaQ5eP(gy z1)!2_FcDFPl5-eT8&FytW()&uk9oUv<|@i%DrLak%fY$R8G~+}3GZ0WAvP5F75J#?wtz4sYh9H{v{h*PVLT@AdHNiZYMcKNqs3 zx(`Gb%4r0bv1@*Zs<8al!$=XhY1E0a4G1TPGQ^(^Rf*d$m`HW1Av@k@>ABgyas zS!ol_!yv74sA7h2I0HiAbKC#SeoX#XN1nh)1u0oA(mL`ZwFRqqB20RKori}X3leq> zE*g(JI0J34K6E1onHJpBc8ISis?BSRPz7{`Jn~bYMrhPp{q$^~VV4>QoMCSx#@e!! zZy?EZ&+z1tA4s2TXLoi+e^w!~79A22A@Bd=?oFVhDz^XMFti2*Iv~L~ph1EHG6XeB z#Au=fI+`e=D2fA$BFvShU{r&!Ly|vz2?`5s@IaQ}>SJkdvyLRo`wM*qiYnQ4^;#cmT6|FmteYvnl zjy_65BQkiLL)g55LReoA_O<6aX0LJ(mhK#yv=1q*k9?1vAL|^-&~6)LTw>S)Q}RG=8LuWAzU*PbF;5M1U-z($XCxh zDu^Z;#AvQ9x#6HRAs(gWj(1%Rb&v`H6&Vp>nSH`CKM~ntA!TDBvc0vAO+1YhSN3Ep z+kfv;q{7WA!6-WiRm^+$}* zxB^VJI2!F9VG!i!>V^dJ5+!zHa*WxpQ2 zOKG%r4;y5MYhXQBVcj^1S_r}Gi>3+NyQ(lbRh~##-I-jH836+*@GNo(<^JHJL;Iv)FvtQkuh2h2$tMF0B}3JhUS#{EQFnAoDd9AAr&-Tg z7t#T5{v)LBpo_AA25WvrYS`|w+mohIkt5EcWgE((PhGM*yUODS$GF5C+I>$Kgt7Pf z?z%nYGd+jXi5Hx-xxsQS6jf}9KDB>*W5f7tuYC9T#;upGu1KOdRUQujurq&)_6(H*x_G7R)?9(F@JlH5#QlShpb)r~n&JY#%PZ>N;HmiuQM>No$c;WaRD!X090D3!|gYNha#)r$P z&qV9YNwFtf_$`IGC4o@|YW=dW{$iX>FkZdwI16sItTaH^0D+i*75XOyFoYGAo z!8kB4u+R2(rBpB!Nc#(0--rg?zZCDxBFmwb7mqAU6TGVl?*3sHHx&7i@ zwXUcq-!&bL4#G~2CO$MyX>!rv0bG2M9coJ{|A4UkPL?Dx(UrfqE1%n3#T-`#r|@XP zB#sQ3#B0ruwLHikIB(qs&=R)=N0-pDNu9UhLM7s4^L(_eCnW@D(4ZCuiXZR{<) zv2TBb(P`_kZb-ce`7@+`l?{*=*%%Lp)Hj5;WgEMa#j%Y$Ln)~+SV%fk0t`aIAc@Vd zn&wz?p;(m$Q(5xx-GfrlQfBu~1@j;*Y(s*#tVq@(Ibok=1y{pi!St8ZN%Zsulu2-D z7<^Qt){cSv6+O+=INpYy?hoVslAg}$l}JIf!P0Zda54br*_WJQv0T~ zG=7jM68U;tI{Ln+%C&<`#jeaRiO~?N-IGZS8p`A0kMEq9weF#qH!##yZ1uaH*dG6{ z@R&zQ&n4$}ySINKN(Zf(7F>^3Q2=8nHl)OVUlzRS{PzOpAfO5Pb z{|<#v*;%9rF;M8AZ{Vw607`zdigq%JFWG+Eie5r)KLWUQ*8}U6rm*%5t9rMFu@_m% z-gslf&vFfaZs%YzIE21p^c7s1lFfRpWu;M@4GK52Jc1VCBOz3UQ;5luN#^`;rqZhdW7K51dzV~1|4h%2uP^| zi8BN9->9rb_0EM?Bmul;gL54FKz}nhS9J&QSps}3fa#8X`Wl!1NS(v^$7`%hqElWI zmRz@-c8E2<%b88PrNcSk;gj`rOaGsgb6|fAptt%T4a1jfXCQ;&f{=(_>60d+|4#fH zB3e4oig@%4F#MdfHP-=I(qkhLRnm=MxIfhuhF78D778@G)JOItR!;H2wO^1K_*HDb zrw9IOq9L(MXoR`Xa|3@Q@?G!@Ai(gGq{s~XOANdX{C$9u9;nrOGio|^N@F+VP7}%L z=KyNmjnJ1)#r0pjZY{6c`vdaurjYZ(isN5X2!HjSCeZf+`m;N21AR|HfBHBox`Zr1 z_G4Tow8KASAMi@hl4nMrR+-Y6jIXUJYq(^iZI0Vb9c9DJ!S=P^$KVragC2eaRN=Wy zrro^hbzJy5sBY#2UdwCON_BF1A=gXv@QWVQ4wjr@M-xv$tBcN+c5eO2(6&1l=i)H>ky8sBA1RHGqM<_=?{* z-be+a5+5pA(u`AimY zfe4jc!o#2bia?mwv{vWb&8LREDLummW@M+S*pr-TJDyf<9G^x` zr>VG-3uOGc>$d2SGo6%smDZOXSGwSA@0c5HqFC z!LBO3+q9tZFJ?mzevWl$TtXWczAT-peGtKGI4uLOG6V0bZQyMp5lyRX)d;WV8xcqb zp6Q)sSyExQqsEY(Q@N|ic3kpjXc?zv%x>yKRs1VvY3H-PqY6scSJtl zOZ=tL8+Z@UVB{?&sZ0{KBHmiW%|u{&Qv31vw&6W42_3iaKb8EOD!N21Om(^UTqkCa zvBDWlk!cgu6WpmHyOlX4#!diNqA1F+(BSAg`P|}fSuNLRMSip?GVO-LeX8A{vjT|O9E0acV4u@?=k}|x5hlE*v zH_~lr$XfS;I}c@dF5yIWA1Zbozs$hBo;wdCA5symM6yvQ6MQ}lJ}<$t$x5WQKzc2=xUDUabu;}; zTHU8RgOL8X0roZ?w8;y<%(8fqRc*n1-bp-%N4VU5rHd;%qO!cmcI@sWjyy-Ku-~pS z^)D-wD_&Ui#!E_|>8$EbaGme>gzMDf!c;Rs>%Fbwk25{7n(d|ip+hJD_xm?Q){zj% z7hJ{_sPkYr+*wH)DalVFYI#-*zwGb`Xjw+g!=SHRuBHy9I+oN1L1BAHb^81}KT>he#VvBw9tnzV}?ao}5+Om+yz|D_TpRQT-{ zjlyCZBdwy7ITO!4XjdqAdML+BZX}3G?0brcd3_R$SO(ffdK7<(ckkWE!uFz^V|nGJ z+B~U!6^&VR%B@VSl17fe!oZwR4C4h;ntcC}OFGidSLFM(?yx-d$a;TfrOn;3;t$8q zXV*bHY#yK?!O@VQsPq<)YR;m&EU8wbTH-946ToT_B{808QCa*Cw%J}OAY;7b5oN${ zxRAE@=r&n?|B>yp{Ch5MFI4?XK0!Uipyq?B^Fyee9IDo30KayWcvYXBG&Uw?wVZ^# zTI3-T>oT==5QHoK*?H=MKFdP5YrCnog1b{A-0!IH^BK6805=10cq70c9l+55R1NRS zKzj93*Y2=}lQNKcG=;QdBc!luy8y|*?Y-8F%jp6Zt<|l;RCWdA9i3McK$$XR{^@Ev zBAj@YuN2(X3dUx$%TO!WnWe6U#%M-I6%KK7zXvy~_}^e7Lt9!;$^$t`k_$O)A=9}e z_vb&rczmI-4g!Y2n&R|FU_5<4}I1h57S}P^gcwN4@q;FR60Po_b@P`M`-}hg9 zeG6Djnk?OzkV+6YG5Hm3mI34uXx$Y$Vt2;mPDjb?|VDFUeDJGyo`p_BfO z$`X?_XNoH0lR9PvXA?^E<33OA0+EB4D^7KCwb=oAkzTi$2pz4x4Z5R=o!dw{B_V5+ z>&fEpQh{Ll93{H?_xVYK1vvdfIE7k}aX-Zff5*oBOTzp= zo#N{8h19IO|4(d-NE zZ+&?ifLvdG9-}XJ{YqS+PdCvmT^gPIe0C#0aEOnWwC*bUE(Mxx$BY+>DO-BazhqAR~1 zUp|fW<3+Be&a^mMJ4+qr^*I;1Hi3fr|NdrI>+7ncH#fY{i?Vci7=2$tSkG6ECkxLD zhtQ#8$)D*@uTK&#!`_5`UnydyL42zq(Irvu~teWT)j*B`tvnVq2KoyN8;Z@u<1Fs|Eq>H zcOlt=D}~CJY%Z)Zq{D1FjjELpO%qLPt39#xdtl{KyZ%q=>; z@{)sK4)gD~n3C^0lUNR|a*zN%wZP7hQeCYYV2-Y8N`~(NCZmaOq7rsy?Mi^Vk8Uo? zA#|`pu$ay)3K?cu3v>AK%gfcTksqxhYIwBvq&?E6iYETpIg_H2?Y>mxJTrOD9S2R>X{gbJ z{UecbE4{M{#_EES0^m$_@Sjj_O&K`GDwC#8Qc3MdVyn0+Yafk&m+)IlSnkqsaz@GS zAkNWy`rbv<&v=L_F3aauJi1sg_5wyX2V+Vn71kU^DRFLR=sBz#LHHU-MNKoL)IOQ3 z&kA`%v1%JzsD8;2+?{~?`bCDMVkXf>BndfKF||8$I71jfL!qb9Fm=fdXYOXCP^q=P z*Clm6i?AJaN`D{`0F5TDgH@=z$EtfA&V}aSKH?kg?`&>7=SGv*Gzuh!G62LRiVg%ifHC9@2*{GXRG)|X3Jw8uq#m)0Bm9g*i!)WzyFxo5{o#r zZN}yfQQ~;XS_ATAa$cA^l-vgl|I9lf1xp(|PdB9T6fccXiYTqL@|f#U@8~|L-vl z$of11(Yj*~1Cm*H{73?~?wAN1e?BMvY1I;FQdiu{qJKCUXdzcTdwt4?PtTM8Uhd|} z?vTR^bV+)i%q6V(aXJQTdX__2%OeX_fgr|7*hcw>a|UBW?B$s3P*T=QdLPzb{+`Sc z&F9aHjp8(~d3`o@f+$jvFZC#XC0ctQ5CjI8`I#xa^Wc1x)VRUXpbx_W&S3Nk<7Qt!a~g4mZ6(mUG1AWhf}adjFEcj5P07WHZv7 z2`>ssa~|ab@N-%Oz?uxe&HxNX0cC28QC344X~*GW6XP;m-d}J;YdD9SkUT^!|CIar zx#1k{JPen-c8>5{zktnsikMQRUCD3##6eEJdQoKLb?JLf->mvpkiLCfG1!UTi+Kh| zp$nHE7VZszilNJsAl6{AQLN#aas6;!2dxOjU+#>$WzU05yykMI%R6HnLBbcS@>!gj z*hf`PKAJ(mnI-DK-aq?L(Zefr*Zw=X?n;ahe?yr@GV#M<0!WvbYQD=v2Q)h6U4>Ic z2a?LklOLCa>&V1>eTtXt;xg`RJM>)!kukUi(CP6ezBDAk+Chw!`Ap&Z(S-N4a2kz5 z+R8*53{@Ssgx5(yQFiU`4=~!11}IER{@S6u;3FZ`?lJZVuJ53s7IcK7!}4lMR_9tn z&cwKw*& zIC3Stf@QowN2fesr<^1IBBfRS7Qz`Vz!ML_e`<)y@E`xNff~kL{w=cf*o7P5Ckcou)Xw1zYIvfl%`*X zsx&1Yk&YRaeldwvpC-7N+JZV>TzV(LrsMC>3xB#9VwQWgcPEm%_{GGh^R8%;W@VH2 zHBH|A^g9jRz`Mi7SUsGa;@&>wlZxHQGY#He!gy)s^`|t3+3-C-jCW9S2>FXk=u1<* z>KhZnIXg%*GYb13-NV^#L@SB>93bgFm=7!`hUkGD)7Jkw!M=*uy)O|`8N+Q@zlfjq zgQ>GP16W7CMQcxC$2TZy7B-v>URygPx-5gKJu}`(Xm?cS< zfoIrYj86Gl;Z)JvSdF={a_0ahpSOvX{v*x**x-7{E#Wp_0O$c!!}tJO4kyiY5=DID zS<%{6%+Xj+WosIov!-YWR->jDe4n z*rha8;uq(v)2ZIGaG$AX8fWaWuq(Y~TyePuy=+E)^k3vPjGg0RIjiB%Y>d4tj7=47 z*o*pk1cR;=@7CA#k?m-t=mAW9eoaTywzgoh3|_(tP4i8kD=6N?#mP~!HS5seZu&9g zx4FA?cl{WPs*7t6)b!?cx%6~lE)t!xx5BBS3t}KlGr7O&Krq#I75mvc@+q8u{2g!Y zWJ>x~Qs>4?wzO9lXrk$5fSf*P%swWNw7@>rNjM3?TD-D}K4>(_LAB{v4kEdK%Vf&D z@MWZJ z{fWp9PDFj<6bWeZ1n95Y52A`+4L3yaq=z7gdj}AeD(ZBQ+JN6E)^Gl!M;h%B{n`;g zy_+DlKjK+-IXP+xMJ6r5E9sHx2W6trZ6I(uNTDyS6=Z~s3zAy; zrE;Hv_%#_n+SaJ^4hR>bdJlK_MxAvEr;0u;PgCdq2f$@cm4F>Dxy#!_yntNS%|qTG{ty%Km0Q%I-?p;v=TSUqby|moLhOm#`@Ab zwv#YB0d+-XY~Zs6HPk0sTgBHCb>jB1RaH8~w?DkH z!fWZpvdh>cWq%DbIxf-PooMf9_D<~{IIfraxuSSgG!Y>h-|!?I|6WD>VCwxd@SM)> zTI%KWBJriI5!~|Gor)%opa)`70)@(#++88u*uL@>T!{i^$;OtV;Bcjr)$gkYDB5#lyRk37KOQ~aOJAp4Ueg*L||6b3u-Kggw{&mGSRfg@+ zm;z-O1a*t+)Qg~4IK%O4T0*B_Px3*;e`VqyruC`4N)=#8KTAX~gg|B;qvIaQO=Y&x zTA6%HF@QC3(~Kq3sBPSNE+PF8!mRBg7s2P$4j1rte}-BvlO~U zIsC_+p7Z#B8)4VMpi_zO?g;OQ7$>#eBFf)t@B<{0X_G8a{IKQZX zS-zjG&WO%q*(3{q7<_Do`kz}1c6D+XHw=5bIR=xj37xxRF}(EY8z8hCZVfa*3exyN6I15}$|HU8PjaBMl&bF2R-U)cQY1?BY9 zRK)r>lE%=O;f)x&k}&|W_sL*rNpCRpJFY|=hK4J%7rC1(hM{ts*Gi5co4>pk3>`p3 z<6?wzwr31cY9-9!&)11uZqywvUGjpl1Tz#X9mvr{gacUfeE7PO*9@I&OgsohQpS8M zqxqO9YdU`Ng8iD7z?kSncoBOtS^n64!Cf+PzXm3LYL0V;SJ7JSN#j=$C!nd^Pap&_ z`Yo-5JMOKH^g7<9GuNN{K)`U}$@_A`HgXey$O@g@44t&lhGFiTD9NvH8J%~$nSh)? z-a6LcxeG$D|1z+081^p3v-4^Gs=i>nE;80y1Yo}qX#+Vq8ClaxZCnH-;v>DY~98Q6(>ojo#uX-p!FM4o1{_`)$O} zP_cLn2PYGob{ZaRDWXZ4PJ+0bdy|fNcvpv(FIs?>Xf3W%)z-Gd)Qz7*_s7@3Gn~lzwOgm|Zfl-z{Vn;{+oS2+Swlt3 z8fn3JW~-1zeBzkgFxADm`6uZ_lG?;|ti-ug?t431TQ;Xn=KO!}gX}^p(om|6yA?ft zpc_RAD-~DN)-hfBTFJa;1zTVvV6>Jg)n9+8q2U9DCq;kbNU&wP==T*) z8aztjRPG_2t-+rRNO#^>dsFJ6_Oa-VqI7H({tW%>B~WHJ+9mfK;|6IoEDc@{pZ~IF zeXt=6-xfaia!*^u2K$DQCE@d&ZJt+}7ISG(9L8T6KCcd+GsEZG;qwKaPCw%OomD04 z%W#tNe%Wwy^wz&2yw~Fn7+ZzMbvQxrFoQ50oQ1MrI91lXe%4^xD=?=h$v2-bzcENLE^7(|+1a%T@|yB^&C zMM?~|)z@lnG9d@x)bunLpRsbsQ8^!+t-C5sAus;dm3f>yc=tP-i3q8)i8USdPukIR z_eI2#b7f+V?NhzESXN0;)_G8t@bd-ja<^yaR0%&Vq_-E}dw`MajBZc=zD3rCSUmF9 zuYI#{E`#{gT{2tZW7cbW!9OBjq&>sk3J3WchLy^+M0Sc5a@v=eK>1wZoz3eVyh;9Y&Iq5g!si@4>zg@tuW=v?Rc?J^01u^EZosj_ z|DMkdxY^jdZ|jK6@-Lo><}@*bce$<0y+X_>6}g5-EES3KP(Pd`9$}8H>yDxyxU6E2 z6TFnLf-SW5!%#ZqR8spFf7SvQ{oGzEhyqBPfwbXO5_*wvA+w?KfP79Ich&%8oA&(%0vj`Y`3HE9=caQ%_KQv1!FLZ(A) z*294O`^9^1dWiv4pO^|DwY+S>t!$Uks<(|;RMC7dFHmQfsqaEK= z82ToiM%{b4d7&?rb}N*!t~l>JEWKWjm((bmV@>yh6wR}dnIV8K0BFOp8Crb=)-eu1 z76AN#FRJNw#d)lFn)qI{_I5DqKi$Oy!zueoFpQV%WtGweaL0x)_w^QtfBLWXvi^E5 zT`|g7$~)>n|Hr!kwEBfD4UFnO8~?+o_NEC1AqV8LTw#34m-%wr?M|ThFI*thyVEG! zx*jamIIr~b(Y|Pmi%C`%uYn;lARPa%(gs15cR+y*W!M^7@9*G=I}FaN@J>Tqa&R## zE?-w|`w`v^i)n4F{)YKH^vCOBd(jFG{vqSAe_EXe`WKzEBe+<~<&)Dtr0i;(XABg< zto!u_4dfQpb8s=Rsb_m=Q1RpMZ<2WYyDHBgxx4vNn=~d%& zscWX_q($E z)ehx9kzFWG`}{V=d@06~Dp~kxS3CPByV|~F@s|KKIM)nXO0^Ae1@#u3)huWQC)jA! z?Aaf?T4o5rIE^HJP%X{bdjDGGUq&LgFV&|a%ztN?|1Qg46cnnNCHpJu9%0tO%6g@P z|1!f0F8dH@h@~Qr*rVN(Jj86j|3yQ&A6}_;8w^W2F!Af8y(F24{oF&E{td@62{zcZ zzC-;damUB;ko*d7=a|Q}fWsj2X*M0`wyyq6ND#0wDKC6r1Ysk=rlIs~msh98MxH`? z=L{JxZteJ$^=_(U1f>r0Mrma*l^NM9?Oj&9Y*6%=HAFNJ(f=Kyl1tp+TJpsXvDBdU z4R%38Zb!0m$PG1rDzYA|s)0LN12NNy99%B)XfdfDUw`In!=>5fb}`(?1ej8CU*c&* zNZUW<-7g%|5}&|SkyhZ_$D5V~-NtlH9v13pds5Ej=!U}<$8ulK^6?ws49(j5`&d!G zVM7eskW-ux&Y}qk)c(3WQNuM|?3}!#N&gmT@`&A<(4^Rt$gl;~TtU^;vi^uTOk_vd z@+Wf2AZs1=a&Gzje7Z6I3%fz}-HEkvSzi2oEM@W?t|hX|qsM$5b2BoB3TI1x42IE- zjrMBXuNkdv5R3I9Ykp9N*&QIEfD=p36-#IsrZdd8&tK(ToDB~Y^XLo_16&h~-~D<) za6*q~d1Bte#UlFT^U1&KnXIMpgq13)k1U6GsJg9R<+Rq;hX+ zE&mwpZnmLNG|r8P3;%=DP0w%@`59cP!PUpmj>02C&Bx(D&=kt>C{^NA(MYmln(0A; zLq~ZvHB@crv3Mz1EVOWtJf33BMp#0^e#l;3*nor|wthZ;o1Qww25%!i&GFErvg1zGCyrTvz zS+j#VXOBL2S zEhcAr{I}~%Pp^?-z!o--WDk~Z;rzwwwECLH>9|HQ`g8N$4jjr5sRdsEd1@>*&2XH$ zD#u@w$kZsTORyCDSN3%G%k_NA|E!a9WI9<_Na6)4n@QG7=oK@ zxJOPvCCV|aI->!tIX+W;;w5c27?YT1y&E~GG@KzHBJ4zD+TCJ@aDs&XJ7Ztz*L}!^ z9ZR3uMv$GxTpR4C&Chtr-1UGp0dDPK2GVrYHSKJ|eX4hQ!aWQlH2+Eg@=OK=LD5<% zas97Hvq8|^X*$LVSmS(d-da;3SS=I2aA0rDfb}~gSU&8|21AGHn+fX0w1n>1Ofu2K z5w}}nJ$Nlmc2vqaW?kl&{HQV&3iAu{)DOvTmnj;B0aW{yqSul&dD0N42T(+j9c%8Z+aWny@5UZ$n39Cb{sGU1P)yA7} z?d3L}5=<6NR}brs0@v3!Mq9|^rIeim z)=BnHu3YyGC0_6~l$*2>94r1HTKh7!9e7NB^d>vi>&=}7K$wJ9JKo?PZnnmYPw$v_ zLSdb$t?XI_cf+1{!T_hAVGD)vMjq~WIDWf9b)9g_%I#t$+GZL5eayRlkccHU&4ydj z6>{xznHrj>-f8M(`X5U)_-PdWA6CTsr%2zseyUP>lgC+x;WJ|1KWpr@>W)~d>ZMq6 z_$;F8h~h2<)n)jc^!g?`@3!r3<3qYi@r^m-*C9(t0hgIgY9prIDxU!Mj8XR%Z!qu8;OE-N7h}`4M(c0k!5t@nViI`F%k3nAf=(w3kbA06(|F^!{G_~(Tt)EMXUvVyH_-!&V>L1&#iOu6ep6uY7g7u)xlb#H zsCxy!x*HJRJkXFdY3DR^FM5=u4nM2mVPPj|VE`%A=F7x`et7F-`e7#p;w8rl7?Oe0 zHe780u}w1cO+pQ6lWHn=UCYK+pP*JByeC3egjT!hD+mN2J(HJsFX@1a$w7W0Hz9_J zbiZ^sRCEM~>S=xoCp#VIC?1LvQtuBVO_}jFRd-PLI>xPm7w5*c(OLp*pqM zRMmE8a$9!|qr1X-8E=QT9OLw?D=FGP?gjuipXLf5R->d)4LVWDvIUy)f_q3Ez8WxB*t+Uq__nOY#VG`jYMh)39uqVTm-9n})M-dStyqeDa? ze;i=#i%vO`u*hyu=X5(BXz1!DCmPT{pANW_wXR?L5M*~EwS!zO> z1htE|Jpn!UP^70ct;3i?#r&q2|LEu9FvIDJUZa>(^)n)j{;vW@>1VKh7U|~@{mj+R ze*CZvFhLB?X*h!K6h*<8=zB-~Sn1h%yH-C}^Mich_V=Vh+p5hyxfrRlNo@!hNG?z8 zOV7c9dh^g9JyOW4Kjua4rbQEb!0PaRNdFWtI>dXA`jW0NdyOmiLsT1(XfS(?BOo-k z@IS*FG`eGLmPcz_klCwQ1}V>KS>3L}JDM5!)o9(L6hEsq=T&)Dc-Q1(uf`@+axm&y zGQEU+Q{#NIS93Ho@(Nu@@lW$8tGOl*UcnNqT_MHAqUHZljh_EPHR^%N(C<%;q%z#i zl2#!QK?LnB?Vy!ZFM50nskXE2^B@nYIPt7ncrD|iVN!KlE>8M&Nh_}5WohB>wSzgJ zN<3io9E=v}8o*5x#-j7)$a{SJ*A}H*bK&=xuc+zzQjy#azFGS*hfhdgEjpPNIj{9J zx(@-Gvzq3p?tiRN-DRfIo4OD325{Me;qx65P~pkh41!(Iyj6IIN)hn{wN(RZ=D!A7 znZl+MfzccVNrWsd)k|Aubsefp)aYY;QXc8X+iOWm<>6tZpK?X!7lusadBP#j%Y7zG z2roK=3gBSr0(iflO)bh6-3D{>OCG@Ql6Poui%Qq|_1`|M9K9yvW9pQ$Q*{;esg3@n zGTknjsRBgV-=xaq;#kiW6~%)KqmzFFZ{Xsm&xH#F*GRsr*QESPW6Z0zHZruG_h3ZN ze~TMRp1I#@LLJYfj%ACqh2!@<)<8WZP}q`D7T{L(3!6EdaD{hS59(Bk*Fz9Fpvt=l z5oK;RRVedL8^MNlj%t%k_D_p9k-w>K9wu;EZh@8nS*$9NQ(|y2~9r7>@1gL zT+$HP^1iXm$A~(XsZlWT+T+P&bc^oFD!Sca=^u zcgr7Ewd{25{VVgKv9l?Peg&In8#eFOOeV*ebj%2Wi`GgX2*|ht8J#jo;Z*KPSX|MT zi+H#t(XMaOJGrVl7s&|8g%zy^m&S^R^oYhk6ZywWwsR0y$U_bHAEqJBC!8k3o9J}F zeg{}8b&kmJ+K9;TPWAJ=`y3hWNC|Eqi>X;m3@#}KCfVhkLuGsrO>klsY1Te^k<_Ok zWD^>QoA480!*jlpWJU1L1W16@bq+R@czTSX}q6mcz;lMF9K3}JrwgyvlmjNhBy1B zEK_2LKR$E-v3-YTQD$I?sbJS}hwyF-8B#1aQbrkP&$7DfA0d|)8T4^q*`g)>-OXT3 zgNYi9{R`-8mo}Nmq9Qd5M3z8*0O)=@96Z%74w22?Ml^BMF6zW-!g{EYsrPsOhaHlx z?Wb??lAS*hLNF!I9o!o%b8YXQHn4NyF=2lf?ajO2kiKCnL*MrgHzgg~Ls$ z$cSAX<8KZ68B_On7xKFF+ZRoZw;k1CtQ=kH?NsT-3T5uTf!?Xql`=&Kl935v_9-o0 z$`eYJy3!lUe{6s^N9ysa;@6_JI~d66hJY5UDtoRvI@NopSSg*^ul@SxB0%eJlVAEK71J0;*Fv zK6vyW4Ql+YtOl>$@&a^R_L44E9u%$o3L4nyBhdgZ#UqFJay)6D*phYm&dgv4$T32| zwH$4|0mDeY+ntQ9x9{_T^h(QA?0gn1euR9AYl)lo5Ty80m2^JO|UT*AbX(?lJW zJ$=YPjjc$c(%iztl3b8YFhft1!u{aysb@c|7}A~mTkN)18spO0*o?SFNY z2murlW)eqQM_3Kjo&0|RWnH^5Q)P5n_fM6&3g(xc@?ha3Q6w$0Aoz5OBBdYO~7MzZrLXx$|CTzB2iK5(SU(BdN*X zIi>}NaF<-(ltI;wVI5pri!lu1yV~)?2Uf)83VD${wME7-=MZ+y$!)v2Q5YD_nDAf! z1iU80y8>6zcb~QvF`U)q@y7r6M=J z*2g}M8TE5{^y1DH$?b{kzH48L{AZ1_5`T0~w5KT;D^iOz<^*E$)bQir{Af?xnyy&z z_HW01HS_Le`TBm^xM)u^T2bKo86=MOoSDzm7411)n=#Rz(@O1;8fuRPHs|-8JI6w^ z7u#dzN*;qqx)?O_H02~u^FONiaqfGn#y!n1DxXJL?&)iI(9oQU`Wt3Z0sZkY2b4v7 zmM@n7Q_khyP)D?$ci87?8!T^17GJbl`WD(Z${w@F+2ib*XwOrpMtcsQ5$#zuN7WF& zQ1uY%^-PrV^iOER%D#R`o{FUgnz;1G>jw9xSF`c9*dh6f^=tmS3FgFEqaR{RHXRmQ zvU&Sh&(|uFw=26pnvZ46Z`i1m6{$%*`u_@u^kLz@%B7P0H+O(4Qj>;acG8j|JSKW^ zN)_fgO%!Ix9#5c6=17-+hBRbOQ}dvRI)4Qr?okkpJCUbA@W9CH?*R`S#*+O&dKhKUM% zas=-@pBw9*izc||lsfmk{SNoMZ|)WNIAzgq`;*y4ilnuDH};?z#(0Du((~W>D2`m>cR>*`wr9`_^t6Au+h#{}vEZ()O3a;u%cJV|7T^MTy!!rV(Txi{=Z?n2hR>>3xn>2e=WZYC&A zV8Q9ehcnU+Ft+~eYB14YXwCIFFv9NY!sKt0Osc3|M^%M|G+h`Q;J=+ke|RaIRqIh^ z3Ae|xb%;^Gv^sDh=Tx=(??rSnv4$`+$;r$l^$EGa0N;|TR`RNx!9)BYFQ;3pPuIjRh2 zhGbp*4uq&Nkmwpk@a1y4BO8)OWyd$OUb6m(TUFV7v1i=XHCCKZgIFpva6F3}lo|_0 zEm6!1?TDstP(k>Sw(=I^;0?QR%0pa!5zlyTf7B9HdMPK9w$i+vh-hqU5VHT!?$_&< zfeY&MBo8DU0dd#b%H&exGw0#t%^wSs<<5xyZmKs;#rOg_?_l-PA+4pzc3O(@J8~f) z8j9MguBx^}s5e)lyj7-nc`Q13`5>GeV^-oK^J4pA{j_9bD<|Kf1!FxjL-n-jeio_x z@hQkZ71;xMBEF?X^!CKX#75`M)dNW5c*rV-+8a=;f{3YZBUvP|2V4(P&$`x|uJ4TT zTtj)}$hLHVmvYrxpiB^O#C6Bo(9)yF+alTiFtHQ&)S&8$Jqx$?eZNVmnzASb6%OEHwj8u}_sbo^ul+@GF9Un8#}nBvxIPjUBhcN5hM z*--4bQT-Rkw>Ct}m!pa$qi4U#xaJioOgKW_ERg}+)u^0Q(PV0akUU@Cu>0iUFWkrs zJYN$Le}^$BWXprSYrd$l`_=QwfVmJU?L?1`so%7o9I5GUGG$9MIX$1Owq#uut$mBd z0ke#YifIb6gd8>o;nu)ZNmr`D?T6j%(XOaR0ilQ@No|V`$ADtVoLJAdV&Tn-%S&?@ z5s{DEE7{zQ)MzR-vvP_*H&bL+Bdm?T+e8gRFX^;hC`cw2tI@^vmeQhRm%Lah(SN*Y zc`G#TP&8w= ztd;0bj1z`i14CBq@#fd98{dU~eYbd)~fGj}cXo{M0}kC=gy` z${yhq(tbyn`VqKTbTnLU#A#mW>GqY1PPH3H)nYAPhM&Zuv6Zo87@vE1h^(_-Gh~_77VT#h1aB5* zkfJ~if>djkpdnxmuP`5i65$g7#3LowsRzXgD%Dm>NJA#B-*Lu?>&cs?wcQf7eEQMTK z;|U4K+y&_biDVkwd|KFCkT^|kj+@NLRJN3!f^UodV_Xbj9g)y<;>MCQ_2AyXaQ^DK zQj;0?+ehO&p*gDbdcWp(XZ6Yyx?j^Nw7U-K{`DMM5ud0zG|LK}eg{R_BA7~8>GcWG z2HlkvD_+Wcx-=}>pUff(sr=|XM7(Uf1cS+RA&kz}V$ey+i+vEohBVngF{q8)1LNWeo&$U$|+!73g9gD8a(zhcWKt~<1~Ah#_0q|+a- z>9ruQ>9rvDH|FcBU;PbZd|`T3tsUFner&QTj3sXsAis)a%j32v#5Y)vCOPWk*=iSm zE;DDu8yA&ix8>mzzi;A3BytY*zxtH|Q!fr66BGC1Sp3_KFq2p23m@^q5LC}i+-04U zNgvZ2CzNo&&D;?!z3cKaz=jg>_ zQHjjf^cw7Mx}qB82AFX{EL8ZSnBXhSDW?8Kd;^WjoNoweJenw`Z~{3&Auo;g-k1U@dpbrB}CdQ<1Cs@~z*v3*;{Fg3cIdrPL- zkSVrRUo`$A$!iu!Y-D^rVGAj3ziIUdhNcq%W64jhjIY_sHIdv=ZJw9AN0#-?TD6&J zxGedeKS89#JpsgtBi3$WAyR<@O*Wy{uZwC&Gr7V(yv_#}TC7Ee<_(;Xf6ZE1fqfmG zU)d?mFW~6Iv|KU1C4q1-vy^v){8uE8bM7m~fzmYd&kN2Zl-^Hx0c>%N=aS>HgTslQ zO8+rxd(M>r5xfAZ)90f+Thutax&e*;&cKftCDLCnUn;+o8TKYiROkx#=@K$D*%r{& ztm;v;`nXOkPIY|=M@m2NXP+QagoI7-s7#s~*}t7wW-bwoNgnW)&KMf{i_SCIK@{Ya z%!kr#2n(u#zaQ_F?wv`FQ;a#9=v)=5yoWVfDwCVg6Fl;*{E97*z{3P{S!hIbokm5p z_QMUrRAlx})G|jZ_j*Mn--b?AN|m=rfc#&Et7pQ^K_@g>8dc5zkdIXqmHbXKmum*5 zr4&R%PDSzR@BKPU(@3s4$;>U0iyv!9hMxWs(o!g%aF8z``F5VjsFR*C{y}2V?8(<>b z&rPIh?qy+o_P9|2Eaht7NRnh^i4!^)ydhGXdeiy~{qbh9$?$e6)LpdcLI;o<(c z#nA5?B%%c)gd^*>Og`YfVTl~PFyGErL?++&Sov&|Pv!L^RV>x+j(TYvFT>+_pDJW@ zr+l;xb*E}{YDZ}xgUK@H@=hFJTW9m-`UpSfi^NMx7^U0i7-A;%hs%FHwQJTe#&f4# z3mjIoyYaf)HU5%^zgK0;EM0l!C$B{pP;cx~7{SJ^zcf?YQzlxYT+zY5@e5#!Gq~ds zZG&ew3s=JXohZo|lf%#``V&vq5XlNIhwf2rMr%LCiy%HtFqvy79@g&rLJg@ZCSrmYj3PF|eeBMU!bb;GFr3PV)*LuIUELk-S-s+_x*qvTL4SqKb`gSM&U9 zdcimbol<5$b~KQcEIRK_%|`K`TLeRi0$~p?6vA|z_5Jn^VLHzG(Pu_QcVwuj|2I(4 z1vRE8)O6@?kk^Su{SK_Y#yG^>v3!m7oHjwB7Sl%PF>vlUB5`D77eF{2kR84myfKz^ z88Y^EbClg_QksHq;WjD5)tn{LYVJs8Xl6HKPAH5x8Bp&J-Vb)!*jL&c9z^#^I$mx& zl;{X-;R{!jD8($Yjg3z2ZPX#zR9BTa9!D<_(qnXQbY7lpcG|Qz257<ye%|B$z#9Ge-n=v6|NI#4iw5WMR(I;Fb#^wD))>fSBBq%P z3p8O6TWuFIe6o@4LZU~$jUrU$4coDDRuWaHt5sh?(MENI9B?-!5cxqj- z=&*&US<@`uW}H_2HRCu0fL1i4u9wms8K@(%Ub0RMJJ1~+q~~0nM4c=kI1h!u!NrMV z7-o#=S{?z{e=#s3XGg;&*HF~M@iJXTVCrIo1QQ3-Tg@>4E~KDBl449xnx6kRGvvAg zl9h8mcDtKRn}-(Ch`6&z&<3r&`8^ct4fG2yksD)t1iRHNmJ_N};++W{{%WZ^5cx%- z$`y=3#@5qx9}V~yYZ~d&qf_p;2+p2gnqBGLXrPj||7-s6zI4gQGr)xQ#C4z~K3JLo z*U)gIJvmJhf~7ddbP0cIZz}S%$tNZ|6b*%{{5+0WHEZ^eet*^M{ua9wTiEI98Eh?E zIp5z8zhEs2r2awwy#rPBcGC6&{_`yECa$!ZX&MhDwMy79wZu!U&9Sk zi4VkXQjsfO24%6{fU14P#eBO&MW)0(ki!vTrM0?#mNBdovTI%lrRUp;U?V%p?!D<> z5rd;ozDwH6c4x_j)x)4{J4uVO95si|30Shq)NH2=Gc{&q(uW40-6RG4=3P$>zPYTxu3T*$0 zD%mB;m*Y(GEjtbY>kj2iMMe?JSeU4XL#F@PS!~vm@nrvBz6x3I-@}tCt1y2m@4?~J z%=8*1_s?gp4Yz4@(Cs!UU%kl7*)}Icr?gTyl{*ZJ0E!vQ!$}vrtYKa_{>rpr(j_q3 zvPE*<65R8lnmbplIXzPjZW}zpEWfA+Xazf4qg(#3sdM8Nd<9OJ zvMW-!W0G@fTWspZGy;0b2bNqwxaFGJm`A=VQj;u%F3RvV#b3#&yLBTG3E*SexfFtolL+5y2NbI2;`}PdMrW zj;`A-q@Nwdz*D)qerR}lXk!{rt3L%#owzNUy43&#ikWI9I*}`Fv%{*l(Pqb#7mYSM z!4TIpk&jz~ern5hV_F+DuLKWTgt1eX;xPoaaJF$N{-KC?$(?gm^S<6r@y)F#?Zdd* z@?SB5RaE_U%rvcUq5qb@zVFZ7%Wta#{v z>eWa!HnX?*Db{mUr3|gMI76%8mX9c$`|F>D6BfT;-Dco59KkC9vl{jX{lK8Dw?&ai zozC+?J!{vYw3nsz*=+H`SYQ896`ehTNKI5LfklVZl7nv8(%M+jqzR^>=|nGy9aIf5 zivAQjW;PEO*`}n9Chnxaw$ZkpYbBuT2LV|W>Q`O2&5Zj-51V>aKe-e07U<2Nr&x)< zZq{^LH|gs4Sq>@(d80eU+<{Wny_2hZ+|~WCu;VZrG|)8gf~78m*ONlco&nWf;{ z8*zYGd3!i20#9PDxk;Ru=S`bI^O>H7ZI0(T`VO~u${zk5oo%$Xj>L3gcPgc(@A8aw z+oP`OgIZa)MW^Vr74?Ww7*wP(DbQAdKQN6;=)Ja_XS}2Xu(kAvBts=cNS*RkK=7M8f+T&#!T zvfaNO&c1%iaJE@i>s}AGG1T3{+6c7JNs4pl$83wbQpb>%1 zt?R~dR;1Y`rb~8>`ilyfv7)n53{G#XKsd(^p!k^VS-sO_$ZCuMI?W8d^N$b;zV(0B zWdAaCr2ewfcLw^wrj@E)$-m|p0wmDxy81*S8Wo?+)U zLvhB&GhKGirnqe-sNw!|6S;P)aMHYAKY(_FcIsD7qS3Fx%Q{W%mXiL-dt$b@G*~O0 zSvcTR(==Y4u=yeB{a+cX!BZ#@>TRDLn#c;0Ytlg&S3__;!M~_YKT+AAD~a#BKQ-OP zVVb)B+;p2ylQxkC*$g(Q;NB;o0uyZB+}cN`lxB&(>Mf&yweWsN0X^P_0!E`VMtA71 zqq$91=^=Fmb7+33`$>xE{$3q7zP!0}S|6WhGb~F+g?2N+_-nw6E|HoDkxJAfQs1DZ zU@(%oz0oV_x|h(aT>W;}tQQV39ZON`kJW&Zr)hxS7IReIJDo4tbku=00=0IzQHoZ6`GOy5^snR<8v%$Pf? zk;Y@*lXc?E#a~xn%wp{24O&(ey>5?^S9vt%k9nu|(5%?%agk;Zxch#;_c0%{+((R; z5?nnYqD>`Ff98(wDwA9NJMUy-N48n=E+~>4FDB-qw^;rZe?5K!eK9 z5tcRg8X{EE9hv0yO_E=hN#2v>e(iuxs$G|`h_ft@%;#{%g#`~PbBbNM%euYxrh9jX* zY6W=z#m_c1tlJM|a;-XwG@m(qEEV>XAH}qAULT9MF6iXX`FvADeB(u&N!A+0i>w4! znZgTEqvGMC&w~cL=sB20EY;KOf7 z;p+bVtZ>);U8$vO?rq%l;vZAfF3UgpO_Ap{IsU3vVw1U#ZtTOIxi_>#&^uitB9)sT z!h8~(I=c9bG-;Ch^oKOeQeaZxQx7yj(*W{kh50YewTH5uW)k-w#H zo5(iyNbGoY`9f@WT|4ueKj(u@4R%?I@YzlDfb(}uVk0LyusHNRmN!Q>kzoR!j2x#& zePn3(!GDn+qT&a<=_-De;%zKF`dcH;e*Hd;v$n3{MGv`(m$-^wL{Jq+O0$alGq+l$ z38yQ4D~_BN4loK{?_Z{lqOvQgY%d3jIu-C1R<^qUCL??6Q6K3Re(>A7%0BsqtL$5f zx61zUYhz_k%2f7r{0jI758|$$RPJ%as%P%X+<{@;_RExWMw40X7g|{=9eTu2k*=VFfPBn8S-Np`CetbLbuRd*O zyuPJ!6Cs?w891jJ9OrfZa=~FG!+!P~!a?rspR1}~pDdEwCEZ=%_zcV*E>m=hHl$#; zM`to#Psa3|^&KqMpSIe~S(<}^G|yP@58?gX^Or$w?tbo{1xY=MSHs9nq|#q{R+}M6 z`@&voN_wkn$4C4(r?awcWB3~c%Pl&tK1&X6(*74FKJH0mSdx|j9T*H z=ki{f(S+wmYsWdw%bqGPT6?BjgdF)_bqA+;h7qnz{)egEiJypz z)-jrBFTuGdKh!vy$Wo|?AHV)m@l_lknGPtja=P$HSmqeP?Evw|zYYq#F8A7uz>Yw8 zYv6e7Z@Dq>hNT*gY_mc5S1AeV(S%gvfm|Sl?b_!4prxp4*S+nZ^5s@-#DC4jJv=_+ z;a3oaOcG3%R)^bpYO}A<)BoG)7v_V`;C%*x+rM5YEp)Ja zoAA7C!Vhf|{^vH~>$eGCwoQ1{<)^)IhaUR^><$6F`7RE+fVkvIoN)GX3^+PtQYJLri2F8D>zda)d z+rAk@jtsv02;5}aO#c3Vm%lWfzurb@nE%mj^Z)ckAGzK5<4@&hS^kNo{tcFYfy(#K zC%d{pW=5w5Rq(CG%9#B@^dH-}!1rGR%(6L`BdgZBpvsyV!YMbH2Ar~drshGzYF zJF@EkVShp&=l&Vq;O6j#{NI3=imU?v@ku#srEXu{Vku@F?GF2z#s98gi%Ib$-eHSp z^6;atG;f{eqg3SPKjm*&+n9eBmwzwif18Q2DRx}`W1HmPVPTA7gL$uRl3{zhc})PV z}OJ{Ty3tc|>=P~25w2@@HP>t~)S;5*{xg^nkKn@pQ$rqVmxeG;p=lus(KcV+VHU_3A#zNkk!`+EPFFwOER(wwYvb%&^xDz@eK zGw?rfjNIIIcOiuwey0I&=7C*Azl~B6P5l;E-zWV}o+Ugzovy+Erry;Pb;IYuGUj|8 z8nAM-&REg-^|Rnkt-Yy+`yBI5&+%u4-*<>5PbtU=&Q^-}vK~#80*yrV|AGEoz5H+c zb0MGpravF#)Bo0=lfpEA*Po{w`2Vdxi|3AKW+f7zcOhTs2x z(w}W;&fkpBAGI?0>+$(6pZ>T0d@@Y)cl|lV!2fUkd9G6Z&;2QW81~p-jL#m8U;nZ{ zv%~NINBx=hj5Qp~i;Fqdc`+9Q{4l=5x=TWS9)Cp<)u+SEvW1@?SyoK?j_DHScZoFJ z*`d*CHkW;jUzssDg>8R4{*30Ta1uPJ1TlcJhl72q%9`o?E?i_{*~P5P74OGTuIAhP3#A<*QLfxZ4z#~?%pv|(@bb-C~u_|w5O{+8AXeq`?l#T@?)uT zr?bEc563bDWP(@!GKv;Wd}7=$5Kvo|Y0)uqTlw(s_}fI=x`Q{f_G&UKnI9@4t9sAeW;2x;j79c^ z{z4#qh$4V;O}@TVq}ZSn%7}D8ZX;=!_c#9r<%=Iuz~c8MYFf$l8sT&{(J-!w(XwYS zK0KXW80TP$4aFgvDmUATlm=eSm95y!aAf`huu9?WHTSvFJEya2XRwWB|DpQks^s^< z3Y)&JqSzzo==0OX5>Q8fwm8$#pZlu_Xk`$KCD#R)S+S**JCS0`DRsQd%b5$8_kna? zDfFfhu+BIhv{xm62~Hz_g*S=3Lkj8MblxE@@0iBC++S|xhRpjX?XMtQAhujVrRgH% z3$>Pm!>+%qXSyqo2?rumzjFwJyHHPIL+LI7X+9(C+G1$&N?_uY)Z^HKgGm5H7|d0R z9LyZ+NB?C788h?TERV4rgD~sw=zYas)BEBux{=zTfYDo_D?Pnpso!{`PhK|KD8KtoJz|@B4S(&)H4yEydf=`)D`4^O&MT?+3vP zJ)r5`a?$&!rs@4H9`p%D?~@Zgp!yDm>Su@pd%tQqD-2c;!e7Mf4dJgAA5Hj=X~JKw z&kd3G@6t))v}`b<%}nin#96KrsZ+ChOSs~29t<$!x6!Vc9BFpb|Pem-S0AyUkhfEA)Xb6cw3i3AAd4z zfl_EYYqJt@q&A$@|0gWu44mPvj)jnbqu&K1QlX%(kj*7%7^gy$?4-yjH%nQ7T4x$Y zIY}z@p03kuR>@`;BqDaHP){e3dUcAF$8ZdvhcO%@T^@+)9yWY~x25AfE@b}ici8LH ztJzs<1Fax)!#V?+WSwQY$!1FD8wNt++HUhu)Fhs&6Q5=he^K+$2CVQpO()}}rueCV zn_xhj=oGj7xY;;6{PdHXpNif5^r@yWEkC@5RvmNgyYvL5oF{q zLFy%tZzygaO6$lso#gunYfC@V?nd%0vXdl3&xb`M9}duqQi{sV1RhMv%0 zr+Txbs^y|d)yTw4omA^p9xUWa8PFW>aQGzDKL_=9WTGT1jC};-B#2He;#^{L>zfQh z-Y40qjkG$vzYy%%gxEy3=ObH3Y&zLKDrvfpEE;B=Mabiu9`azAF|raCHYoXhWSG zXZ%pt5ZQJ92R6%_z>tJJ6MrN&4R0yK`Re;gyju|(?~k0iO|Q{^_8zV z<-6W4-&GCDcLK^cz%C!p(>E+%!Ib1>JKtTlUZ!l1G}P}ooRFbJsx$!aiD@|I@Xo3i z857@rQ!A`m%({SIUGWQVYaDk3$T}V>9VxNDOM*pAFTuTo1a9cwI>!6l z%=p9=zIF9IqZ_RU=w0IoU%$G4D|FNB_UPh3baroktl63T$iy>)R2~ z;Sdlvyj9?UD8uwm=Vx{Q_E_DV9WVi5q zQ-(cl;2`VYeWng9zy<450nk&?yY&TE0#-07_lK(3O_5J590cIPf(q0-U^IY{s>>m7 zkjaUKgMfwFr@Q#nfT0X}Z&W|Rf>aBim&~GhXra7RRyAPZCK)Tw2YaU2k@eU>q;M!- zKVOVk*ux{E$tyTNjd?;$qN$!Jl8t(@2u=`=quw3D$;nV}m|Y~C3RVM{I5_b6<>RCr z(Es2rcJ) z$~st06#3w8kkRipXpo(+>XQ9{zT;5asrdX4_E+(D884|Oun<1+ivQgt|9qo40u=Z2 zJGkBuwDw{y0;T;Ba372e%Me)C{r68?Y@E=47udyRz{K)aV?>J*HPKORnk?`3S6t=& z1s3V3t3X`CmzSVBa)!k!>599CP+qwUqXGwH$PRmeAE{t--&^DlSi0jM8)qQWt^OnN zKL&tQDPFTn`H9Y+NG7h}Jw1Sq{yu(S)$CN!Kb!W7{sZ}e^HB30r@wOhqA@PQmuLe} zT0$rM!6<+Sqy6$`(RpxOBfjF#vhWYC5?dQnn2vOz=yQz3RsMO8=s(fi3yDva zxX7K2un}bO$;JmrJV$>@_(5yP=e<)}R?Ky)Tws;-bY2M~T0OIrG2pStiMhlW(M&L*XCO~! zmeDblF=}b@9x-zbzWA)e$F*XN`)~QyVp#zuQYUcFK&bQT*dzj%t>3u<>+#=UES2sY zgom?dPQpeE>kn+(I}w{oc3@EvyE6*ui1ff|Tk%k~)sj$&xlL>rJn0hnQ8u&{(OQ7D zVb7b+e*YA!LY{62s#Yw*4vwdd-qEA1`W50VzTY}SQoNriFQ9)l#M)_{ zjY9o8u^V=p$QJ5LP1=W}Sl`1L=k-`7nWT00Utp8lTjGiLQZe{NSyrN4XPLO2P_C0r zx$qXH=kExrIZWN;pj_%@Y_g@{Tn%H5E*r{LWx*2&P+#d? zUR(W;S^`<_sz0g|?%h(?|1($pKToXxKjQVLhpYZwP5qgBy#7zJDm+Un^@rDAss92- zLj94IyZ*2yt3QSw4eGxb@!a*#YNGz^smSHf6~8Dr7n_JuBIn}Whib3rH#ih*{YD?W zTfrCiE=GNGtPkN>SRKqND>xK);7sx0L{Vlr)G+_Z!B{D84FT`wkNEr%Q6yk} zDeAY?7k7o!sb*+@87g8tC#txtB>aX>3q{Th$xia}YFz9~y3dbX%e93~1($Q)A~R&| zk$H;ztUrU^3)ZrntwYu>^;ju+qOeoQicts`g>VB@){3cVa;@KVLCdTa(_XdK%qp9> zIAs0AWTCrnDts=Gg_-GsiJ{0%OdO}meTiw;sT`elJ6t7`-#HeXfz537)2FAxz?`P| zb0yWYkU};zR8gPs;HiHbXsKCYzP@6uMs1+#3nC6#*gY^brMi<@#{%7!883SinZ2!y zB%i2m%55Okc$BSK{N)%~AH%Ht>0Gipvif#|S6s?!v_3WhMWTB3KV2W|MxxKg@>ptv z<*~NF&$xVXjVJ%o`k2Q1y&xBnLz;q8)U3yOyEHKtti?0QDd+>J@T+(o0H?Q7%3qW1jP~D30<(2Tr;McM0Ue{aRCq=(C0>41$C;l-jC}`{g<5u+HM8{ z2w1BaXw~yH)~Kl%%Q@uE{KolUe3D8i- zqy!)n;M^0SHUU163-nG8WW~I9-HR%PB8AQJqsyr;RJTU@!SL$TeC+JH9xtO{z4O-s z9AH1`-cLBcf-RWeLv7$idb!c_>+`HUUP4&-39rDxbO`R`kuY4tLzvcbqhWq)26>)A zn6d;*NBV`O4*lRxORQ*lXWxbf3!v$l+7(x4@06(DsH`@iMMx!Pa03?%8fb|lj+#*C5Y7YIDMWEnAx2eWYRPX`RN9ee9o57;$-;dpyW z>~UDl`m@-*h#B{89qW{6y$_+;n<<6uVyD0>-v7EkQ*hE8u6Ca)G-=z9q)!XaPH4`= z{w(Yjk?WOAU%uirW%V=hvZPe6*7ddPS|0amUA@N5UfIAqg9w;^90-1lk5u#ZOviU> z8D1X>Ms5M$ajXBYIBXy3H5P9N$ow03a=VM`EnbN3mU94{F&v9i>jcKv2qD=9S^@|G zXu*^@e=t3fn=z73DwXmJU@+zhS2-@!<@i>eA?3I^BVLdWD9Fzrn1Vcw1l$EFxXct{ zvx-q?LLrvg(+f+ijyJ=RsaPtPC5oh9BS?s$dKxMzCx4AbB7 zmQRU&*MNRF)9=tz>*``>o{`rnR4=C8#y>rsz`3@_@wID2+{lTpj|-uZP5^pxvh64I z24(u85R>=AgO4I%?xP*09YD7fPIeoB0XhNmaU8)t9a9ee>vhAbuFc*fKH>Jh4O5zq4#T~VN0pv~3IY3xZXKytV-NwMmf@;Gl>L{0)%A`7v|1048GsUcKKspEd>_06Ehj3xm9Sbg zUe5po3q&W5Q+p08fK|M&VxZ}kgnAN6m38(Si+)ji788*s-kqXQ#g`Vf!F zm@^0|aN%EUJbE8=NBT~Gn1R#QkLRH32R!6pl_9bBVO3qxld*sVHS~r8iDKSL^+2Iw zqd_!KWrxgX0owcn1z2`D%N^}?$_Xe;h38=;!#||>Pxz`0k0PX1UX9H`<<)I4r&xVF zIWq$pVYN-k0t#C=XnhOW>0!4FEl11Z(n6=x)LJwENaJGoP)uL;i00H!QKSZVVkW*Q zoI!eBG1nM~;H2YJSmlkGLLaA9hoJ43XR??`Ex?WdgMP^k9=PhHZwBuqJ$ebzTDX^ZCojv;B!Dw9!M(AtFoO~9L1i3&BZ#37Ju@BOPoo$>lM z7H^(Jbr8}!i?cjEHsHWXzEy?C1@fbzw3PhLwLr(TW&@%bxRCdY>8GGR)34Lss+!Xr`W9A^T0HY!OS-F65JH9Pkn}gA+=tN2SRur z+}g!Gt;;|#oPD2Hy_Pu1r+WA|ofDQEa0jfTGgKajlsps7^*5@C&C6rwB2-CWxr9bj z;azn+I=ng%Z7&^J{T?WCTOUy5A%A!2ul7V~5kJVNkF~bCjgj~5 zNLQz3-IQCnJs5%J7wl7zk;?mzag{$PExZ~fykK`wltK{I*XSRaL^0!n=pZ!AW_9fY zsQRnWK1ps&2e+&5BZ+#{TQXd%QQN>GCGqlUdJe_u8M;UwuIP_#gFHK^{QWPz>lXw zT96+fHvEX?1pX!R;~N0v{qti-haYEw5Ss}<{;fCoaS~)#d^`!wp`?rh?1RGnQ<|5T z)XK-9FNlXM`1k4UookVvBc2c6mARdQsX2oM^f<1BIJ&SM#1RgIL9s1;kMd-*D$yiX z!11g)sstsD&*T)sE7?rWWSPmj(4NUUJc39dyy2M6!3@@P(52C{fZ0W?mQKVypS9;1 zH0r|mcnVpkvmCDZoXkvTKIajXP0wfDtE$MTZ|UZ)KiJm9WF(r2jkBoQ*#X?f*0~no z-zt!`1_uE(_{)VkL93S6$$0bDP{RKiXubx|dusgOCiwq3+mHC~L##K6bvQhfhr5X) zXYd`AQ1jmdR*!&%2WK!F!(n z;U;Lt1>T^Di@H$fU8$>=XdNf79b|Y(+`II`Fr? zz`L9P9eWIM1?Oye^Zz>DOo1ZbB;LGyUlP1|6mW1ryg3Om_pgs69UpvtItVw0PK)a! zaj6@K-kQQWU`Sp)?+eo5#4b<9L6gN<3iMAXg6(l*Q*xHWTqN_mP~-WO9xg z8-?<-YOu)hFSE$;i+XdmEONBx_4%D+p{#8U*Eg2QO2q4;`*RX(L*Xl&!%Zo;8q>)- z)k37Y6{&u0Qr)bs(Wzp2BbMKJTchQT6ZP^&dkRqu7_x1O$E7}+?vVa_0n{T1YWy0q z4P%v1bes>OvO74$hv7VDIU!!_II`t^1bEiSkK=ow>1@PXvIe8{c=WKWumhH&(5Be@8o3nzg_-IRymPifb+js~4<212x3ic@f*+x;srfV6 zvlQv!?9ApdKiE>27b)P`S!~P7)0?kumonFwLn1rXHL%Bc!vVSYjae8Fv3BIO0DRPV z>IS&!s2!CvIF1KlioS2F_&DG^V~dh{`IlZJ^DN%tUkNP{&-brFB~ACv{hrpa|I;@h z7@&q0;QGsxo<~?>!KKK6+SZR)B*s+Dcsq&Tb)4gVqA;=A(>LrN3|~wMeGI=)^y!Q; zWE+Yu&M3uKtuG?D=rzbn?6iI{%neI}hop4daWXSvw9?$Sut9e#)Zbx1$gFVOSSZLWTI&hJ+ zUajJt?=shj20ky)1*0y2dn@l<-=YS~JWMs(Ys2w6@H%#3G?Xz8^Jd^8SuhD@jIwGZrC# zZ}D&z1*$HK(tq}eObz#Mq9}5=+Jm~$@ZuK>#aF*xLD+yb*SNDNb9ICA-7hMab2HXR zbEVqlU>ViFi(P%tr*8&N(zqIa1H>Y`s8kA4oUw#oyL-gK?s-E(O+l^tfQbsQ2O^iv z1)urGC!3WX$e7}Z1zUJdGoIkmTufBko|+;4W^yhvIhVL|77LT;gHYi=Jl@$dk%Z^G zp2aw7RI5iZe^g%uc|Kz$dBBAhMo*6VSGB=4D{B5MR39z-0KXCc+!1<4(xaYw5YQ0z zzY10XEuZuNJPKYh$)P!&6k{oK$a;GI5$~mBV}Xb;@siQq-9=h5g}I&|GpS+BH{We)d;Mvqr7OtR$2Dh(Dk5=L!Bi#h(xG!`!w- zAwA!5hR&il#O2u_!81-(qnCaeZt$#)fRpF&mo%R3BP)je`<9>(L2D=B+xmp4*6S<8 zARbJCLPAtKx|JmKn4Qpx8pm?66C0>@v9?WvFBowbQVm647iJ1Y-w_s2EvK+;Fj;}S zXEj%-Y@8ip9`gt;V3|roxK;eRQB53#{vo<;RQqu!nepK)Twyi-o!4?S`M>>=}lrb?G(v34nm#IcfPAC(Q?oDLpEuM^|ZKNAM zlSqgACRreZbkdM6r2EVuop#qqSH*%0(xF41$PXk5bs_)Jphk_Cr$F8awmsa3h<)={%Oe^`wkGO@l1V5 zz{&D#!j@-ml(!_S91wQw?=U6cU=>OqJJXGW$DrIXJ}V%4Q`Fy?cHG`>+mEC@!?FKy zFziP=_D!^NvIKayljhw>9p)Bkp!>zsNca9-N5fnSGjOmocGeJ=Y#gjpmvamSnj9d* zqbV7gD$khGRUczYRXvO;MV&$u?u}oJrV}i@>gU53DYP~36V$L-`(-2c5uL*gh}!~W_QP!d>AsH zO5H%}c=c*g8g;yDGsbb_RJ2zI^d;rV54fkDIckwnq_;_*J*4_e3@y+Zj>3Ypi*=W53AaGVRdqx-c7FwKAdYuG z9;i(u+qcNqC`_svAo){I$}?kOD>o`@kvdd;k99@ydy>Y$qEitjX>)54s?EWT4 zkwF3NS!8>jDxUuG!8VYuw*<&z&kB%t{SY4BVxCeqeTEu3-4^QuxeMG;ClVO5JU!PE zum8ji%<8^lfY;k$GB`Y~1+erqq+{&&(ca#%kEgx0W51F1y^shde2DffumgXG(_95J z@b@`UgjQAKeSlTfz4(*OA6)7K6T4##NgDS(vO)r{b%Ow}Gog@CkliS%X^nacp~%&b z8t(9^5@X6#cZuI-H4Wct%u}qY-o~Gv{5gd`P=9NL|Cqwic)W{EybI)8ug*0-KGhQ@ zIk(2xSSnvty^23?;>Vnc)8hl`v-#GiT$bF)y}#C4>`MIzBX#b*Cz9id=BI_;32@`o zUc8eLjGTq{Ofb-UCqsG}oA}6_A?sR& zUe`&0=;t&eE!rbJGX_VD?!p1wRR$<8Lm-td=@%ejuG4{$KeyAZKTXHd1UxV%Kb!5f=`1{Tv*(N{TRmY+19^h)eq$M`<``3VHO-iM zs{&&Rs2gcQf+yUqzgNP}MP`S8_5NBJj|v$?{Fe=AsE>&rHGrB^#53**t%_yS8upKT z3b=)5U_yFm+BFN2$)G;~La2?+(AroFrb%t=A3EA|+{f*;zSOp#E*5R95H>PH6`K}h zScb0}bBkLW6Q^h9X%P5R-f_@OL`D|c0P4v83!w&aVQ>C;r=yKsfE0~3R*D>q4&_tb z4u>{&2+FO;rrB}jDy_Aib{k2^zrg$H78(miNEnum(ZkaFQ4@PadW{J@;#Opf zL8+z{J@?j~qq`y&0s}%$dp%F3B<`jMgAyS=G?f9Nz@46l!_FCd9?sUQWGb$=T7Gjv z=`cVgUU`d~vv43#(0Q+S##244Q}2&O;jou0C}~+4p@Q${ zYG`UOLcRJnjX@I4;lOyGTs(<+8YK=`Sc&B0>H{sphnXf+5gm|PMmgy*N?d7#O_MH0$ZCZSf5zNkzVOB<;*Gq^*xC$KZ@jsFpP(DHibY7$=(Ge4*m-58&4GUMad3Q&qH&q{1+_D0)reB7xG^sOTrj*n|m%Gew6 zcpSU#_UZAh(W?$YJH&Q4de?9C-{jag(EgQUUr9SJIYe4(X?_!C=wY31M~R~T4IT`Q zX9*|zKcjgP%>ZDW4O>->(L#+n8&E-(I2~WoPH%ORxYVoTjZ3CF%9woW5SqgND;`7h ziTc+2La1-$%nfP1fI(n9^;enddXOt~`5fPBFsf13N@-fipGEw6kq=>W|F2cYCEW1l zgS|^vV%}op{hhE03{R@&SgU%Jal6%yA;A?}e1oj*vX`r@x}|sN1}I=W&X{AZ=ZKmb zgO41{{Wul~7v~LftsfxXeV4P02Sdfa;%e^30S{Jz961X80uM;%lA>`$`1|`f69-Dn z3GZoHaHe z#M;VfSX&v2nqA2%)lbkWnB+`tN^-{b;o^+$Y#u#8#Hx3(G?%KG3Mm6f1RTcjN=ID@ zE0ESh>d|WtZ2Fq>%o@#((!^l66r;s3NutacvVvV<_-Eqsp$KG^UCRLcZFvmwy8cmJ zzk5>Uty$KISDJ>)P%v7!gXf*Y&`FV#_C4GcJDvbX++v4P5|~h#QsykJ4&qH!y~q4s zpNIXf1b6J}i+Cm=+UQ*C!Hgo%NT8xPBYyZcT!tye;tc!PEn7koi}b^_!eDZQ=O4}U zT;@{S3_Vm@!J6Ajz6h6z!blvZ(Of~Ks(%4cS!^GLAzL1$0!>Q8OGmWCt>Ey_l!wWi zt7lDk>`NTX;dM4rc~EB%@w^IhV0p6bd|(dP=5U#)@KTnDXSNAC(Dp{qp|&|(HpZ#0 zXP5~(()LEsF}7K@nj4ylcyiF1vWE(d)f++B1LOGBGc(=Q7(zhA^TQ(u#|{ZVv0*?Y zIT4?9HYgf?HQE|U zRR`yUf9M!k5%ZCwzM+1LDprDg!Blag6Q)8@(P`RKbqC$ivP9UdJZEUm70`{m-q`~{ zy)faSq;4>Imp&+1Fy}!@lNy$E+8RV#-HMOgF;Uc;?8-l;sad!6owFCoG;frFkWu$+HvPE?} zaVilNWC)@JE6B<(Vo-)=oxWh5;2E!EfnCX)T$LoT4P{MP%`YKs?7p@;+WHXvjNWF~ zhJQSmosC}aQFbZ&8$hbIqHV4ofn^~UuZShmG#yZ{->#ul7Zamdc#;~VuZ(U4C$$(- zgabv149K0sL;zMe#{!@f#9bh5sb)$@pa9N;0&JH=1Z)?|r`L=4Xt2GA&z9NkZx3tZ zt^cPeu|~Ee>AmlazZ3^`Dq(T#WeKsckN;^xN#&4=nI4t?q5s3;@9F-K=~b_XmGYF` zFFRq$5!v42JskERiz;*)DO5TSUL)y98^cW$TBgO-)g0vWPrCYVhcxKwGwDEjJ{1O= zp4pls?XFgU1$MR5&6=a_Znnw>va9W022URZ;<)k(>1U(5LN^$vKEu1i?7S)#hVqhM zl)gJ#Evg6Y0VumAbl06ek4BKMkDdQAZq;P`GCCqY2Oo@|YT`HJ7x9beuH(<45%KAz zZk70+H4m6}ZU-?Fh@f?Gmfl;e*Ge1AK_K;UCiRgf^(9W~Z<^HUrH(MAlTx5`DH0D% zW#VU>_@z$#MJ7JI)aQk)-SPU}3eS~WeP&3d_d!6IY*defQ0zhA`Z*e#?-t^DU2bz^ zql}U4=4$Roqn1jx_8e4*XfRhC)kw+kbv@IAm;n>BM80T76Eh%f8NwVChmmkpC!3fO z0x`*j!mUsQB``*N47aaMj; zyUxY;n2lqecQ?wD<9&iPXr?zqCLS5V_R&XG{EdWIj+Qp$QO4oNj`QG(kwdI*6um1ZmA6 z><__XGymA<9hnW)K~wDl{cwY>kk6z>R@Fhe+d-C_AZ60{W-ir+$4YTTp7TtoDmtKM z6Ll(rX{`A~@%Oa7m--IKk`gRY5!-ih4y=lozs?dZgAHMMn*sm)Md8>+Vv z&uMd!F~oCR%Y`DxDwHC+dSbX9>D7%wIdDh{N2z_@S=aA?1e>vv<1=Si9p6uiSDP`$ z7`i&4({lx~1OOT_vw`wZ4}vfP!Z--^^)(m-oq{1dakqs1%-LdY zo`79QQ$!LRMl?=e^oahs?54DAWT z9f(-i!K9QyTshOZQS|^REIUz%v{y8&VdHqXnNy(mOK0rkcy~68f^a5g9TioSot;R~ zV%5l08%2SwQKx{(+~F(WzARPe^y5sO(`$4?d4Wn;lijEm!XDyn7+ktNS@NbkuPvEF zFAPU3rEpmPAq^u+vs;P2Kz_B9E-(euVwhrec#ITB7Gvk`L|=1Cb(Az0^yJu=ASRh7 zL1>KBHQ@I6LOm@bfCo(%Yp4aGi-sNkBW3)>yUJU6XVsv*I3(uH@h&}fPU^1m7T#G$ zO45cl&?fAI*exVkBu-Xl$?rh-#VX*)Qbkd!VB}b84_2!64LI!B-C(TL-Iz$k!TTR~ z2Rc_aFAsEH9sX%IvcCOEe0!8xD>$Hy^gTRa^*uCe-R(8imek$OMjgpKE@X|_5Io?y zPkl;4Mxlh*KuZ*HyTm)#lGd_5@zd1nrZy< z*lZF5mc~|??@S?tdiCq|c1QkXOheUrG3iN1^|7%~Nm1_^OA#%v8cPW+&xnOO*?eOf zi37Xp9$G-q7mOrDZC2;%NhdB3jE5Jy>LwH9M8|8W@ft`k(v7;nn1-sp#uQLz(1f)A zeH*{!)n5J_sly)wKPG;7Jaj8#8p>kTjYb3N4g2NQpCBH>(tRV`bpmS{;(WF|-jTgd zzN=!qB8`n`fAvc&<<-wt<0MphY%f|pb~k=FQ&(P%P0NFT;sW6ItOJ%=<{mBF>xSfr z=dQc7c)+G*7d$r`%9?FdDX1Y%4a8nG-HP=WoMzRQ7%vT>J=@p^nD5CZ@SXJRY8>^Y zy`DOY*~KNF2n3lKNFu;4x`u7y*=tIeD8McT_Xnc|;B0inB}33=r=yM7@(*5TH|5qFnl z{+V<&b1+H)-*Evbz?eo$TkQDy)U}thjGPUHFXU^zx@Hi=r%k<*%O|Xt%0?J|#|(AV z2VI`2^`m$thJss39^`q}w~SxAs$yYP&yY~=-7tNoB~-F--~>p{dv89!1{$c z44q48YROIp75^cP({;xgq{v?jE)bcCzBmq{>3Uk{oF+4Wk6;ND_EAH8=FUE=6ju`WoI`$3KxhQzZx z8Lx4Dg3p_)8K9fkS;9!!sI7l&71j>=g5S(K#0=V9`;mvy-rn&aL_04UH{ma&ouGxZ z@@eKh#CW{&Eff?L9`mcN@Q08#AVSrG)rj`G$vD3TXC7thGf-}vC=mA940>0OmD6^D#cgomU#uKuLgt<;*wkG+plHj|;Esaq z-J;9)4M_#PaShU4hBu<=cNP{Q=(gPWT_AaSIwIBOnD#(-r3PA_4}BTuwKzbDw#m2? zH&yT|GQ^&`5h+Lg59OTLO!XBEHj6KV$vw+R)M5Xj#pq61PKk9#O$t~*N0#AjM?(*|`Sz*$U-uh@YvyHo(u~YILNHpXU!C9=h=J zX2;j3GA?Bq-S~OJ#SEY39}>sUW(dPJ%XHT#34W#vE*uCyf4dUZgLX5H5L?84wDC}Luoho*@k9=pOa8fphzZ$f2{D`f*=*@{l5tu zb}`Q5;Y|Ge<3hpDp29wYpI4X&_vr{NOoa1|^PO~#_y?T^)afAj;qMP~B7XLO3;%5V zTt!_Z()Ii44t~C~S(oook_yUs0@7V}B;ug#$8fO$Zqtn4L6WCuW0%JG*@qAwZIfH* z;HUo^q#X4R=?nbadnr?QbNfa$--&x23|H-2`ToPeJlSk^@R+;OVL&jpY$F8%XeI7>nXKdO$IJhM~m-1`lvsj4Frz4abKdU(__Lud~H@+r*M$oy$&oDa~ zEH_y?yK6xv3CV?@k0LbvtI@*-Kf7PTcJc=qbU*kR94`2I1!$W1c@Bc_2R~ncK1cj~ zfQe^$p2o2TgP+a+ors@X*8=lg`e$>L(2bwp(%*%jU()Wv&kt!g`1uLV20ybtBv!Sa3+4fohSIYBfw@6{A_C?T%seqZz8lX&galM;y>yXpw9Oq zCjAG)oQR*>PEN$nS=2=$T_3;G!Otls-785d=$Id`0)Dm?dg--GRt0L*xyElb{4j`q z0;x9CKmVYL8f|m!I0rxf{0cRX`qRz^e!i2>)ZO@b4h37-fA=ICKW{*)YKJIGHR@YP z1oGI?LMHX9HA6$o@TnHYl&*FQadYRzR%1$0n_&9y@pJV_2KJ2pxwS9>Kfj;Y2tQv( z43={kdccLBQ|*KderEi`jh|P;w<-Mmsb3@f^kKe|c}xtt@CM9W#ZJPsa+2};a8SLC zpDU1JGW>jQ6Y#Sb`hG+FEcvkkezy97By8~W{aoUq3qQAD%w>Fi>goP0qZ>b;>c{YD z?_LG@N?03y26JFGE}JZFBklL!8mURun<2dXA6G5F6<-txn3ZrLLH$a z%rp_+H_m%56a4(L6Hw=I!4H20%!&B<3S9VS>z{elMIv3VM$zo?dta08aU>OV%u`5r zSvumN>|e{GMUC1A0-@hslBZ_`Qf-KzZxh0!ZRXzO;OD!aq2}0I*#r1F1#%$~Kld=d zu>ZmW8$UaFP~mN>wizQ;K>TroV)rynjxe z^^NfM*(h`g%5s+vt%aqii06%QU7JOk;qEppSNwp6I2|E+)Z;3#;yrra2G>eDn_EF= z$c-gyf_}$=4d=lch@Hg9;XP-9B4k^M+^iHFdy)q36d0#pE90F z@pzVa9%w#b1VXv>*<)|`Pw@EXkBG-_qcMobudz{xx6(LWpFW<1cA15O$| z9(e&_SUG*2uJE0LNEPZ;Ts{HkcE))WoQcQP z=LjBW2>S>g2Tg<-I>K-N(&?OGoNuIa#NV$yQ0#EQBmdbjC*pA@xVZ874eBG`Z(V?6FckpMg%?ci}&GzRcE?=;}? zmh+jqTc5p=+!6LK8*Ah7BS=+cOg*nDQ^Zr8R-3YQuV<=Tgo-VI8l#T;dbL#Z{1Z z|1#*w9r@8-y=DAqblF{5U~+_yuSNOb%WnFvFS&n@InKSYw?O8e^9Y%|kVw5N{+rd$ zepmScnW+typw@zG8>z4fDtnn-zvm^WTaQIJ=X_O>9d4!xmlQm&GoDGoGhhnCri)Jo zAQNA_u}ketj+dbJQ5-o5t&ieB&Zz8*%~_l6&6!YI>x^Z#f31L!5lZkk=Nn6H|4Q*^ z&%)Cjjx4f0UlUJ%=vWPP9(4_lSc9Q%zfr`(NrT|wEq;+pTJ|!V`wpR%=TR(VH&ZV_ z|Akz52b<)*(VO;Sovkf6BK9|!%sSaYtAORjNXXdR(vGP)+y2K&*uj^!{WsbNJNB<= z&xIWr_%qGDVaCdn)@KY9p3CMO0aoS7o6F^k`!D2Mr~2cIsy%#z4Uu;o1Bh&nDiEk+ z0DZ>pgizJ%2(EAQXE}dX@aHW4oWdX6#xcvm* z>S9J+%bzv;Vd}A4%sOJiwT*K79WIAGA6IVw9Ec9XB6jmyWEHU5u7h*MLb*OFKRpdMKqPSxwbIV2tb*fia{$EluvI(UZD0gHE$OVzI2RA2ML!<H8)rcOSS&28W3 zL4HxAu4Y?dJ%t#W1nF@Y)7;rsWwS&nNVy@>?>$30l1RVpOCbHn&>9-*$?HCEpeKhg znvCnohxSAP5>Aksi;eV_3($?dgSZ`{sdl~4@HjS8B&E`4NPXPL2w8zL;{fS4%1-T| z4{AzK_vul6u@P?}9PXQM<>{~!!+)SqOZsJ}nW+h_*K@4V`MC%S1Uog$f5K4!d6H1YKi-tn&jeGnx2HkBc@KnJHe5Dm+LlgMjj3BlVUcqp=vB*n*Wddohf zko9wZBm+}C$(~=>3>uKd1Nom^12eq*IT6I8`w@6*UN#X9w&@8-9dj3Pk#? zgBPD4v7J8>=gE~Q*1AANKejOH)UQguR1&UYpYVOiSHN5)1RmFnSP9B~Lksi1vFT~M z=XHN?K;s1g&g}3Yz?nTB#GdNJE+2xlgBUGIpR>Igg%(C(nHZ%EU#I0xV3f!Leb@+_ zme1Dv&+PYQAb|2@RKn)M_B}LLEvP=;?LUzPaC7gc!3g%DOAgqeiLa||Uhbg_LT46) zT_40wQoHYIwmY8%WHL?xXCQ}Ql$*9I=5t3hOhL?lP2}q$E(*Ak!JzPy1f~td`CY43 z1`5`&K1sUY$NB`AC%XSAr#_H;%#8$K_wvu(nMo3lkHrIlS+wjRUen1$g7U16PYkm8 zF;3Ah0;}|!(V6H+5XAyGxb;0$;`e>0k^ct;A}`BzZnDMp54_aG`KaS}!RF_L{71O*FJ;Kc+axVl{#|wcbVdGa_^A*Cf{8|^&p+f}%1=E1R!llNc_i)& z7U&s?=peLbp71&=x*gJgI#X|K?qTx=hC!XZJ>--d$rar)bc*MT(ot)rj?6jTQy zvo!g=+kpK3(UoNt*FbcZCcjxkGXCMkGKc)$NF=|hq7FY+#bC(&m=YfOK)&g4P$OOW z3iU+ZZ9snAbiSJWW@+-9<&fVjrpv!TWBEJy~ z6`5+2U!joSh2l8e2PC=mB9dR8G+iG}e>gUP_7iv`V)>Zm;Y2os2gJ8QWT8N+w#}Fl z>i3aI06aP7s@Ydvm^B1LqVv1rjK|6NWNt-XCW?%D=K16sDHMUCm6U~$n^%FGmuG_v zC?4;J1N8H#=gHqme^_=3glmdyVc5S&eU8SYSSvzeacR;>YFvb5wA6S~!Z#r`G8oKA zjlhMD)X0j{cl@2TMrwnCSc|ji23Xigkb{nR2!>Z?$7RQJr)t@;j;-!i9ZJLlZj@;2 zC_5C}iH0f~co&v8u0Gt3j7BHp*V}d{Z?7lO7YA;yc9hW~Wp9)4O|;hzk#kzgrU(DC z_IeX>+*|xL0tN799qxl(q59&TTDE@lw4M0K#K}J(M)24H=pS$FVA132OxUACy7TQf zkasG>@rAo+K3+4}Rd8Cs+Q$1q&I*jmNeR?#4@O&krQcvJI4=;v?PRzD0r}ybgWnB_F(m z_EQ;~By(Lx|BYVX9WTFiX9@GIA7dAqd9c8WYCqm)J05JHR0i{_P~%Qw<3oG0@-o$# z)G6?Ozy|8z(2vf<$dc=~m-YAp&+zFh&H@;ngtw%IM&Xr+{wQu$u&x#>VR#y^60NsZ z@|^WS!JuH|kbLW>p!G%Mwv?Q#?OZv|qR2caFseVE8Vp*v;(ImX2D82>JUL+fjxdGa z1|vrVqUWPM<*}xfsrHZ^Cp&ZTwn{ouSBHzR8w3;@4}EpA&wiQOT9p$yNM4Pyd&kPd zNt1q=oRCRTXA{`0ukiw9??B|RU~@b{Opq)qxJ>#b585*97Vh!rmyU;BRuaw{lt;$om2~-N6zT9oA9r*IXo~b8}(-JfOXpE7}enMro3j= z_ky+viBh+jkX=OKWf-108X_--TuXGs^>8ad$U9|-7_RW4BhU=}QOnDB_;YnqS# zMK!Z{{bRKCR=kGDY7Rj)gH)3v%|jMq>RMv5wMsX#Yk-1gqR3-yRW@{@kfm7FGj-Y5 zI*As(z*;iZkTnYLj8X|N!xU+}rXefiYt}SiHLso){LcAhAGMTkz>QV9-<#ezGrZp<3J&T9e7b0<9?1Rw%$hT^(utu3hT=GYZTwFH6kdhCi#gjx6ms1&;i7CQ0@GQ6)7?VqCOlmT}d3Q0Oy ztG&eo(4e8njd)J%j?93yJrrpXid>8q-I;IIA&WopOpUkrQIt7keHyYVWZ?``mC_pJ zopfvPey0>pGS8H7@|>F=8Bd>nM8GfA9g8NukuToh5>?#KjK#OlB!w9!1vEQ+YD1k> zKu0`UNA%9^i1H!nImhA~u-1VP(bP6BNF$?UPL9*=ss87r`3M-Wz6oRvPcNth9Y|JR zL-GR8@hUEwb0V6v!u8q=2E4cvZo5y&rG0+qt-%?XXsVy?z4v339~P;_VYyZ<%3@Kz z^e794r>FB|d3n&AyAj#Nu0af0e+f^|#Ejeh2!)4saP!pd=(RIKk()BPOev4&?8GxS zYYB6QsA)RW^!&~{gEIguXtk?gkPHvbwbZP#Nf)us$e~A>tKtqmpq{=0ygaMx`6-bd zs}Kk|wz@y(vQV_|>JVtx2nJA8MgJ6(8`__Kb~I#709W7*`HKFc6$Z2Fyv17)fN%L( z+pDk8^e<2JsIwqnA$;&wFw|1K&topH4D|Ng}Uz&UhBsBF8bqS;v9uiGe z^Kkt=`b?FgI%uWppPlY%V!i0=Js1d(dD~#g0qaHkpz(5lm3a??!&LNx`#p@6h(YkV z899@i&3hP8JE0SqP}tv-o3!KaVT^?@h&}0h7~9jyatY^EyJL}&dCckHni7xN`(1(g z7@NptQB~|k4o}9O9A7a~Um!s)u^@tsjP$xy>E(h8s_O^sFi{fU*TsIo}^Ks)jkQ>`Z%2<@bZ=`hg4CC3I zp4o9v46G3IT9dhSJxHLG{b19JSQzSDgpv(n<~@va`?(f_v_9SR{)JV~a6M@L@!TPT z_b=qTSw-+A^OYCvMSJ_F)Cp%nmA?NpS!sC+tc9^duP{8Ccn@QDN2=0VA4pthalMC8 z4pG4UUlX{_BJW}J0Ac@?_b?7Zx!vz!w57c#Aja$mXhFN{J&fw7VL#gO|B80=9>&i! z@78NBzr6ywUjT^30?RKnm%xl+LtEk@U?`10kla}R2b+>6&%>9ig_)|CF{P_6#+0f$ z8B>ZnmL{w}V_c~hSuWVs7570&x;5%8ju??N-vMgsJ&d&&y6E>XFuIH46=zISQlG@D z56~qGsH6O%d||*Ww2PaNSNTrnH2_%nTORLBX*Io{V7jdGW3Njn2b2=+btXP)k*xXq z??V)hT8>kf1E3MJhz{<>{jNm!H>oUemS5;gZZD}(&&-sp3sNK5y%~u9YG6-LOw_+3 z8+jC9d@JMA#PxoeeT(>yVNOtq_w$}d7gU3gZr<}~7eM{&_dM!$5X`auk4y;W<~@%x zIEz&HNrU&*Mq>0?d=X=W+5;>|lHSzY@HsM&W`7=J7T$3$rw}WJoZkOu9h; z3Ihw8iwn846eMnMmTiR;4Vo`uObyFEwdFOSd4&wOWHI} zGjc4EoYVZ`4CO`uK2!aM=Lxt&7J|G$zvoeVBqO99b{r9ul~JD}48OaMbyWh(tl3%) z#Y_GRI5^oRhu(1rs**yWl5d-!x>N?J&>r36K}+qRB@(p3&agl{T#+4aj0u+%H7_#x zu@#$s&*LNsWv`+)c+Vq{nfRW^lyehMljYdodmhnJpX)u3tArlx{a-|PsB?e>_nQ5` zP5~ou2Us@=+;H*Th#15Y_3t?e&Fx?H(oGGwe>Hy3V}isu@OvHu5RTnnm*(nzdyPKc z`7z;sOhu{bl0SDMU6-L_RI+J6Fy>mVDq2bEZ%7uCJ}=Raz~4?QO0O8ypu=NHrv&moow=$OdM#RgES z=VM!dULu|m=V>e-L2KAQ;Cxiv-nH8WQHge6%5;Wz*7#P8;@`2=VEM-y%jaXKG_d?T zZCeXp5W#%dxNEl-gvDLEq*irh8`j!>ep8$t#*RPcQA2=Cg5?g(#hKzOsGl~L_eP41 zu^i{iUjml@!C4c`H=DPaS})d0`8e*LiuRiMywAb@?8CWh*G2;l!J=u`BLMp-;|LZF zcgq>%&cJ2p@ILQoV!3SHZGjN1#HsE|III~j`EjB+H@@w`0q8254{N|HY!Bg6Tj@mS zIT&4P2VE&a8(_I31B>i%3rx7ASU%n4w*;Y^#_}s9l*V%6Yc}y!@37@A-aAh)XznL9 zMblRIcA+`nza&k%=MuDDjQ1}e75!J5&&F>wJ+lb7(Yq}&V3sNBRtal&SmWoI2>R;Z zopkV2m2HBvdc1{<18KmomJxbOmyqL|5~Cq}%PwC&W5Zp(wTP-p5RN_GJJm(Djo|xK z;s%PFu9mpRoeu0)u{Z?nW)iX~(EgFIWfKEp2egh*YR7(G{LR3}C=f-q=QHBzKeyTj z?ZG|)?Q72kqv9^UJa~AEM*vJs2cce0AH|kJThj9-YW~qEMwVwWHu`&`d<{Sy@*;5i zU}rz@u6e*(sG2rzAMyz78IHZ0{zp6ZA8Bvp*jLiN1G7<(0c&YiFhlR}bR=>HMmK@m zn^iVBE9@`vqfUa`xBeTry+@+q{4vI6>@D&ih3=8Uha4=Vh)bPnW?Xz~7f4*=Ha0oB z-(ivs!t3D66e{Igr`8BVPy#F$7n~O`E}3dEO#8!aXFgi+S~g5X{C|%TbTKO{DD5Mt zMm%q2X_P)fW9)N%QB6IGV($DZl32KZ1p^tX-Muwb2jMK~1a!pO8wk$U?b>!Ke9`so zU?cWbfnsddS1%vTirRB1W$;p4&LGX>yb19S)X4AwKoc2)O8}{H^-)|%)}7NFsE#5< z1J$Jx!_0;hV$7okLbK45DA{p+eAquUUXRqObhK9`Mu>48`<@h(B4O|C82x(7Nvs^0 zF4Nw7`vjt?Ck{dGm_#X&LhDJC?%dQ`L7BT})xLug$`^mX<$mO0@5J5PMo*};VBsKPFqXsxiKamITgpGn40L?=EyB#zP42uf z%C+2vJ8>UB%+*W446}VR-Zl4d6og(ZV_fuNCBOEphFI8vV@#+b`Z~C!TM_;N@o(b& zmM+FKo3kpijY_t$L;fJ<;U?u$ri}cT@N4HU7KT#bV3}3v$5x1@%{{{(ODX37=UM(m8Gy#>tv)fPOjT}7KJ}I{rK^`|3j6ENM#~8x zf4>QUe1oWKxDS!aEz;lLJj*Re!Tknv!}(^T-;PGQj(&?-^Y#LGyvUIACOtK9j-)m0 zAIIW^tX1;5dtedk)l@mk*#R>J;W^45HE^>%U#wo!t5 z`zDq@m`5tn3f#u7CAEu62+T~P-tGjI*y`;SNHLjuo3jv@*&gL~skdF9Oi*tZKH;;$ z(x?8`vaxzQ2LTA@c?2q#dYjh*_GsG3L*nY~i3q_;Ty(Ij5@{FsueMsM^WTmNO z6~Cxt67@FK1T8T^OHI%u>g~_qEK=M!wp)=2mqfjN*Mv)|-j<4|(XXN!^%@V3@03tY zs<-oxHR`RL6_2JJ+sy?=vfsZc{r2a3so%aW?YBSuHVZjuD7sg|9zef6)C5meBTeun zY@hw;x9g6+WI5sicb;Mq{UT`ive5mh#37p4hj&pJ~u`=rtE@D`6G z_UZ8lYU9G~f2G86TfI#&oaOm=B=I?w_}uv^;PXKSpMjCb+ym@%>9?I}cj>o>(eBc3 zThQ*(Z#P9@H~Q^PnvH&&Bf8Ok^xKi-m#}}y88)2WyAg1D9170`f)=91ZdT_Y6b0NF z!d=vFGsUG&`HYKC9RpL-`t5FT08^-yFYcofj-Y<~y|~n?uZ>Hl`WUAFT)$oVJyEw+ zMlPVbwcu=qC~Tg!-859EX`o%z16562D4Z`*>r_9e4g~Bz8nCa0vm_MKF%KIdfL*9< zdGG}RbcC&ulKbJ_-KcGXl6x>FB#DY6h=QPKO~U(Ca&sXwZNOfH6q6~rC658HZ-O$@ zP|2Mzzk!lljUiK9$$jom_$E_wGg&#XL|n;ThG=TpKIDENB{z?v@PDM_w%wahzPOV6 z5c05<++$m6CHHt1t|=u~QN2TqZ#8rE62PIMlKUJP1ie@W+-X|L z4VzF!4CSDgz!A}Fl=wHHXV%m3TJ@+A+l{P>15V#{$Pww#lo#t$qq33?koB-<9 zbL$`jsOQ$mkc@in&&HIgHW-sneQr$Ys)DAl|Jbf*IMH)=tp_mA5WTHN-9Rn)0DA5$ zq@dRm6W8O+e862uuhD$KbDb0B10FdIxhKpAjFVV(DjgW@nh(f=vp}Vp52(6=;AqbW z90%W~<^!InYXp_wVls|U*^?mk*Pybk$AQYJNHG~yUN;X=nGKboAykI`-T*4gFuIFF z<+R-iP}C(C&qIfIxANZAXg=UxL{soqpbyq_9;!x?H57_eO3Fzy3_1o_K zK;?fqA8^kfu3kz4mD9l22ZqX_CR7oDED2Qh7XK!ovYqiv3YGiFGN7VTrVLF#IaIDg zDEEB8$`f2rdEohg;l=LxfG&_;RCZ33?`G8wUsxZM`7KT|9|{M|2eka!hRL>v2~2hd z`w=D&g+~+f0n;Jv4m2Nd5dkU7GwibXe85`||F!vmd&0oBz7Fm^NxN%4;BMO6JO1No zcg+V3qutC0+(NUN54f`gtdX&Ytl=L^b2`kx$tOjvapUA?z<82s1+gA7rMG(5m@?IC z#^h7a8B@A?f~K&)<`lG?;N+)Y0Vl8c6Ir3jbEuvk04Ikdg}*Q#a2e8#6w6Cs0-GV| znW-3r>S+P3H+gQz(D>PwY82joWvLQ%&C`(#!Hwes0%(7&YwrHi0O(aZ<`aVnnbr(# zTMu6VXgAoXYu194IiXsKue$m-H-L)Me9ZAMkL`7uH5uMLIpB+{3h^QKI*^R5YxYHo z$tDLf9sq#WV??0=bfAIA?&`4nkPoKf#!(IHjwP_^7?v8}-paonz6rYKL=B)lSvhvG zJ)wFrqN$5_kV^2pnG{-2sAf}zE1`p#P`#uD%yBoZ)=7l;l?JH6Tsfr4`Ag11xF=L4 zDLtVYP%myvC?5cnV^(kRlgPu?HDB1R0rZvaC>&DraY9v^6$P>wSBxrzB z*wEh2TO9>(u7-x8ffLI^vP6}tzK9?jS;LU=YqZw|cl(f!S-@(w6}}0;X>NgOX@E0+ z3rrfKsk9p8zTfSv7NWlV5Ky$8JAa?(m-?(yotgMv9c4f+U}Re+j);9qr#hg$!;s-w-HEf z5iQuPY8$jIk{Cd+&x~hM5Pa2mLdG@T&ijyfHrQEVXI^Tje=9;|dzbzyDA`S;0w+;?&C*WjxT7`&%PY?(H2Fi{-)DQ=&7!QlO&N|as zD7Sk*Z;*D^c>E07UE}d~w7bURt!Ovv*)C;NTq}0tcH@{-dd5)H)ATyF9)jPyO0mk7wiRufrWeR z#K6o17^+@V3Eie&OGSU0{8g-A__s!N{Y%crc`w{OrZ5t*&V^1StlDW zpK5PRnd(TG5U;1QWNM3}+j=y3F7-3GaLiUC_8N7)gz#6bvcY`Uo<9jl2Z5te)vlZ2 z;VlkgC=NhpvC*kc$zwwydmG_-8CoYc+QIV^37lD;o)-|$+Y`_4n+-favLT+c_haSp zco@Tv9uExWe5lb=C(*viv0p>`SC0K6+E+UEp0vLXJJQOdd670>S_G!sD@^CVfaY45 zf#;L95DRdbB7cq-`u$El4RJ(1SU|CaW*wvMH>RO#jxh~X(~K#g3TO)ZR~}0cY>k{3 zt^}la6Q!+29Ye*}1?lD0^JsnCxZxQ|AlrB9bR<&!mUCK-=gE`Kubzy=ldebQ9j!6h ztVi`?aT4bU4wI;L>NV&J1ZT4z^;Nk6=ZiEPPtGMATV_4#4fuj0czt4{^{8`xbZfdK z12v(I)^tB3-~gPf;7AUt0nQsR3en&UXcA@Cr#2TM zpD52o0kM2Q=BqH&GrpOs?N9J^V6RJjlC{x#)TxN3PThpu0m~Xcn%H#pzg&;9en==^ ze3I3@9yMEOwKw_`3WrK!L)C-2SzWOFU#>@W{>9Zx0Mv%-QEf%lKG1s9c9J^!x`=&@ zRLmZI-HO1;FU7x!N!F#tGn>8GaMRTzCgoD53@Tc}uMOy8Ar6m6s9f*Tf{fMz#Mwlx zXxdwC5`Z|H^8;L?aL~-b;hkee|3zzv{wrVTzib_V?`zUZSdV%hhFpN@OxaxEpI>H! z=qoz~L{}UIUV%pZ6g--kXFV3clXRZdwI1~ofhxrt1?1b+U7^{A6k54ZlC zMY~J?J%M(Y{(BhhuJx!Lx4>@JqdfF8>rqEe26wz8+~Gfn<|Qx#KeI%aa_hs_gPExh zkDv?yc=lF9j44xHWK2GlV@&DlY?{LU*+-(~1UyH-2k_h`>DH+A9C*3Fb5%9YtUKU| z>tXBEPSEIn^x<90(Miy3$B`=H=L)FaP81hj?*s25SVZw9NM*u-+Onv@m z-TR6<8zf>zJRcseq4ykGasT-ds7#LaS)TQ&D8&!32%w`r&?<<#3$;=_jLuYwU(wN8 zo=2p$&n5Wb3*0TDUqhw%{cjs7#q|ekrTB6_T=UnI;=ccOaJLjGCR2*%Oa<8Ve$q;@mxXIeDZcQ(Q;J`xa`jabrFgz#o(EEj3r#42!z4=a5aTaBg&q?u zwJ}r!D=_qQ3AJCPxV1^B(tvRlzji`mAsGJx)}>P1HxIKB_}_(pqVu&Gy#<|Tl9zDz zY>Eq=&Aw5sa3;g&AvX}8yHHw+e%#5JQq{3AQO~WZ*M8~BBQChV-njVw4}0$(pY{Cz zkFUcr6&o6>9Imvotk_Vt>SEPa*H}phm5Qh+IYdiRv}`Mv%SCh`p^!t4Atcl~tKM`_ zkwi#6FGD%51NOV$AJ6COx}Mjy>)Lw1KfeC@?MB!0_;@~F&%^z3c%Ia+Xy;tazYQiN zO?@pP`_#K8BtvaP2$H-Y0q*5X9Ay7=zaaa*<1iZ`9)F04#FAdI#N%x6=&JUPGBi|R zU{KCgbqJ){@r^nV-{oAwtrLOo&bfr(eglz@7YFk}vg|s-;IomB2heZH$DQf7%d}1;igOk{-^JQq{5`K8Adp2qH%%AJ+qM%Ew$s(`ORQ zeytYAhRMgttWLOmT)tRaf~P~Cu;k-K2o{{~u5o%`Hj&wpk7ptlLxKk%s>sJpKCL1j z_p7btqGQe0=OqtCyn4$A>tG z(Tkkn?B=<%t z!CtdpYh!I2dyi(n*0!O<-(n^qz?-K_N7;$|?aQ{QwpnRN(;eRypaXoy8Egv_g z-;$4O({IVg<=4V*$;VsiH}dg!bQ}5jms>D99+%nS-b?p1xPhOIMXa*r<8GMDl#eea z4-omdt#PHPbmMZVX2zAGPN56;KOBR06Y%W12;jL{=;Hnd>Sq>sMw5@XfhR?ik7)pe zy?FbZ2Hnhh+23_EOgi`9)I-7HFu4jjD0trpd4MqK+<)T`a_+ymfWYYO0bs-j+>BVj zWYh(-UpLz@$ziK9{`w2eg!^v@P?%tPE>*W+cJo&ul-vS>1|_HQE48rz_ut$Gl$;3x zMWbYB!R)EgC`RU&0EoYBGCDB`uAgi{Y#2(K1+&`xHgsZe!E6t7Cbj1iln#_EV$t$c zftb*(XA}O3`)@Xf)d|SB7{w))gx!DhnMTImtWb;vvyGzK#CkU&=7QOQZC1ZjT`>C^ zbC}(xAt=^@*?W>I#)8?CCNk=R*<=$Lb-`?yDO|cfroejHBXmu#f8g8`RrgFKbM{wO&@6ehUxF2g7gS;a2*Ihmb|T zquZ>P{c;2GZ!5>WdoSJ7;3ob-03tqx&SiDOG!^{AFQ*RfzcDV{e`8#@|Him*{|#Nh zKU@TF@b5L^pU?&VQM9ZH|G+IY{`KjNi*FKek0NeQEM0&`N?aM7vc0;+l5OUh)7QR6P=AZy!0yS(CK}K7M=mEe=9B{mj@nC^!P5tcAd7zAz@~v zn!!79idQA%;?79kXz%nVZBj=-Dlc;ns0}8y!cRfxe$q)OT{mexXuN_Hpds@sL<6s| zU4n=ur%R36F8m#1)$i_wAa&g~Q8~abquY!BcqN9tI2pzARvcq5j<1FKgaiFf$y%X` zAwO91@O%V|JZ#P{TzU?22Ib*W!~%z+o?oc{9~Z|of}Y&Ef1$dwG7I`f&U;j4C&3L+$#3s!_c18;g3-IzbOw7 z*br8~sPb^XEgJO)vvU8iJbY-Q)k{(2;Q;4ljq>nHld6cLIf^{|jKs%~ho_jxoM`g! zNJDuZDFgb2|5TBOyC9V<4-Y+vA>crNXbGkod-3Z2g8!Qg{>v}$AHRbCh35Riod^KN zHB>)~y~2INiw;L9`bs#$w7*&lN4OOcG0rdS-Qvve;Qk3RwtyuMze)a{9lz@Apgi0R z!~baH;XnET!!7(j7T;y#|1XTU@P8-$mOQ+Qej^WWqua>C-wea-xc_6$4)=Dti{J)7 zI93ERn;%?=$xME5E_s^B!!3*}O*J(xmpZ|?Qq(bY6}$W4B7V&e+ARP-ST1z;s|8#m zsevD?28)d*4|8n*Tzkz6#7o>~ARBQ7=X%#>O#B{PCQiW2rMK9<^$4mE4wx@W-U`(V zvIPP2Z;=n(V-PHamgt;KS_xqONBjC97J%u6uZjU-$C@gDdGaqBFmEPQMFGsv3EcxS z38?>pr8$844k$(g%(>SCFzRnp(V;u`r*rEM6W4Cihh+ zL56x{J*(LVm-rwygFQWS4YMRK{D?5cvutV%((rc<(arfJ;DR}?8~hHR$gwqP+rv#N zsS>Kj*%H)=#Y3I=Vo4PPW6m^@Q86ao(4R-TF)`*VOk2U2UL02bpUwmc*emA+M_07*&B3xQxAWN^f9Lkx7QV zG;7oXli}+flA)K$@URJ9&tRYXnfZX6o5kGZegtmJ?ZSF!(#oFL-55U^A^Z!xgSw&c zWC%T|+BvA2^Im#GL-%_O686k(pu40#Kf&Mj?|LxKAnaokcZHN0e=ev-zL)N!qT@gA z{huKj{-SgHd*RFd?q?UBiSuJ38`vM<5GCFSL7CHVK2mX_ zK5k|~hI-hz@Lr#Bxzydpm7)sa`XAosHF$dkst|6kJylRMe(bLrZpAK9>>mC{5N^#K zG94vnh1vslPPFZ)m(}7CENE-YwJ$dpw3Xdu#qPaN3))6C*N$3V1#MrzrEF}IIO3cG zO_=n8Nzu16e1{p~plv=VMnl`oYk{^6QSV5!O&LOPw9K{lLn8~K?IkM^8%;cIWegF) zeIr-53!QoF56Nt2^e=nhsW+VR>eS6jUlMLfMkMBk&jH)TYT5g)nFE{c5f9XaNrls1U4h0aB5U@ZPyQ@%ct*$>=h@iLsw_V zr@F`&?%;l~$=84{+#IG6Y14|hAdcf$>=9x2k1EuTJu*-S8eP?#t8Gn5)vnwnr-E_JJMrKs!a zDt5o~b891?&Uz9M+iWdD(e%esdaXe|Z2=0^$fqqqFB~t;`c~dgVfuVq)*xIwZ6H~( z{|l_e(&x865e}FWP8Yy*_J1K30zg#2Z2x{0z#O+v1Lnr%)>Nz>Fc)EXIDnY~iqQZw zZZH6IC#3vHz}$Bw%CP}+-~h}PM?7u(K^P#V$6nt$8`;#^OHum2sn2`g3#(rcFvIqL zt9?H4x<-0@z>F(#Y0*8SB`F^Dq?ID!2Cqw zV*uvcCNe5u&Nh_ikuu6($X};?@v!_cNM-BurvzLfz&t8_{&x@M?G0!R;^j*D#r`k0 z4)JrC(dS>3<|1JBl>NBw*^fDZ`PxPS%w<1f)esivB`{(CSCgPV zfBB%J)8|{_J8Znnrr*NLGwHYRvH|@TUjEh%euJ0sj5Bz7VqeUT_hojt>(RXsZs29M z$Tv1#UXRI4yu6y2FZz66 zhS#Yu-Y&*uiks4<5e&k<2?=T|G0C6Y&XAceWSWA^C(0Ork4OF%I{$?jA}}38;E5Z! z62kd2dm)_T+c13F9{LL7((ir|LF%<-V4K0ER~Zix_S+OrX`j0tiu3p)4+wLYn!Xpe zrIwbvp)NE|oI-E0`@-@n=zkmtQIvfP;sw#ayB3$XKVs1TN}cnr6hZ%~+V>7(f&Oja zt8zlPWGr#n`@Tm12j4;Efc~y% zCxj0h^q1x~m68SyiOXEciaeB&zQpP!;CAE*;ie*@M=ZWN=)0Q)iN3#cuA;A{ML;F; zgzz?ruXbnI8zxEAwZ55#zKjU)fHD^B)IvP0#Vtr>+gqOh)@AVk$KJv@6*68}`+qwN z{-Zqv|K%6>&-MZS50&k{g#885V%R6G<{DRunkg>#12Y^}Fn^t}f<^l@E0~Fh!eYqI zEF2RsRDPg7Sb7Kqg7)2c_`(1mPt$U+`h=W6JAO|i@`LLsKX-;s1&BTljyZ6a1FFWe@$v-ts%$w6_4lYF~!=^0Leq_aD$X)I7Ms4_dv4 zngXvw>wWz&y~z(QBTvJW^Qb)I%2FMSD??=(SDHGDu44DNy$(OPVmkQ2*Ftx{T1VBZ z27d4zMr}0tIgOLV=id9U#?v9v8$mm-;3;5s1XID|BIfEn!`Kfj_Jr1TNFaXKHyUYA zqqo@o(RV?lHFk;lD1ks*0I`HXJ4^%ZO)Qw(eecj28=WLT`=s{uKrE(yH~0v&>`Gq6 zusaT@`pH5YXeB5K$0u3Fh`03=mf4QU!8J=(KXiqmgm8v*2g`PV_H|G+KwE|qf`~c$ zasX{1lpqbXLrg@DD!L5ifPN8E1BP_yxEVkgb$vYZuU923w6I(=P=*usy!xjxprKHgf+)6Wt;8u)V5f?JNzsTyV zkeD3opqD9U07!T9W6;(I`0D_jc-W0oOsaW|1(lxq44iI7#9wFPix>|o)A;L95f7>4 zNU9hjd2>Ue%#he*lMoL{{DnCwh|8G-`KbGst`Opiy>{{{&bbiYh48l2O}rfl{zts+ zEx)+`3%~HL;sODNOM+@o1_@V^+HE%K;{2Nl!}&MkN>ja3}OsY?VN8CZ;N; zQQH#{kyvu0wqdhQ;V@hb-fG{|un^xHcr1j!y$N)9{~?k1+mraayeIItYb5@%Cj(f| z4%shebp&Qwc)Ngp3vVB$-@@Ao^jrIRhta=PWA0eGKh*Af@-cy0zsU*YzMXCt+`!)j zZy_iQe?JB9ApUL??Gan<)oSDNsP~L3N4;)bS?YPZirp2v(Q>liY`Y)$dyNQY`&B;m z!5Z*)I4DHJUzrj<_jRBr>uZ9AG%Em8y}LA~n)|}Xv-EJ=#buJMLREmz6I3tMpqheU zA><*UV)wG+1XOR;zC-s5s5XVK%F^21FWI2Vp|0NBu0i!AVp-%w1cXF6yLJ#m!vWPn zpcu_|ky`*zJp=WQv|XfMf^s0e4$*?0zwKP8Tn2K})Zmv9YawdTcA@P()?JD>Bb&PU z6_j3+?V^)Gt|EM{BfSbHgv05*jMi`(`@-;#UJR>W(01{V1*aQc*KoS|WmGPf?P3q{ z1GvB2s?-7PuFlwd(`!~Q0SF_{t_>E6xhC7ig(g)I3k-p>GzwAf6p4=kl!rMjfKNH> z#mK$6yCkwEWA8giB`DgNt>8~SV}~n*qQ(vy``ns4%eMD60D~i*){)Ihp1{$Hh~ z2&l6Uv(4P!cpacTxKw~L0rQVQ89+pgeF#^9BkKADwoo$lXnp( zXI~1O921F??A*ZVww!wNg}}Csz-P10H<^Cxew!QUKQ$EJn||wln~wCG`@y=?ZSDuV zG8Z$W?yH;`?jCd>#4G_$P8RvcmQ!EDL?%u?Ppn6mW~nEPD@{!|E|>BeSBjcMSFwBJ zP6sDny%#u{{W?O?;>{?<)_{|4PzbxvrZ3*!_7tz}DZA9vIUIQYyY5hLt)?US^iQ=F zqXo)|D?A;b+2=E3emKG74L}~dZJSsy@``A!dg4P4=+d2qr=!zK;D!&675kblO@dS9 zECNwHHD2!Vm6kEi_rYTPz~bR=v>Fba&mf-YP>;V(m!-FAbrCPuchFjn`jc%h*{sL60xm zYA&AYeC5rb2EWpGDc%G691p-1 z`Wcg>+Hy8go{TIfzj#$vu)UuI_h4Doy?CGOym-%-lLHe$lk>$9u&k%4tFb5TEydjT zIrb#yoD8`e0{a7m;M8}|nRSI9w}q`M?82yv;LUG>B$bhYOEhmDsCn~5mPCc;M$L_z zb1QkGcc%6YMl6J~4)9g6EPeBg&6_#s)ETg^vW#&HH0l#WDBg+;jw-u?GOkvI0NsNy z86DnS28z)vOE2VtHy6L_@aB+Z>A}t@$8TAd>U45Byg5rPpO4ru-fS#OB8Ct?993sa zjw?=Wc^0MDWLX++c=I%V+5ge9l!^QHt@;HmOK(}c`P>&ZZ*I%V#j-3Vm`X`=AH8L1 z^Yd0OfvZMZmX^Q9GHbFd%`vH@ML;FevNS>BtFv3(Z(6 zL^&Yii=VMc18XApPK6-8m1X*QE3083-%F=Q_A5i1I(^JUgBUt6xy(vDa%qov(3q z*IZOCmd>Lvh5iSfXZ+JvFGbOLMq-k)7umJsj+^-FAewlHXkARIBF0A1d74Xn44tQ* ziHxfA1UP?C{yb7f`3w2$lrJ8ZzY?hgQO$Y82mj*=A!^7TUd=w2ymZ=+nu5y_PfwEH zeX0R|;Vprk4YR$jnji)@!fCVH2&eAvCpy>}_l96+5~d)r^JhfF(0i@}dyJ;{So^Qf zCqQM#=VCLrxv%4?i-4O)abL&nX9Mdl2_@ruoAuhhber|s zYoP($pN|a;b-mD@9GEtJwYN z#}013Jps7cX+A>H^sU5Bw7S}NlJY>I8v9UJ(2IJ%(eMpna%f-HAlycjE?FzoC*ar? zUjBAxI9|@-#_iyFm2HTPg_l>(u7a13z_LiZ-2bFC6EV^caHLa;4i0w-;c(xI;o;zA z7AQu;OILf~`-QN)OtIs+?E31liOjb5Q!fiI)p- zH@+u?=TY(U`MDY|UwI6b`-kx|pLp$XwJ3O*EwXP-czKdZRm47yf|tK?^keP}(Fz0b zPTq|hEz6_ZO=MKOd{-iC!prGMW#i?zwf`+%CbuMBmZLR@m*2`S?muShz+dMkBY&<( z0KTK4>LeB;_mXiAUT%6>@N)NhjhD+25d$yVfhX61mvsnCxc>q>q77c&ntgP5*|h~Q z&ce$9^jmn@nSKi|)9JVHvJw3TFI&)U@bbL#Fgw1G+2L+U_a?Z3mjgt+vGH;$CNu3s zlZg3(mt&19O^q@xykBNqDXJe`#qQ_VIe0nccHrd+lnv1GhbV>CU?)lj1&x<|JN4=0 z{Vnqk8j5-s_+JsD%+SwysL`|b7z|F>Wx6Gp-z4*^trcs#xr{%}{AQTnEc2UVem(qE z8OK-RGhbN@H;hm{VG~(fS_TiqmN4T_$RxD3^fSc8#T8wQq`So_Nm)t$saGgCz@U}+ zhx!HsI@kNGM#$u{RW9)0_|l8Cfh%_`0J*RQ3|wPY8`DopuFo%t#m+S!>0tr-;80~{ zW|?Pd=|WKVOnu@7{=n{}%^@qX!5`+U4;ctk4UTA@p)FrsIrzL^l?P&4z8VP-i9M`Z zlUIKBUt^Qli(}&1SU8_SeRBEUI_ewDf%5M<_4D|siNR(5*g10S<0zA-rk{?u1k z4M0snt-b2I(L4^D6*m@VUAyEgJBXOhzPc{*O33>-fq}2qM^x74W6GTjy;7*?+|MI- zfj27@lIy!jJxr4R;})#YBj&_0!omxw`ugJCEA^;Jd~m1)phB9|Am;M*&MELE$T*sS z?3tBaeRa=-d37*6s{JoWp}*$A^O(7KRhna6>vT1)YFu589$PJDMuNa$!UJ1Q4S~TK zo5i>#tMJ4E-&sr9!|HRlk1x*=eO(Nzg%{v^3cSM~ReNUF zjw>lER36{h#hwmh%Mwf0*NKbsb-}1>8XRE(BsW} z)U*6ZZSUX`bw@IuI9;Ca>za_CUeB}qVD0SXg`LqoyUTP}pLMGP4p%I19hd8i%PTFL zbh1#w^CrvLp(LjkLh#7<^#GOQJ)$wgr8&*RXDJ_~gdE?x;O#gGIyH!LPnyRwW9Ph_!h$*omm^y`@_cAK>Z|8eti6Vs^z{ zB_1F04&CBAbsAjv$~Wx-%Ohy|-7hU_9hdLx=F0c=OUd_kOwFw91haP%>E*+bKnFu$ z+OMqaG-V=C3s<)eK_(>5_uYjZmDs43xg{TSJi{{-^9CIZ!M36z-6qVPTvB4mW<(cw zTViyA=r|12yn6xQ(hS>|RaTauGELE9#d$Moq1CeUrX`kgeSs(U{eu@8+{^bJ!vatx zAn5Vsr+A9X5{g&Ug0HXv9uz4WpA$E>JabEjzS9y*?nQyi=1svx1Kz=ps$al^%F9^c zWo*>~?@ja6RpdI}<({<&V9*~xtxi7PyY1`yXs5-fP2Ac}4H@V0c7MU!DM9^7>ql`} z!@x=C2A&IHPx|}L12V~%{O1@Bvu+6mz99z#jU`PH^XHZ9Ni69Bf*#*pnAb4SpC_KN zWgh?V&v0b{Ry4T4(CO;IffUxt-y0KspUm~NX$LCH&`AUSwf2Djv_&5=4q zIIzb*VKiimu1|9qU+v=TSVpSS7IC6?VMA{G$FFm6_j7r?bu!DaQ&-dJlE7cUFPf9WqX#RO>L&b3&42G4saud?@x6Okav%3d=)RBiF+6VV6<9%ZYEu)410N7+v@2B^; zs0T@hVh*NTit2_zn(s@@?{Hbd*rtKUFwlbQk=?!5Clq9Vomf(WP~zMrqlm$&9$)C@s{viiFt=4;r4=3FHipO_Cfp7FdkGJQ+ z0`E5r_I?7^Qpe-(f;llLHL3X9S|0CeIukt0f4taJYqe)H7F`b~B|eacTI6MJDR1Dc zm*#s{1*KcX|@LSL7#lFT?+vFY#Wm*^{j%zU)CCB*Z0_{wXDi3`{`O=a1Rq7J?!GCco9|uTz0MSpE7p$JCAi9ve!2lmelo&(n3nD1RT_DSsjt33|bzdo}J?@#!1<7#<)7cBR9 z&(k0Jci?n^r4rPLpLhs03XGJXT+}~Y`oegVu|{!PMi`Ei_ruQ2Eror+)bD*)3kdZ_ zatvXUe{$P*F^0}7{bLe0`KJ|lS6~p0MJlKcozK?{SgqTr9sDqy;60_XS3+^7vP z0>rNb@$QEBf)Nh!&lZDtecaiSobS8LrHNmxiMPli&0CP!tW0mk`iYs``_vtk0b<*{>{m9IohM4)ks1+SqMGT3KP1Kr?D=V4z zqwD!?&5-xccaXO>gp5YH-mmrKdsVWl_46oIfnLKV9$z*a?KsnDCU7n05IWA^9bE9n z)P%&+{^(48ohSR3!n*n1e)!B=AoKiK$jjE%_g|r9`ZEVSuS}PgNf8Rgt5Ph%TiX+& zudkepdPhAE*A|~)-EY%^r!d0pg-5Q_>nqPd^0DlNs}PKDODr)5h(~cFchFw=EMj3V zjCvmK?9wXs!s{1md*QPCEK5}N_QLs?eU7~_0TiRz3lFq_y>J7VbELiS)8;70wijM{ zCWnsPmY$}Lor2iK=o9{3?5W0H*aX>Bld0rH|Kfe<<4eNo7u8-k&Zq5#cTGX%{$YDz zW3SaqQS61sKEyI>vKM{}A&IGqII^SI3s*{f413{oCNhV;7`dm+YbehnWsD+$`6}xx zLy^k17gjF95O7wkLkzr{^_A~V0Gg`z&>FNCzA3-^)Jtp~_`hvq?1hg>b5Z}D=VFlC zJJc~4&V5u2hOfPixdQ;3hKLyF;o|SF={(#gNCA7{o^ONp!cG|eN3*_iGQPvM7q+6` zvKO96zhy5xk_5kHFWf`Fu^0YMx3L%2J{_~;WtkoBKTd;t9^5cqw7L&94O^G)hsjJ+ z!DVErFcoB}JmX4J9gNGRGL0)mokbVUKfHx@ll`|>Tnl^Q*FqQPAD~T=es$~8-(ieK zTVLUp0CdsbYtThLXa5gb3Ll)*b|`|LIZsvrG1)p#wht;{1bTh|LR<+M4ucWV)0`)p zLi!|R&Xcv_9_&P~IZt*yVu7Af&y)Qy$wtpj7~-lGPQkE@$)$Q;9x&s+nq5EF`9tWr z9uy6FE@Vyz2H$W2J^heaGn$@63#CWX~6xa-G0PnJDJqvyq}9MIGC51uF6S#0$Za4&M#&jugMtZCQJ zvnJIv_86!{?)oW}_-c3kTx*i_)SS>+kQpKiGI@r+j0j+88Ow1nR6Ja?I|Hc%L(Tm? zpS*^F5X8`$&XYackoY+P+>H1+Mt=9HQRHs$Ka)nVBy0{~2wX|(>ZUp@MdeAD`=YBH zDD5*{pmZ2!B%w495i!n_Edfgm;d^kO?mT>9z&cM>OyJ6npYbK}RL+zAd2woR>AWHl?@N?R%{Xwq66G#68Lz#MS|{ z%lh1Bvn*okD4lcj7lN(RwXXqUfvr5;T4hJ&v^%R{>qpOOY;8eQ!>l|CY^{H92wQIk z#c0@iMN?pFCM1wZY;`wAIX1Sweu^uEt@55kG;Hn4k0axBc2pK2n<|=!(rd!jp|z0} z2MYvA{*OBsCGpi_Ydw=BDz*kVuP~Mt5>sPh>q?{&Y`u!J!=L=%i!KXWg9avZ zWVVVP2#m-(hWOeP{Eql~lKf)-5BVSbU78#D^sqD#Q+9NM%p#1_7c$E;EQq;q{-N8YH4}|0F+~B@Q)s%pi9p8EfadsfA0Lt40ID0u< z#6#rsBqg@GU-mEu{tV{B_gz&F*mx>RHn@2!{nmcUE9tlPQ+A=>+E3Y@g2;%G`Ud7)PqQoUuUY!+vSHY_AEbq3=NFgn-U+SjG#_K#!f}c6p~@s ze9fTm@%d;(*nQQch8S$P1`w5?wdLw7fYpWV!3-XF4%Qal{@aGl-5<%i(+;Kzyk8@I zbEL;iYkM|+Gb?-1crzC3-uD$#k^Yd^(eLVIB2n0f+zqP|2Sa=(FnNB& z?RbtazRwr(0h1D?HEsvdKrIwG4c~Ht`IaPnOJCOQQM3?lf6h~rvhW=*63DIZDEt8F z+Av+uyD(T^gROl3v#^z)jmAYMb$<>x=6Bb{kJ^Z==#>;{iPhz`%MY>5_&VT^J&`{N z`8hETK0pxB<1xa%W%RXneQfz6OkXqd1;%}*uS87qvl? z;>C+-M)usvb(ztmeu5eZ|p^YwYXCKcq_9cCyXakmwQS#APqn1*V~!a zNKD|O9(@Em_#NNM0I!J`e_&DxFGkhoaS%Crh zIPx&eVSMzuXV7+zw&RS?YWVS6m1lq-`_R?o$HnryPfcLg!~dqyZ4%T-84T2SZsC$S zcu0!sD`9PVU|P{I+|7}u3PF>(S7TJ5Pg3bVR&+P_nM@mgh3PW19(14|y=?o8>3|mZaeFpp7-(Cg;dbJoI>vMk!H^9TXzjQf5_!n4$ zx&gxaj$^_$H$M})zqG*6J)46I^?aj*blaZ9BxfNj!;Uv`vm`G57Eq16zjOn+xBs|P zA<#SbmwxmYIvsBdT#frn@4ubY?fXmXQ%os#U-`5nWMuP8Ra?h7=DQSqysoG`N{e6i~W`4$nX!vCNZpCrm7|gzyxooGPknb z-1RTjU>2`jMZy6xFbBy2PC!JA{mN6u)VN={cOhCG_kZ93g4wUUyy4NUKg>D^jOT_o z!#@_#Z`sctrr)xkO`zZ6C&TC`KLI9=rQ57O+!K%4(fSt74)^VJyWj>^F90hDx0ihi z=0-5wh+i?IsMW@mrrt9ymwMf}Qq=Qw;r@@u9f;kY4~V@+q%qw8VeE0$tv?J0g$R3@ z-uRm0DV~%D=vowyy;&1F;x)yG=eXkXgIb;1`Qu?U6xFaaH8+cD*cuOTv1AS{S^)N@ zm4_>f57tU7c>_`k1L{jaUF=&Fp|r&fo7!NPOUKmOi4V?29(4oy7R&deIR3oLsdw%3 zQ18Mjcl^n-p?7gBU8C;YK*230wH}w<0W-elmeUF~=x?re*Mm4z`+W|$99*rxDY5i- zQqH-a&5DbNm*-PC#8$;ajz*a8owXa&qq1ibF?|x81^yPBHU?|PGq`FK1!jNz<)NB& zmzp(4%_cs|osC&}*n$|UTjyJ)ZU=W`#k?MAqJl^MI$SBA+iA@d3ZHR_4`#6;5amMM z18<6O5hqRd8sf1TBeCRdq$oa!Hk&EKD!v_RM)mH&)#w(L#g6v3ZKmr5<>^{<5gYE+ zZfv-7QN3M{py9Gmxie+sx%YdtUuGrF_Q$tFT4cWPQCFOr^c}TSr(%IL6t)y4OXa$t z-XQ({$EM^@P&c(yq?n2Vzk3Ep1;m@yk}SFRW4Z>dS%buq$*i_7z8`A=wK?&@(Fout z|Ai;#P?hdpZ2h6?+!Xn!I-iDLsLtqO^%(Z|_P;W45prOhG1G_0RD7_`*rDj7)~Jse zJqy@Jtyv>~d|!T*9z6@XN)_;S2dl7kmL5Tg4}Oe*;3!%*TY9R;SCy54w-6EB@5J(6 zKzaP_seg+P#$!J4^XDQU0E?_;zekm3e-x}z4_0aRXsJ>$iZE3=nN=#}u*pMpa(yXz zr8})*bGxq0@-KB89XfJYEC$$=w^mJT2Tk}vF-8@kXD}zT@~~@soe1FAN%#Jm(=8-+3K~9y|6%c$AznBB19_+t;+$%{#hjT4 zLwk7t6Kszs(H?BcdiW%c=aLr@V7hNTzDC^yNaUbI_nWr*KG$ih#xvPg33)KPgr?XC zj9Y9Dnz@U;I{|N1{GmqnMibqL?T*B6lvcSZPzyED`%zRmZc|b9bTR!xT~aK?5M$n$ zQ3Ye(eMAb$Kp`4iX1ycWl16MPsfD6+F%{Tg7;1O)%e$Q5y8Tz9K~58grnJvz zx^RD6CMphdi>eDL4GsMT0x@j~7L&WMq0d4KESw%3lsLq3X%?m?b`)Wgw!iKBB;uI~ zx?`ZO_7x<}L~niF6K1*Z)dTNWR$g`Wnl3rD0%yQN2Yhkb_qUbD%Sat`P>L-AR0*l=06lx#`@`2 z8T%e|%9zD6GEoLd*Cy%nH0gJd9Hci~4$`-2(oKS-^TSCWMm2)fpLBymx&ujXuPvmX zN0KGkn)Fqg^k|Yk1*FZqi?GLWtU$(mE~iZ#RK2>Qq2*&NqNCPN)2d#3dhz}{2BO(4 zk?UPucoqcEX~;#i%7RsyL;E*$9f%D;un=0PbH?FN15~{g+SeYj;CPeZqs46#D!@A- zDQBx?S7F?US<2(p`+(G+Uaji&8Af3^!u$kP4-m6fTdH>RQ)pev#^`fYy(d7?sCv^F zuXVO0Ra$wdQVoF!tW~`X6Op2B{Ob@piAn;rAe?w;yZZ<&Hlpge)RR}Uon8y^g1&Uy?*XA{-bJM`Fh@XjVk4|4Zb0&>%}?^T z9c6;wL~y=$wdycX>}iEEwf18!sM#jN=36C0XOrO`6TF1MKKJyFP?4^JXa@IGxY=%@ z_keCi2>;|n01A&EhMDVYaXPBzya)7Wg|6S{7$B_YwL-V;%KMQdQJQ$4T596DN?iOI zpc-jUo4_S2|8e&}6tbt?^}X2BW)=Y2Iu7O6+xE029Mi?_`VTtFUI0(ht3p(eYW5)5 z-#GtfAQflm{bmLvsC$gdrS34U6m_$4C8=R>{qOd)uBbv(d)jbcm_4oU13{3*MrZ-q zbjgbI{}9Otvc{hFTYCet#-26@hYLdXv~7sRfR1WUyK(@(oVI_0Y#Dk&Jpywk8)ZM? z3ZSzafi>9Ewqi;+Ae#k>(d=oi!vNVM5TqjQX~!JYAUlL;>B69$@JA42(^U4AsKrs) z(=I_abqNOeziLlg&_AqxQSE8Z!`92;^~#l~+&^qj%O7m@QWSey_HdS2lRfPuld6b) z9mSsZD<=%($|0KHIjmu{u!ij>GDovYClWjc9N}GwtnvImQrY&jIuF=DHrR#UVc*~wPfPRaAbf(|pAL;a4{G$>5 z#-7%KZeve7?-$IDFJyMOThhG=ZeaBQk%{bm5mPalIa(*-SKHIZ8W+z08yC+18yC+1 z(}nZ@UI${Qv;)MRa5X~F@`uPYYS0(dPMMlgaP5ax@pON*IhciuHa*UmGu~xumf`THEt~CeZ9x zc|vf%`sjwgDwiCi<1$TLE5xa~eS~eg`^l=5SnT9YZM5I){%oziAcKW^bwn5t#v3Rh zXvqnh*bfKL;9r@z>lx>3lfydu?@CY?_Qf{<%uD`eVxRjgMuhR#6A;2b=Ub3_#l0ck zIuF$O8F#Y)96yB}PZjv)ryW2R*_!Yh9G!}=!3W*Q%mH z2P=gYqos3aVfrDiwW;!=k*spO|AML+W5YFMsHOBFW#tw*cBO7a=Y>kY4(F@%T?Ku6w7x`N%;QSpX@CY`770NA%oH4k5Yztk~U%Tgnr?JxI3L-2<`cfIp(? zI-gu_vtf$)*gv7!@Q8jI;5YF@A$afRuNRHr$o~=`@;|1W!-d}f!K$iG0_=m}!eb$| zhO0VBYVrX~)k(q_`2D9K7fw-c_Ch7XxNv`c@qKM+GAwdCdly$Bn_9&&g}sYKtgByN zeDCr=ryPw_!=CKTi6v*UZFPXY@?MhK_mvf--eE3i#w`#z37`a0RJKras(R|&%fspf z&bt_C5=$n4w4*1q>90BO`K*wy5mwk|=o`bVyY4rFqi_$UG_cvOxSOS+HX;|@FOQb6 zGNvAU1x0P@YxPTqj;RqU+w#FIu_l#mj-;Z>2BvE^lNYgU_UGLu5{#6qjSgQOB9Yga z$P7kCDr>o>@M%ISma=v_QVG))Eb}Mto#F~9YZ@ub+`Nq##4uXK>#j*(yN|HdzY z<9yg;Fd+tIXef(Uw+$EWdJm=+Rji?iD16GOgJ|RsM-O}kKy~bQ!F`8plfW)$RmLv) z428_>_(coJU+2Lrq)x!V4$Kk*k+tt|H}joOo2>pGzkBa4@WkAZzIBLxi{E}jzr}Ai z&~NeEMf8*3LYG@j_d!sHdkfSMH4%IQ?lp9eh8wVY=n4dZ|KSGT)#W&vSfS3sG$nsM zgB%jFNSaDEt`yb4xRO*Y<4RB!d94raE@fHP+h<%EPZ4cg2BRq=L;Kf|95bGKM%2( zr%}%rt}n2GungU&j=4hv;nl>Tqti!nA!s{D_yQRs0rG zN7YA8>8(-mG*<2()<@p$Y4uVRePjWqcg^}pu}M{g0T4|e87lEH^pUP6GAEio(#lYt zN6KKQ3;FA?Qt=Ra>mZe_k9<4Xg2s?UQO){(=?>!KK=3HyV{iGz`yb?4@UOg;tpt6f zJp%v&*uVX|KxV6S2Qn`nB9M6*CLtj+0}(OK7d{K_CioV_OOBp^b${a+0#kN;3HE&( zedOyOj!qwW`!isig^%m#xA5@|`Yn8%LqGA+*t1ILH~Pp-x{W^aG;|YHa2aQZdlua} za04&biQr=6Wrdh1D%E~sKAI{^eP>*0YNv6z)Mn#KQETZccAs*WgO`7_0$xt;g;2Eo zNRjndS9`v&6cnn#%PF82^*r{oh%YF0k=38L_eO z^097J@bXib{>W#}B~l$7UN(XX;^5^SpcoA=hbZ7>2Z#)jc-d`l1YW)eJc-t(eiH$ygXSl$9Uu85a$g>(L7R)iI<-sm5rAhCjPg0*>|hh|G~Y){x83< z|C5_x)_%L6;0U~|&j5{=;&LBq;oxQBK*7s1FbRp5aV=xwhZD*fhjw_4^A!^ zynKD%(c$HkPk?b2Ue2c9!pnQ;xA1Zl{T5#Kq2J);aJmg%-nJXF!c)1o>Px*2gF<JhrIZ)lu@mupgimzQ@(C|W+7a%c_q zo4%kB4KL09{wqMw7kL~TDx7|ULEqyVKeA9`XJf4_4`6M=@3J@-WQc2@f;SU8yJ@BS zU~_|=19i^1+!CGWoveL35DV-)2fiv>`mgG2W9KFea5d*9jh(-C)3fq`8THPVepgUb z2yTV{3`51i&W@mHuv0_{XH#hEx4_OyNbDLrdm41iPz}D;*a^Lu8}t2bCw&#f&Mf8b zf?9-Or#X#%0Y8pi>uB9QkWKZ-Md`p!Jyo@=nG-r4s1@(ajjTxt!MQ73GK9;Tk1`q> zFRF#x93A!BoG#EBxJSLxDXf0L&d-o7vE(UB1Aob*vGesVs2r%dqMgS6&8Xng+(&<6 zusg9E*d*CP3Ush*+#=sbEE7Aj-fn&&WxZ2ODrpf=i9C&6!I^-@9!>ZwVlIb-ct~Qa zNfK34e@7x~vIIPYRDz%dYzu$#Q{!B=GG2mm5w4%u3~9@j{d=R>ztJLM|CV3aN7+J{ z#l5d*OHs^RCvC>_2@igceG`0kp&geneD2p=4wA0!D@eL+j7HM85m8uT$_`i7)4{H> z4wuZQ&XBV^~<@eQ#vJkfs>_4JY707r*L>gnvV!11=8e$mIkKI?s?%jrKg zBv-bl-#RbYoPO)PU_<(OUJ!VB8r{3K`|O>VDO+WxxKF41L%4yXmy6hAH!RAyu34sIFrV zZ~i&KXTNI85sTjsdjA!)hc`2EjS;7Q>nQf{HaS)8;oeScHOC%aF5C(BAy5KE#~%I# zlq0p##PwsGuT2JPO?&uR7ol_jykiePg%M%)@LC9w>YJ}Y?l*1?*~6!SI;(%PDd3M@ zETHXcqmkq!el_BHF)o^|oCxOF$_avDw(>7JuwmA!K6%U?f7fYM?cqCU@9`gZcudG1 zzHZ zylN0SFI0LJd${4(&z;Kg<1lRdygveY+&{>>jh*O~8^iRTCvFMyZnJD%2#RFgr$V_S z>mH<8x0?mgOmw4W)_b@mJJCB!`%XtJm`R6dtoxbvRap0KSQuGGR*uCKfY{Zr?$abno9kbtoz}MtX_)3y6@@AGHYVpgG{Peth=Mc zSIfE^n*ivrBvpZ?6h3~uJe}g+hv)5ym+|Va?!w29!}O#^^b;ZyOK?SW z^wa)V1G&w2RXs;*gCNfUI>2Cgdqb)yf#Mp4q^n4IBXex74D?$mX>2{#$ zAJkmsP#rAcvX?SR)!wSnv?qZk35w9|TY_ksqAq9`hF0mhsb=}HjzQDl@?##dsk{qO zdbP`s%>}h&J@S8Deq4A#Se<~Ni_tWRB@-a5wXvXX`cBEeCexhV+>6^jr3#Yw5S_MVHcV*^4fqpY|f)T^`+L{jnEx9QCIR ze0Nv655Nr^94~T>t=Bv+W{*lWmspPeO;a}Gm2ti{Lry@Qsn7Jw#5Yi%SwoUOcQ;0a=`)!K;h&?OA@?`KWLxj*|L8CHmGU8K zlPm#nUPUjdjhunnGHfZ&M8wxs-$2n1oPqd|dI7sY^!+wnQ8Sz0-Hdznc@d-G zcUKJ!@;hhS>jlU`X7mNLCo(*<-{!AGL&z|^`Pgs_hG+KMe2Lgt3~%T;RT$p90h-|* z#NLGZmEm5<>6xHS2Fy<0scvbe> z^g%Y&2jjPThW8Kbw^`OEtWH6OXYaT9-~!F?R-TIr#b9{<<9?eV=UM$ymEm13NKq5R zOP5qJ7~b(FGAhISIh$XEljhMF-d2gMiQ&D9RKoDgewzn|xk3z2&%4UM{h#32AMnF`H&hM=KHs@1-!TW!H z@;ljY^VG-ScSo_`=JqAvQ5L`R(r@v*+vvCW-9Y*+ewRzX;dg!MHvH~d=uN62p%vgo zcO2Y6NG~uvT<(7d)0B3+*F=pazkAlWQq&ydN>UFQSAv>K7vBH7%Hel!Hvqru1U|r) zZbf~u20LCJC`4NiG5c-0f?oLg@u?!l#t$E;fl%~-Vs~HGAWZOYEjcUHRM zC(3mi+b}vDAj}3u1BCM=hY0v7s@Zw~;h!+=X&}roQ0Gz!A8H^RqD>6`wiBV(I|YEyEFZTrl7E`B1ac{|sY}yQdQHp6U5&}2i1jn84WgxlFM-@E)t4oZ6nhCo zvgsv|EcIeqSp5KsA0k^~$t+6?c;Q?Pim#rH%87b|U5L9$-P(m1FlvAf*Gh>rd1x1+ zVwQ+qh?fwQA?Hgr*ij;{(`Zjc4Dn^mi(cHsUq=rR5A}dXCRGt*K_&7!jo&!<0e(XW zexsS+dj9WI6Pd%v$m=wgNMudR$1{*hkg=Oq1@6DvWg{c)C$aYZpZ2zGKPg9Z$ohx; zV*LZZn6!PwY=Y(E4bog(2f6&|Kk-TKCC503xv8Td=I$#sVlGES;Z##_xQfsY+*a!+ zLH&TkC-8nqKd3`s!v25k(oXc>LH*#?b->G;BlQFJaG`cFf zkLmOiAI*N7M)W)T|LJ!2|3hC=U&!=ux1@U$+`!8LBDmQ4!Bos<;^ib!TDjk5tZ`xg zzj0yzzj0yzKV8`WKfuAuDfNJtCr|=F(;pIvxq3TEGAIP`vU~8MuYB)TJOK6)u0s5k zrvlXRtU=j)~-)WD>b9C%1yxcK~u6UE!^p!dZ0~W`o=TpSTQX~Z zWbGzd2kVNisFIZvM84sXDp7A?lu1;dh^WG=sB(m~U!0OCLRx&tX;0OaPfskZg|QVF zAp-8Gc)ruBA_oX+rRj=xS|ScE@Y{OIMt6(Rj~`ckbBKMOSB&~1|y(qA7k zabCo!Va-H;eIixTf&Ho#GOgFD!xtipIfZha$#R7u_a)-c)9=(qPx~h%s8`R#NG>fa z90^=}nt@?T>ir1eUmz1OXU2*1J$VfSyYK1Ykx8ptr$1~dY47EL1z{BRc8wxQA?BG93*uN3_ zsI&jM7QWSc0S*WB!JA23k17!1B7WQDS{`%LTkKxl2Ur6@>h4|D-B@DhAS>r-7a$k~ zGINXdFj6ETBZ4*H-t9#16PivQVj&`MC5U@ccB4^w=)DZTYW*1kET9=Yk9o|cS|Ga` zFG2)aef0uaZkv!m_5vtI6Ue5OK_D9i#vdt=jawQakd?o031kagVFFJ`AREq)qdCbD z$d(|RT7r>Tqd;~OfHJfv`v189`HZmo1qHG#D8oVVQ(9_)>@-#`mOz$dD#h+`q(ri7 z>sUxMf$ZJpRxd>n$QFz`n^Z+CFp5AnRN`X@WL-^URDrCOp*)Y2F^U%Q*AWQC zLxHf4q#}qKi$7mjg9$*gUu^@`nrx*ejEIi zi7lz?%K4BS+)J&uGX-XbNul_~p#aQuiBIn!3lh zaQ@x6aQ>aHV)xR^(9Uwt?-PHvj#FtZSoD6C1mhv8dXTF8GrP++s8yqnRF<#O`we2t zcjug0Rld8Ng@wy^#~>NG0LS2YI@*@+R5OVV%6Caf5=*{&{|LvBCEtCsK+AXMLsc{K z-5qRlU;IN%TC;rjbPubv*z#Q$RFaLg0V@WMe0RNM{kP=1<%i|d|9|-|&z2|u-^+K$ zb`QySZ!XgE-D;o?1(xpTgyg%|P22*+sghGfzWbnwq@#TI4M!yap$W4X`EH8Ia=Rh- zcN>xKK0U}G3Hk2h6y!1T-3kVV$#*X!gn$1}<-7MFdP2UN4?#AHeD?(IAq&cP(`-+% z?YSKuHrJEq9i4o)y#n7FO}_iRTbO+J-6d#&aQW^%WaT^^3Q)7;yAo2ga1z12cDBqpcNy~SW@T|yD%6G$>hvd5tK{1+qxA1MqcRuj(NcrxOMG^8{ z15s+lPM4+cPFr5hh$T`L0;vW5{>cnaG@I2Df}ec^)apl<%5Ls_Nyt?U)@g z*@bizI$W@uM2d$e$xmQuiCW|`K~ML1NrVOM8uHq9zV4P`EJx{7!kPt zyf7%=?Re|xETIKzyft@unH`N;R zrL0o;X^>_h%Id6xNN*wY_dgqCHt$D0gze2hX7hg32E+oHqrM;2Gs#BgO_)B)kNYKA z#&^UV=pds0VNO-ErF1<8n6nge4k#LA7RAar4RZ49K<1wzHfv-Kod)^qRgKJ}30hca zY56t5f%OLF9De&-{w0P;J{vF*Af|b^ViXQ#Y4^aSd(fRV?ibI zG)REc0h4JoNfa@WLqa?xvBo5cx{ka+B5PWwE=DR*sLlIPE4#Wv3U$c72ql+u%rf8x z?>UHng6qXQ(I&Jfe|0z>x6j(D1ICf)w~~d9QbeeIlFmiuz>Y`)J}5f?D!vUCLYWCQTYpj$4Bvg)aj3h z<83DW7Tz|Y-@#kJXdU{k{iHw4f#2*W{fln1pR_(SK($Ebj{ENy;C=ya2-=wO6L`JqN5E@9=SimxOs)^OOHbu)r$;PMFF4-ntB@r#*g>;TW|Lf#=%#hf`Ux$Qv zSP|-PxruMzn3{@zaqFvq^sO9!{^WL@Tp^Hl_VaK~M#Jafj}V_bfM-&bJ)gW2BRieH zJm-9-IEc$14qy;*`FMooqMP=bMeG#yCmJ^w*|wUHH1$0~2uimV%kuV4Ad!F<5s>t+FKt@Y~h^mDyh*5CZ@Yw72Gr^bIN{aZu+3+U&19cbmz zy;!?@J%icxr_3&QSGo_t4cs1|h?)Xdo%?t8tLMRUINIlmb~rJ$znW=W9_2Hx95vav zveY=bu>Z9^T265LxqZOxOcCy||CK^>wYZJ*bf6Gi-?rpqnJ+$fJJ1W?4`j|&^}SF- zZn8$pJk}sw3T`S{E7VHJ3q)OWALyRF26fGbAm8=GS?^d)XEkEc`B66nT@r6g!DZ-n zH8n#^!Cw(cB4=v!4MD3gJRHay~hmL<(~NnuB#$hs(rQAZyN1tb@;l`Dw1{#-3U2a?{ zsvBL!?nm09-2^Xh{|0zjs{umM@&W2s)#7D^iU);i@UkB0Ma9b&=Y`>AGHVcym*rn; ztHE?IdkZfYAy}kTgO>xZB|;Tm-h?j@rP>Z9&%lgQs>eoj1{F`_=68EKB^^1y^ z*Vof{c~dP^?jOd>V~N)eSBrv|hd6E#U&h`;FK*&*6|wLWld6cZQSkCjiI0JovrJ@E zyc};R&m-lSc-b4NY`omr&h=m7<+l5YmoK3;h?mdE?>;q$tpop?Brs*iZ@nsrmzfy;M}wF3@EtZ@Hm2Xg z%i8o?cvy?>P%^pxw^$F^EowP(je0qD=!AGnfX3M|6h0g9x+UGVOCA z7NC0_eJ~ABktp!b7Z6p?9pLbiuBvZZVDO=g_Jlip8q;&SxcG~j<^<=ggiyvf zBOwI3#h_?}RGHw~RO?Zr<^XiNLKxAYJKDf%Pt|L-HVu%`6Ov%-Yr7IEok`GNO+FHa zYw0DayiG!z25#a51S4V|e;q2~VX6})Rkdc_{hX1g?j}QMw@pYqB(x5x1c@g~ z1(Qc+xKLuNR0-G*NBu;yAvE*|b(?YZS0jw8r@G3xJgN^}#qRlM6Y}^1dhw@#@Z%vH z5|jR*GG#&d%JN6)ebR)jG=(ODNcp=V<)-TS$uxF_&s`71iOWNzXDkEn9TEVbX6y)f zf)-vELq?luZPv{Y5Q_h~rAF;$8g{>Kg-@`|x=Xfev+lJJFo@lEYV0mXuweJSI@{U( zh}Pak+BXcb7(o5tt76s-{6_2!GwZf=X|wL#cp-!nOi%4<&ALM|z8nL?T2PE;)_rXz zu=_r!Ga9=ArLx5#N6ng!a)1Oy7_=JGuxSwLqDkOUtA9rVOJ=ssy4Ua%F(iU!-A|xY zsZajU*exIw%dC61fysGNu7*j;5XA1IH|w50My3XXlm@8-9ntq<_mL0$1M)#E1B zJjQ}bq*-^Oi7#S2s7&LpLq$BKa)qRdAzWu05@m+OCYywKNa7@<64bt(bHty#A>9>1 z?a-7ow$cz5hU^V9ClkL%fu#~ShLW{n>JQ{E@%$THe#T*wpga;pd+x_34EI}@Fqc|l z!qSurVFd4ka#N1`gijo>J}W`M`a(=xOs_U6h)68CHkKvV3&vgbK7)m5g#h09aqctd zO<=_PzrBgq?TOdRX8^A=BJrC28~8ey4@ftw2pDV0&kN|M{A}>}VfronokA{8Vjsfm(Q`mdNsA9;h+#r-li=I_2sih8LUlH1NiQQg|)#0 zo>lC*Hz1q3;b)GBfAK!`bw7pGFRFcF?e7HIO7+nJRPGLoyAq&;_l2!I@h>a!BHvYbfJbOj5mS(DLkc<*3|0EYH>^%vU4N{=(rN$t)d7^nkPy#K`}cRPzkXM#{4< zoA@Hh5KEq&BB^44@km3W%#hf`U#BACp*-6Kscd;Ry;&^0WMJIPMV~0clyx5<$iwwvSI&h zib)1})`N&@hDo}y_U{%Un=0Ci(gDHqShO)I zvod4;hgBLYmfjJ@IDuXu>RE0Id@*V(_@ z)D^>?z&RETfAel7{x$_$q`Z5Q{O(f?$R^=`b0Gvk+7%8n#D!9>xCM zt40GGPleUO*a>c>-`c->CH>a^-7fT7`*&N@Z}#uH={Ea!FS!eI=Qo)ln`{VLFq-#~xURAq>cdc5rsDuzc#q?P-2M$>)e(00&y8f}*yw9RA85V0(x z%JG3|A~BpM&tdpjYHt)cMnYRP4QRU_tC(=K{d5Y-v7>EgED-}}TWvp5BcZKZBovlC z*5=yGSwZ?@M_+71Tfvu#&q?eVWjmjy7NJ#$w=c*q{2$m# zpvSf__JxO~*@(B<5=Fcnk2qk(rRoTc^05DXV8QMG{3>w!NDL+t;C3_;ocZ@^Q!OVu z6rdpX`}abqhV83ybou86?5%1Mfi1sLa62srfd9|HbFdZsG7=bR z!`o_jZ#&-p#B>|peooqkx2s7Ty#0h>gSX#K!0gGF+2h*I@I-`xx79>>vg7TQnC!&c zD=0GrZyT9VvbxZOlGM2-l&H!$0`puwoM=43+qSELw=0BiiCRdlw+g)d036N&Z~x2=$h z5t0%KaTkA64snmv)QFq0&o-AUN8FZ&gNXYmI7UL;@ecrTdqINXAs$nOyHR>oi2HZyw`Kf9Mo=OI5Z8V_?aV%nxHVY0iV*idJfF5; zkFA#?Ans$LQ&)w!BTTM}5I0lOD@EMqCQC%bJ=gHB9C3fZEVS#l7uK^OZpeOFMf&ZK zq110XLJAUZuae)xsuiUo=+AkrBK6x#5CN>HgY_(1k8oRyc@TkC-L?S5}f%HD#F`)AXX#ct?hhTM*>@lBP%(e-@Z2K?DX5ILx7PsynURsO}~AB zv<+_uleXb)7HNaG0~t1WJMwRcj$Dh_}lqGX!tn zG@)emf(a$5IVO~-9%CraweMUsp5X18rNG-vQOinHJ8HjG;B9wss0?q7y|)YaQop6N z2GrIJ98jBx2o1GJ9WL?_{%DMeXZ|rJImCaV-8mul-pg2fo4xnX_qDzEd8i0Bd+&Ng z3k)0og^^bicrAPHi%7-5iRi!3;tRHFi2uUSvePn%*LS}5;lF9`z5nx&Dn_*Tj`>#Gd&hr?%Hche{zm_W3*>uA#x@TyPSRdu(q&wkR2P-I zD*uJ=I60vH7P2S6CEVV-+N4WQp~nQYEn|TYEbD2>Re`;Cl3`KABEVt?e=Qb5kVS9g zvfF#-){d{h-cXUf_seYJ@gg(}?Y%Fsd4R)n@eAmvsV)!`8ui|p(sBgiI~rT|-W(Gb zul~#e0^^B9m5n&UkCGTyuXinw9(GtjdV&L!4EElBNT|f#yXD)nvG+bnd7a{T5eEQ_ z|3Wp)p0n{^*fj{)YTIA)leXD=capZ*dsmUR*?V6kZS1}8Gi>a=AKr~=b+=3_*HVVF z5e82CzeY`MI9;OZ0}H4rIw@<=bp4dWgxuW@jJlj zg`&)rC=a#fN^u(gf8Y?w-fQsr<;5DGiNJ1;@h?lqFqh>O04>gdvACCkw)qbOs*#wB zClTLTAodzra64v3X`q&U{XEyi8mPVvsC%JMY62&rSrDkr`Qb}g7wXH#Cb2Gw&}^L_ zKJ_-K$mfT1x0eIz4^C>Jj{O3o8}D-#K>a5MmIc&zfMX<}?s6}H`ZClz9H`rjMmb?X zJs<0?08rolX$T620QGQVrwBNjjl`2`I;-K>Z({A0DyO)>jdLxKw;Z8*gGV#Do2dhkxR}Gx0dt6i5bqN8n{PuviV~Fbi@aNdsZd>X3Yi=uTPI&_3!;b8@zTf&EWL~!!Wy6%j|NU!|-B+f!8UYqoyHvJq(aQydETL zMB;T{6LPC=CX}kuOek4h!%&`U#$RYT!Rw)mfY--_Z;ASb>#ZvA`VWlGNO?#<3*fRg;p;lvyCCgvaxM$6}L`%9Lj$ zB?}0TWVZmZ@f%+8XDj(=i}4$N?F`?Jr#)t}HW-RYP)P{nuWD0sFGdr{-zTo+xlYhm z+UfaTQ~y9J##25ioc4%ku{iBPfL6;sVtZSsJtXS)-!K?aM%H!>4$RMKo5Ww#RGgIR z@dYG?2+$7V*8=jVz|jEteolD3f7ee<837>ghlLb@-00UjEnD3=3`HTbkPiUkfB_wL zVqIn)9L53huw#wJ{Gss;KkMO-P&B2F zdvch`C9ei9W3=k7TM_A9O?n}l1UYGrUs%t{=>W2$7s3)qE z(x%+0nwF+j?__nz#HFfLCZAhzhgOlVB! z6-dAykhY=lB{1)T@8NF=ksq}81ipu`1Fh-D2bC=U;@_wl;QaFy#QQq5Ti-bxcwar- zZq1?KUmAE0Hjb?1ZLy(CE2B>kfHmy2ci869qVCuZQsG6P)~ zGhBo)@ILbs)D(CeavmfH;);{vZdr-`52n&xCNy02GofsClL_@x=?vw$W}mPif9y+u z{J(^CiTaUCIveCya2})#Bee4KApO`K!2cKJzMomrId=G8ju=e*_7;-6VQmrgFOsZ0 zzXymc1Q9_0k4%c7|ErP`K!4<2Y?6EO!5xO^C%B#}80T2{yOs;>G_XHjYRQE$s3kEw z4jK^ULXnmWDU7CE*r6ZTpCEGKPfcBdR1Cibq#zeKJSZ1p@T(SlXqO8T^&RbhD5L#H z8fciG5RhtWnjOFaiQx=y05NaLg(=`@peRNbOq}Qc*~UI5e9xzcwmq z-4wLvBP|_%SdS`-6ohn;R<=opJ50TFysnqDcThScONWF?hiRK^od#St2l)a$buX7+ zz+(0^TRfh>7Oo4y{>(JFu0sA=#RUj*oYO&k4a$iQ zJ*e;3rUV!HP|bw!{aH5W_Qd_*bkI)N?X3T|Y8B3t`BM2Afe+ zOJ2m|O?iGW9paAi;yPIn zXe6&skb?jBG1M${k8>UvafoC<{~@Gz*N{Gx{0Zr|=_l*b2ixhHp{cG&#qekYs+?EJ z$E(?H)@c<^VRf$J@GDh!eyGtQWTHX1#RukOV77IEB)1^_b#OG0z8LHbDkrKZ1_IJY z@6?da1%t+O`1=e%IX;^Y-w`YrO=_}Q^Z`>-GlP-yzm;tYn)p$&;UW3wsL;~X<$?e-NB?tUL~vWQIP-~0>i_7_!e>H1-RTH4N}n^oCPMAvSwY%%UgdexHv5d1^zT7@%^`hIV`>4zU+eG_SO=-=)^fhM9%48N zVc_eEb%+AgS?B#q)nUj6j^BNh5oklV`qG4w)ix7KQtM18Q7vOA&sFP)g{(i$0kYmF zx?YLu&vl>;S<9dID^=sbA(H(inghe@8V`O!zi0xV@ymP4uMsp>BVWPKu=Ki(>L<@qN`-rwR5Ck2k`8be@IUVu-wuhJ55tL(DZT?;(XcJ;r_*xbS8WR}$ zGTAxwYi<0vG1;vI+F)!HA2pX@hxdr7QCR>AxufrlNyG&}L z8nGOyAqZ+d=qURF=*~n-7k&VbsRve|bReiefkDtDqE9aCV!WU;41(%7t#HZ%p$JMT zY!u;&Kj`=kuFbdA4+u)r3icmt2>R6r8bS9gN9BN^ke#y=_LI8}L6t#J9j_}T4ID&J z#Ye*K%bc{z)=R*?7_Gbpx@LrE-c^~IJDXg&ECF21_NHz{bnxYpUV$b19Fv&JUKCTB zn7IL^c+$^#gHcpS&epoe!p_AKiCpWEOR&@2-BLXU zGveok@(cfG$~VyO@fJYwf0pK=!DL4@0Zso?7HF1j70`5I5)w3zBB6rwenTJ$L;alD zQ1<)Vt|Bnu`?omOV9xt3ycKwP7WcP}?+lEyo%i#Qw&Cafq;2>)fV2%i(@7IQfs1_^ zHs}5B>WSG=XC-Hc>lTKi5C&d)MB%aHsU7g7<*BkvZ%y1;d>9`MRF8=M6gwG-Sw6=MVYH5nss|XgBcrH- zqG|QAJO{vNm}Yb{K8W0|DDC$3L19?_J`IE4OP{O&zrXw;1iv@_SPsAE%A@%H8#D?V ze*Y8EcKohQkLD5zwTuu&xTqx+VONV;7Jhfy zDEQq2laTnGgoFz4`z6TX%JF+F)rb^FeoO$r5A-@a{9ft;=GyRk3uzmEzf0PN-*ZXZ z@H?Nh!SAOSHu(MgjhG!-OE^1RPcxi~Fz|cJQbdL5yQKg@;&+Lx*NESTOej(9HlcX+ znF+VI$H_wh%8-_u2nD^Vk;4OfBR1>g`#-!=AwhrrM6wd@Bq6DsqUZYt|y zhj*_=(hIc)JNZBWNzI2eZw5~;^Z$h6Kp?$Mn-UtbC~DNkUHZfG1xROWHm7|8q!Hbv zr@vtbQcf(j<|_@P7ZbuT1qDDc1!P?dAdO&3IE8Uz0qG!cjATma+8sdJ6!q3X8Z;%e z?S^syq=Dmr&tpw!fHYZUzlqckAT`GUyGoPUObPelF?HWtD7`9E!at27Jd2b2e`!kC zfm`uy^$VC1me>^G?eA(J{o+kjt|C)HEmJ9J?z1-~jKPN>0=)zX3^yfYi}GESDdAd^ zOIie6!c7U6NP4BFgi_8NKvYCi!ncxG)p5Wj$R%((h>HSWtU73eQ|Kj?*b!VQ_Wi-y zkZ#1&8uE+#FVILJbHq3XI4uT^s@73=NesR8zLs{RdHAj4Y*E+dhb@HNvsMuH$R3Tb z+mYbRA5)RLbSFs5aJwy~h<|?2u27qRmg1lTw$pbT?Fy5!fU`X#+7(U(o&yHnlniXV z6lEJb?46`-{?a#+w)sn6McU>seJN?p2*%_1-XhgS~VnWGEK$!_Q**qj5OfB&4dBGf)or=Q1}?3VKn8`dD6?46q-)f($k& zuGC-p2Q0$W53iyQK;y+^Y0MG;eq-r1W{JP^evBJl4yhv0n8pKVzWu(p)HjL7rK$@n zhxde?=&WT~}+{8Ve-Fu4lZY~T{^Fa3x~&t*D#Oi

{-EzEvT-;(ah z#VVP2duK}N<$21OoW2V0Q}@~*;KO5q;I!8J7WRiS$7z-$=OzJXfj-^=Xu@(rG%ZAk zAyum7%qb$+68<$UB=9q5EE=*_SPqWV!G9$*7w`}UQW(pgnaMoiIZ`aZy5+h(P0~8w zJr{$@N-KP21#kwO7kKER&%OfT7syko4<-`|IjI8xzr&v3t`)uJy4R%UBT5FDBIu3k zNqX&G$8S!L^7^l5>bG$YAS-5%ScFlYN5=GLfSXzR3Bkx&)E|W}d>qYma-OF9Ik?^Z zLWwD3CGz+d3VyPP8gk%H&Z-^Y^lptyKF}n8P$wsxn0%H_{v4AB;*xhU$;avB1T~Xi zh2-qwW76;?0*RS$Gp^UQdz$M01i6}TVTg!5ZP2kCW@yC3&W_|92EaH1%DKL;^!S=hcP(XgmD= z#&;zp1k=LKvoXTJqMwCP=21e3s9W#UN#~iQmHZ;9+_n&IR6>}v+9WMENh?g!7>_F< zO!}}S-RF*cqA86KCD&TZugkU4BOJ_7Nfk4bDI6oUg~&0oA?ky1hC#hkGpJ{s6~~~O zbCD@4i1RVFCAR-wa2om3M+BZN?O=iy6ArpA!be?(x_FgQU2QTjl*}omCS*?88M1s- z*in5XHF;S*Uh_?~HiQjI!t%AYkuh%FUUIZFZY|7dk+fsBpt@RjrN-yeZi~YMmpP4M zL1&>;lzF}(m<0_M^)g&&Uz$oXtZ2IWyAH}!JE&Wa$P8ucpuXx`2{MQTL^I}|quBEb zH+MiZ_IvNan_*%FO2}QH+0RM>iC9u>;>#HjV_z%W_~DFqyw}ZgNekH1qOll)U{3Nz zVNZ{N3 zq+ES@IVYmafx=*|=0K|u9OFPOr{gu7L0X-T?X$b%5-HfvroVtVIGyPiE_5gas7dg^ z*i6D(~pJCxhT@9b++-Lb^gk;;?=Xk^$ z?sEi&&TyY+!`UkLIdlTSkn?yJn8KN}nsJ|JAWGD=$bCXzgkJl&XMhMU=a_vm7s8Ed z`t2wr%6)EBx53XWEAEiO|H8sEQ8+5PDBPF$FCO4|SI`zp+y(TX8BPR7GjGDcGL&?@2jMQX3k7w%)$95##jC%z_*18ik zMui8Rv=`f{*C&ACF^q3peCJ>g0~WS`Y)A{flb2$wIKHz7(nc1M?`#0qOHQyE---Dz zu!OxDe91p%7$$j~2`^%}>BVpfYfu3lCVZ!#Zsa5X+8W;}_aR^%2s=Q_?ttse3U7gT z*os-stJ{V8{a`EnYw~ z=6R-d2-t{0SRi~^QoognCxFY;Msp0mz#eReKP9m0wXzl{04%?ow4e5IH0<1W z)O}?K%KU>o3A=i}9~lE+*K0T!HR}Fie(M+W`Z*|DZR-GPgoX(rLLEwZgTATC?UUfKA{kGcY=A^SFK@vAdFJzgDn@*(a{ zM_ZhMDH!*q--9i%=qa?3v~1T|R>P0hvY(H%dcMQGPm0=2qJ>>Z*%Kht+((qMf8k|f zDUZtq`bqjTgCKyphsEnoU-;RbUv-732{xC0lu{edLXn5cJ6az!4BPPJBP&uZTp?hZqe0Oc;(jIJtv}HA1zJ)Ucj?;#xWysSF&}Cbh z*v=Dw+=w7w88t`9b|$$boOeJ}Au-k&3I1D78%I*(OzVklVKvy1B7jO_0Um`~n0Wyl z2Jp5!fFPIPaa8Gd4;vTJ)?@%P)ZzwfTz(c_sI9SldEiO&or7>Abk|LXT3K5VBGUb3 zzNyc!7IfW@gfJ+o-o`Y@cW}^?AMS+pS094%BI)%=m>)g}VHV=3n1j~PfhHxhA$mXH z-oFQz9(RZRMvw!>r&78l;W&c?XMB+f$Huh2IGvLPCGv#@+%e+>e+IK zJ{tYRI7Utb%N>>L5zYs0(m859iuA}|!2B4^$Pnho4z3hUgKZBW_ZBO-u@Pez z{xaVVbcQRC+-UV|bPj57^;{WVy{xW%_=|1Ulacd5gG|Qox^OaH@aw)C9oQYoK?KO+ zgQt?-V`&rcTQEg}Nt+-uI12u6F`feV$UQi3g#qQrYPJV__ADr$#(y7%Kf1m}eFyRm%E0itc?aow_lxCiQoF{p-gU*GR9{Da!X(q09T+gn!4TOON@mD^ z^mxh0R5K4}yTDv6G({XC_H82%vyfmj18SVYz{OioW)D(Msn{>3#~J3qPBEY4NA28!`Pm+}tW!uJ zlab9sM+zOe#3yYP8{0A3x5gF%ghS3g#d>w|)j$NPEI+(i-NL$H7tt91VU^g2qH0tR zNsq0os?kO)VG~g*fz`qM@O9t^uLDzgE2c^lbf&-=_99k>VMo!{cCsHL?;AC34MA>A zNtH4>GQy}H><;g1u7t7U% z0UpmH;73#4rgH3bZ-xvt{{9ahZ88O(q6<8h1s)4G7W9&%=sAC3vM1bL-~C3Bm>;^l z`f@oisoPlY(kE%3Ti(|*q=DHiVlCXk#&#u#)AQ8QmgOx4S@JL{`?F*Z?B0E$3;s&i z^I7ZV-=WJthxsO$@}<2~-^1D)*WeiZqV=r(ROI}DQkU69W6G(k}^IpRHd<{ zZfH3Q834SfZe)XNpwFVAUWhykBx9Q#czqyxGm0v9VHScy->E3=*9)nNZ_@%3((Hio` z_3RvA?331EG5h=MH#FEc=#Mau$UdD zea>^Za220zh4HuwwPPN0D`ShLV!&=<2_fq-J+$OB6peVRQJ9{n^st&8L3Q*s$#Kv9lM?IL{D zTJ8g31aN)|4xu0FB8Lp{V4!&LL%vya52rH@yhJMB49E}*?d+_K1Vi1S5aO*CfggS= z1M%t-*&vcOqRswPKE$9Q6V6K}as2C6k~?f2zET@T66k%?XsHrt3Tc1b;EqK(x!{lp zoQobH_OA2=ccF#>VwWmF9EqX_3A&oGLr<97$_YxKeh@?IDNgKNSy!uZ5!;sPNY^=N9$p}9 zk1uGHUtX||((mi<5qc~1`!cwLjb2T^&j3-K_Pgk}yNd?qPT8~wyHM_lpW!wQW5BbT z3ZM#ysr@L*IQp!3kHRZ&-n;1@Sa+_0Y8>+Lmv3K!Cl4yY!VQ5*9~{`2a30>Uyxx^# z;hKg}a7T(MX1OWgu84C#JIN;+-WsGq>Su zrf>MOG<4Q#kutSt{+$dBR>n8~dL0yPK6*5qYK8H$cu-kn@udgN38Ecu2XzJ521M-Pkr%cl9GDD?nU4jw07Y!G1Zw{kA;Y2L@Mn>@Q@W}XXcGqDVd8!3bD!Y_GY_9 zt+cp@DlU?+?h=Mz3`SHzrV~dDg%z+czoyIR5=wgia^$kTS7K<<;X7`G`R7*~UO2s~(1` zxt_j7rZ#d0b^{{svnQqo-%nI|*w92G*f*=y7szN8pOM$QDdIyim)^Sba}sBh$#yWa z^#qxYuIH>%&*S)XKVUCX_o6zNEe5sy@Ilmp?=tgs{d0`}QTbL!)|hXDd}|_y^UegQ z_6n2kNqk%77hGfT=D~8HPP&DcX8^=h;f+-20+i%4E~jR+k_!*x11r8plvj3{nuR#)5HB-&J$I=jsUBD_99NW{DpF?M$+9 z0Vx|ofB>)qdlr<6Im3cO?GHgYK-+5Q2kDBR-JeC*s~_Q)I%grkBtKu0iz4tmsX=Jg zcy*Mio?8~n)-RdrX~gO)rNnDN)InC(APHE2zW5+1NH@>iKc@$Dpq8QdS#}|~vdq|V zJmnzvIQ(Vc2^5&?v3vv9YD3@~3bpphlU`)&S;rQX(&CRZg8_?xba&v7@2&Xmo`N8V zOF}m@3K$GfknokZ0}$X%B?mr%9=@@)M>S$g2)yqbZ2ZwzM%$Z~JzF1>W4bi5nHY(! z_@d?X^2c6yFc10Tqn$}`^P9}MiMSLKXN6(1I_sB`3nJel<=ArBrm9alyPNG%u|UZl zRoJkNKj4f5qAe(}>`Z{t1GZ z>zi2}$oiLWMrCeNb;(qb8{sJ=m|Vx~24LlBr*5=yo{HrdD+Oqmx{ZiSDh83x@mA0G z44kWdPCr674$jrSyN?8{!U|6* z(Y=K=w;~v|@0;c;dx%&VhUt0CTLF#869|s^VuuCK9WfXn!vh=WQo7qE7j(#{n*k9M zw|A*1(4HE4dp6ilw{HDl%L-#LLv})`IVAJ2aJ3Chc@w}2Kc6-Y?NYOb zYMe->=(s9?H$L(kwpwwo02Eqw0)&Hj1Ynh~>@ck3gYl3wj_xuBhpPvN-yIy@g?AQV zWEf0aVckixF685}5DF*%NtQ_71{h2`#CRKEhn4k-FSG*Tcz46fT3zxntPCaRXP=*3 z@=m^eE;zrNWP_M$@m)I}Dd3-_s)p-ES~L(}0PLL;2>&`b`~eJn<4x*(=-2XuF9SA^ zd}aEOe^e%=YJeA{PEaO34~vH@%@c7?GihEi*k_S@ktMtm9=@8kB4A&aG&pM$br18P zx=}BSa6Xe3aX^u@FO!0t$N-``JOTpo5~|w}A>M0wXSBMgywmGe$1)nZ6=QW#^a5UK z{T#t3F25hkc5Sv+AB(T&)_vA92ic@stfxFykD-5f=q%H$&->Wy7P62G)8TXAA;Ej! z!p1Qvm2(Ed1aMlu&rEutF(GCuPtIpM1_rn@$BZSB`WL_69Ked@6?v{3aNGLt%%h- z3JKA}zTjUcVU9IpUQ3Y-YXXo^0S|?E2sevY8Np=YKH#KOK9Hz-Vle>Oh7hfvBnprT z4S?Yck17m+6|)m$)?dvz%x84+@PR}&T@qVCe@cP~bj>(HYJ$UC&MKTI%Huw~An3lv zLhQW|JAv5aJ}Xt2YYRzRz_Cy>9pLYidn0f>!u-4jn9ROl!j`1ejWYB1u=rN{4`+W0AgLq$AckG4up@$51)+>_8L@m{}AQjC=SdC9_-s$vMfrk(R0kE zEWRX^pS24|0M6;vtX%zzY(87p`yHF-ox5Iy&;n-P91 zJi>y%fZ-9?#glYneb;O93qhRk5PwSKQdnIRe5B+BM;cc6ulNJZA-RPFgl}tD4R{(Q zeA1_80JzCYh(I$O>&|D9dVaxfB&#Wd+2H6*@|AfgcHhT5N=6T(^Qb*MGLIswz&5vr z#iwX_QET&NC77jV^QJBQor8qr(u8S04efJTw#WmhHR?%V%QcFO#~S4q*y16`2z6SR z3Y~6>Y(tj(Wt(z}lT{w(MeY(VWRU|J!1a5Fph4is-`Eqc`+D%yW<&exZ;&YOg{c( zhi%_1q7_wvfyh}wdVs?_bj*?+I^t8K z@o(y_H^QFbDBx$czff^2@F!Av+j~Fifdt5g6cB~Ylft+&=3d_jUXbcK>5m_qlMbwC zoZ3XnXnRNKeh$&m;4$(6N7+eh5e$e|R0Q)4fWgLBx($K*ZP(pgG_%koUE@Y0>F2K7 z$UJ1=Y_DyS*1FM1s$6%l60_a(%JzLC zWj;(OY<=dYCDCJKS-o*G4t=In#Ny(clwNNdl!8H2?+O)^{pJ=mnv@)SlnTV~IK4q_ zo`fd_P*kM}saNYH#N5ThgeXOf&^H_oEPCUtufqYO2!EM=D_pxR5YS0b3g=gUlysBM9qJS+9hqF1tS2L

pLJIk}_ zoY-lk8yR06JIWz3e{Sh$>-wZL3)N132#rG0W99x5rgZ z7LL6m3xj{S1pPy@Nc7#X{7H*v(S_;v)m+a-ta=9}9?W|iCn@eE?mcq8b?P4(lX^TK z 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 p5 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

ii&z0iKwxh%tT=*WS@%g(6OKD#L>8 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

Bx;~QCtSecl)o6lCS*^6!UEt`tEr5 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 literal 0 HcmV?d00001 diff --git a/vendor/cuobj/lib/libcufile_rdma.so b/vendor/cuobj/lib/libcufile_rdma.so new file mode 120000 index 00000000..f3ab9939 --- /dev/null +++ b/vendor/cuobj/lib/libcufile_rdma.so @@ -0,0 +1 @@ +libcufile_rdma.so.1 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcufile_rdma.so.1 b/vendor/cuobj/lib/libcufile_rdma.so.1 new file mode 120000 index 00000000..9348a4da --- /dev/null +++ b/vendor/cuobj/lib/libcufile_rdma.so.1 @@ -0,0 +1 @@ +libcufile_rdma.so.1.17.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcufile_rdma.so.1.17.0 b/vendor/cuobj/lib/libcufile_rdma.so.1.17.0 new file mode 100755 index 0000000000000000000000000000000000000000..6f878875714794a8c01329a155534bafd335f6a4 GIT binary patch literal 82024 zcmeFa33yc1`3F1!Mk9hrRTQnuRK-S%5FmlXf`(;uq69)%L`6eLCM24TWWu5%!4PG< zj;2-=*P^0zFI7RLLJ_IKx?$b0Vw)=38G~)yYP8gRzu$Y#-DXkx^#482_dK5ilXK7V zzUSS}d){;Ixp$WNC!f_PEzM(o`g+drFxPORDk;zvS^0LG0#BajAWwnkSkE!iwx4d3 zEZKF0Dm7D2rpgnWmzO^N!N(_mt@P8oRo+aUaMIsS-99e8X_6{8QzzU3sA@TuJtIBM zozBoq>=dHVK-1X=mxNob;Z|!nGc8~Pe9SamWj#d4Z=SA?PfybA%#>~UDgH22!Rs24 zY+|~vuQcwQMu z@YT1?{rr{M4Tr8hjkNp--_iJzP9>XymVTZ-o_=duZcfkgv=pST49xUQ@TA{Sd}#Xk z^p$Ko248;i@g0lrIDF5*cRaom@STV+KYo>X&PE!*_Z)mD<2&`w^H05b%?SnPW!(GW zTTiS!aoYz+p774O@7x)i^We$7m%sh`J!@C*y#Ig~UO#`%g*C6fG_3xYuV2yUt`UuI zm%e?^$Jr-r-2LKXyNIv_ zPtks}v_IJM%?dQY=M9y3=E}G@*t6{sRd5jr#ODZ12#0zO_N;$G<)2ZBr$x6v{xMas zUAO<2#=qirRsNAKpO2JyenLj@`32zl31~cDKdADwGk)@P`JMNx{2bl>CQVO_ipJ+8 zm3Us!<&QtB3bJ*1hsJa7Z&d;1!p~ncov+=d@|r!*VvT3B#!r3lldsDcJgM@UEYEI@ z|G39hxlE?G+@Q-pU8l-*wdZk-XW#}^ezHnD4`_PsU!e+S=q3<%MXtUPY15Kg{4KAkZvxT_rc4iw$f;|t4K`Mn zm)2C*R)?AjYyG2Y%NF|=dTN8UO~H@{ZObn$ogWN^s%wLuraFzX^nwwi%bU-tt_e=A zpFcm?SXftCUwm%)^z2ekL#V1TSXNP5+Z+lmE+x2CR9;_KQ97@&zO16WtSMv_tCr1m z(iWI=otP)ho39ba*Z3P7?HU&~=an_q>8i$x+A@fBVRd=1v@uxO7;LI4onKwysVuJx z)p#1}Yighfh^MZeq?U!M>nXlQC9vvw3rowuep%C!y7JQC!eCvw+%H2Z?sHkqF z=9+@M0RHmY1}cLH5enpLJdr@G`Khf>z`MO!7;DCrb*S%8dKF(1 za;VaVvdR^FDSJ`1g%f7^OD0S&9f9u8o?JL#V(G|XBgWX5Io9Qa^U8)`4L@eebz&c^eE++D#2^q@yPNUVZ!Z{)nW(QP zsMqspz>xkBd~kE%Y1)Lf(U%||oe$MZ|%`7!qo%=NzS zBvrmr?+=*eohPdD_PBC0ziYUfU^#7~1MAc2C_m0B^?0I=ax*4ib+@B@grj|rqkN>J zd~mkv_dt~CDPC%Qj&fTo9#58|Tu=SdKHE`_Dc}0!Im-Q3smD{`DA%Ht+JK{+vM@iz zj&jm!er7w$OAms&)@*xg90Y~}Cj`Cth`A;3?vmNDG zj`F#V@>3k;RgUsg9pw#<@}D`%7dy&-?kI0@l$&c9RUs{aZ$wC(yPv)Tei6pmlrtbJDms_k9%i4%vgh8OImkiuo$m#X5WO8S-c58I;F% zO8!sGbLkk{D)~P$&n07Qo#eMM&!u8)jpR2m&!u3jUGk4J&m~~2Me+|Z&!u0iLGt%7 z&m~`MuHa|svo zNd6M$xpa$le~W@4^O)z7E!HXd3z+9pEw)qgCCqav7TYTMbC~B6EVfSa6PV}HE4D`R zr!&tbSFBy~Bbnz?E7l_UQ<>)yE7lEeQRjgR@hceHlRIEVq{h8+y zDwZwzKFo9J6!S^`8*K4camf_Rl>BGRbIT#-k^INZbLkZ8{tx+opLrkios$1E^IR&$ zc1r$F%yWqp+ba1#GS8(^Y@Ot{G0!DYY>nhMG0&w?tX=YtGtVVZtVQwtU>bk zFwZ4VY_8;QW1dT$Sh3`9WS&c$Sb^lPWu8l$ShnP^VxCKvm{0PTG0&}(Sf=C~ndcHF z=8^m*%ya1y>)t2&XP!%zSf}JKV4hnpv7M4HVV+wpv8|Fnhj}h#V(X9(M8=h&AQ15q zE|A|78ib*D@c=dS4(jd9IKBmKJss=x3em{GS;OLb(=a50C5p{1m+lYrq%v zgbJfGq;K}y5$%D1!v1}&OZRy~!=tC0JsaL%^*6cfMn8KVa&!49z}nk2bB6aat)hcL zU>&Y|cXoM22p5^`lYkzu-yI0gjE0LKU~iEII&QMz9gk~+rI4wCMvxq+8!vdEpk7Oi znHCk$RKOUR&TC_)hNR|tUjq$EU=8mciV%~*p#fviE)l2n*88Va0Kanp{Kf^4 zX3C&-uamMHH2^8QS^)NsvU!emkn|6InZt?-}+D%ad!-0o?t z4;UBOPPzcVyD$lbXYN?(e*=wnv9r5rWP+lHqdzueJ9B zkaFV9IVjz+iJNgOUOWVcNC#%z$oeoYXm{^$Dy7ifW=r+u7TR@*%kH`WY@x;>8KLIFT1enHQO6)q%J; z8CA+)%x(_OxaN9v;Oc4%TA5uvj%%~41Bmz%pgD*aWwo0_l>TQ-H$_OesDE~KoY z69bzVDlf$8lkl^F*Qw>!&NPf&G5zM@T{&pBX=GM<((25vLBO_PSqA=2T>4nofjp(@ zaZlsR_wp!Lc=JAl3E}lU{JV2y+ZRZUHYxKK^~1!`CN*9^t}`}B^-AwpWS;k)g1>1k zn+f3w9R!xcYtaXF(uNBoLO^2`Q3WEK8KM``Vs_ACyme?12yffM8>-4|_I|;3ZEOeY zN0T+uq$4`%@}lp&V-Bm z8H292GU;7E5!iyXG^QN|{nWtXWja@XU1^pBTD~{H=_|Z>BbW%Umr%}VV+I4p$8rDB z=eSlyMnSq7>pyQ}!;BR?$z|59Vo|s_y>&A$(n1HRi$3tg4$Z9ecV%pt*` zMyf+E?|xc-;jz!GegnD&!;(W2j?45F%mvc-$6vrJU|_3`BE=lK@Rfbc5}=F(0)dEs z>n1KIsh;qw(c9p)4Pg~>7$j5bbF}J?Xu4#cb%Gby1R~8C`)ylAcze^Q7lvObq;sbK z*m)0Ksfbz!-hUx~bRrr;ETR+5DD)Aw&>^D$i|V>E~lhMbeM@;^VtN}+wFXb~A9JHOdYKI0$c>J!tc?dU`N_s~CP#1N zZbsK(8@Y+mHDDw6F5qLhWnoU?%lC4J1tVxR^&Vc|&ctYA!tv4(EyQ$;VS_Sh0aFXp zY*nsx>tal~9t>0qLYvqC2{T|~XdIz&wXFfl@!@w0F(-;m9RnWSHgzp+L^V_%CYxda z4X-KV(L}ZO9GY>>N-*yd-+TAk;(HC(Y68)8dRKyFO(_XV94xgAnpJDX_Z}9&vs(TpK(n54o%3!F^UOF5k0i_^v$>lF;d2g!@!B|c?&hlw#Q-U#=e1? zEkQ?Hg#73tPTs~UrLC*hvAv>t3yp%X?^E(ZwQ#x4=@PC1v~mG83GA)YqIa_A1MO}d zee{nw_D)0-cKaVx#Li7ZvdMxMLAqyC8vb+#GM7?lO(|GgQPl*GF%~RBCHC6T)(6a*b1yo28`^ zos82Q2BHpjBh70pc5O%g(*&vp#Z#59sj6XxH6m<#trV)%_;-#gr3cf3=g4?+4SqH3 zzq~76;J<`iHK}UYpR6hPm;(QbinRuzcoFSC5?DDW9?^*!(cMJ!8$qP#Zq>snDdK|@ z5P#YgN8tdCIQ?VT<@u13=`S7rLOVQd4*yDE`;K^|y=X!^`v4VP{n`=cIA)E&^1TJh zQSX2QL60f{0GA7Pt|NLgc5LZaUWA^a0nWr+7j^ifoCK_hZjov7@|;-@2e56Z)S?h2v@ zabi22roRoLN9)o(o{Y9z9He)&(7*6wQH))na64yEv!p|~cC^`ozD4Gb%5Y+ToU4j< zYI-dG zL`Cd!pcWIl{#g*4@s$6q)mXf7H2fC%SeRBp`L%A%BMjw_5!8cXPnTb6jA9?sp1`x6 z*gW5UMP_c*yUy3pOSk%a(p1ZWEDW-q#z!TmJDWsC5z4dU=pI}PPEWu_ z@)=4&tAr12Gh|QDru9pLo3x&lf*{VjtxI=#LdT=QE(u5asR=cM1?>77gdlK1iNro4 zI5n}iKs`D?7+Vln=3(v@Vvdrmd-(*n)b_cUty76A8oVQ3gI9+WW+pXorZsf1q_Ui#*tLq~>C>j?|)wAw-0Zy;rlbQCtP8oys(~ zl0ugWJBWJo+lZ_A5|uBQ3s0ex80Kn%Y7a=N##$%Znq%$q+v8cgn^KFkv5_*)Rx}ZP zYjMWLF_2Pr;{D(Yl336{Q^~k0Ao}*cB89~bVBtAczc`S;tr335`-G}mZ1unu+!+Z( z91~AOp(bJ!DwM#Uf?T&$K~QS1>w*tRFSWb0+tWPJ#2*=SN&@oV({P;}o~)6-g$jlI z0xC@ew@MTj&V-xhmC=s73sQykxU^{9I#_lz%td8yw8tbU&yY?Jb^4AX8%)(2~8#zvA-NMz7$x5X>0o18n@xgSl4@IZ5b;<^jS z6>EH?RQl*B$U@KR8Y59q! z{4-uI#<239B$u$%NFxIN2BiJoWDkL~o$NqjdoGC%6if<@|)}@`Ej1~VBfnZZw z^S7G(nI7~pvodkQ%lCI?wCPzCH2Ax_M#FrfkRV8w5u7FjMh0LH%TX?~DTXHur4QU+ zxAL&c(*l~)<+jH43WO{d(_o?)>QIb@Mm5wEa|ejTqvt zS(f8dmJ?Mb!vqpZ6R*`Kg$8B;%ri$r!d6~LQdyZ8>>AA2ZO@BikTPWy)ThjU7h_Dj zBbY0os6eDmG%oYs1!zJOf1MS&OL#_^XVv|dv3BuMmRnI2I9;eoQ>NvQiUp;2$v@Bo zqo6%ht*Pg2%oyG|tW2CK^97q3i(?X{wn2z@sNJ4{ltba(A33YOL+9S;C+w3`-?m1? z9o}7%hc9XU7$zdK-yc*_6>2w`t=+mm+MGylGwWp{Jw?=SN+*w!J?cGMvYZxBbcCY_ z*#nVPYcpjg)3GkgQg*_rtHZyS<_70Ig?#~_QsBMEGYebcjfYXX>cZWo<9r%sv84ro zYM%Yb^#Z-+QS4B)BqsI7JP4Pi5StbFG;n`nAZHZQ6T#Q>M^MmK z@30l_kFx}w|B=}aZw9i?&L2but@d>x=_qJm6|$c&YnZgai+SHw4LFyx!As1-tSuw{ zF?ln*Ppa}s?6Hc0yWzbXMb8%$z?&$1=ET9kXvj_R1FtXfm`!-2BL_{0?EQl$j&6J{Zv!+|VUS6u|?*i`W*-ZYkh6=KZ=NNlZQG4?Ua zjRHs+9bzwqPMPiomk4^49B>V&!hgdq7nnm<#@{0XtRq|Z`1^&kDsKGA(uC_^NXuKL z2(ZTAYz62Xe}1zG{hI`*rr%JTliri00Tk#8u<2#4Rb2K>+JJGUL>y!tUK`(z7NX=w zYB~xATi1H4efB%lw@ferie)2&EO}f{mOAe$O!5K4MUI*yOfM0V1_kLV-2SgqEenqn+Y=-339Rsx&!9kjtAd-tosq@~`AT5&ngar#{tP$O984UlXeCy3` zNw<0pgOCa><9qwKJzfFbWZc{Pq{NXtb*oYc#QL+_DtqDw`azi5V-j z&XlZ#Xn>0|XUnZk5}_-bwhC_`8?BouUr*>H_7sS$>;!U1mW58O9fr2twea5d5$Yl1 zpW^y@UMm%M2fT#TAaWF@^G$&8oQ196 z7}WcH^RrX2C`-Fe$DL2mbwBQZVc%gWTR_~q~KC$iq9_ZoH?i_^i0Hek6wB}0aX zKgNf@w(j1}yFT8YeIzmd?(JeUqoPTFmyG>{k8&?_$vH9>YAm1piL`o8-eU{q zlGlZN2u5~h>CDlhA6vjG8*tt8f!%s2F&o|wS;S!3@cvmYp@{r#O~ds<^LZ)DL+vwW zL$%Jtj%VCD^L94SI{K?nr*=$nERz$vYfGDQv^IaYMdIbxNlu(xzl|o8-54R-Z=Ubb z0YP}Pdl3;4qtRiwvZKq~Mds|MT$5S@&=KB{K*~%-ifY1Wq)EOV96tq#n-qHfpgm5#(JuYX1rDR}L^I{f?4kEd%q zG;%7tGBR-v#<5MR)(g$YqP~AZy}4Rz_3ukFX6{3qkN!p+oQ>5A;4S7g`A5IT?lF>_ zfq@y&`>2k9v@nY#B)HGPGg^#B3w!?3i{a<}z32qTcd>mb++dv#2WBe8o~|{xM3G6arR}7{{;Mt-5h-WqMJqyHyH%jp2&5( zH@tp3t-W>g4kVt86_2PP!dyI2^ikZN$Lh+m@N{*nu3zW?IoUK%Z5{WONcdUd07J@9 zeMICwEzW>gdLO$oUhnUN(tv8HhSy{?q25mc>#@UhzwpvN7FMvevOWaO2s+LCChd|{ zH4nIJn2la1b16dwea=P9TUyEyBsF{ccMEde*@32P=_HKiP9q|cGr9T{#~YQ?*l@KeuU_S`1z4WbSCi9OpYqfuHDnndL=Dv|ctBN4(bw_~{G0W4^bK7(hQw zBGe@8Jp24DR$kP5Ha-7a_!j# z2wg?qH6~88Liv1k_LOl@5hUmK`9*&eqqL8wo{c6{-&$6*Zf1Za3tqLO8jmn10pUIf zE#TadAF2^f2SRhf+q#$Pgpl+BZjoCkh1@Q3%1s;WS?t9jPCld*Zr=(1-KAJ6wC{>5 z)hG_z;dC5oa_=!8{s|b~djZGLZYHj8;k6E*UIZM9R?bl3TS2+)gKPj~$qw}QC4C8q)gez*cTnSVEe zRZsM5w3n;ze!A;3qIEyr)vJ4ozNIddQ;dJQ>lCZ^PCWLqG_Lo{Q}iyZsS#2bT_}C4 z5bkJP+fR4RF?%+=&%R-DiRfkE$hdwELqqH7E_aEB#+UNqscrv3NG=Ux+U7+yjdFtQQ_I;`%OXk9{fs)h}IXL2_NLWTH_!sm*LuADQ^*ynH02Sk|DsBXjn?%EM7Y#K>M&zr{-nvqz$@AJQuJHYNl_T&#NUJGBSaj0c+G`Tk-!J&4DY!b4IeK% zQ^Yf01n?DfUjt|nujj2 z;uJiH3QVV?o;Z9?!_s`7!gZ=gTPYM_9f+DWc2!~EK1}(((B%WPa ziuqsZ)O?gtJ@+DdkhK`vcJ60I2wW0A=qJH4yE6i~uFrds21|b98o~t24*`u*7`Ho@C5j z28l&-vzdhTLk3^}9**7lB;&8X<^7JC^`+9oErt)ib~e6*jGu0^TZSd9#fUP)}S zrTMG^{mX08=xru8C^w0Lu-XB-#Rk1vfj+E2*SbN+D9~XJ&>L;ga~0@f1-ifu$~W($ z*UwRE5*)NaGZm;`fu7+8eO7^Pbb#jBpl|kwm=0B-2fIP9R-j8Ap#5#o+Z52@cTrmVyT*;Zg;9i~=3x2F+Bx9_Rr5tqppT0GzL1VIb@^+%s(6Y^A1Tng6zDB(&}|CzX$NRO8}zL&MNF3}&^%BU^G3`~nmbf@EAf^2Eg#8_l-yhG;Be_Ql4VuwOPeXpr zNh?pDnDibay?F;I0!&N5hOV~{iZ-!Bu=C~;B+3>qQgFLpB$eJbnWVI!-?J7L^lQR& zcppKQAL~KMBu{GJK|23G_@wq586_! z#UeCipYJ`@+xu+vc-%?U;lwkLA40h9E&RC|%Z#rEbr^FTa!b@vXGr~16yiTNzm#{G z$)0ve`1cB`CqU9z7b1^L?j{Z|^pESO0mO%juPo+0lGWH6W7RGkD94Wd*#6CUq07u& zt+lupBGqX-pU39@Nh*`?-+ASsyevm&0>et}U;3iL3O5@dh6ln}kF7yGy?Uj8EgoTA zYZR@4k?z!w`wm*V2>U5Ma%_&*|A4mW>JHu=R!&;7FA<_)uko)0%~a^#d#`77KflXo_!*ht)psO7Gg6BckEhIT|tM+u@$A}zYBkao4trpm=4tKReXyEBO zG}`+lv6oudT@%9cy@(vp$z~p>;lh4Z9xhh4O~PM1$3sEl-VHLy^&o@X7fi6r#fF~H zz<|-lE2TPJo3UX%5%6ggdD)0MtOItx`KNWOBctsh;6b(B7*5k_`7rj-^i7eBwpQu5 zTT!!@{dfHs!!xitW5XoxPK=|2I{e*I+`rYoHx2ub8CU*QPLAheTd}pL4_?y%6H>$+Cp%_dqz1>tLRL=kQpPVfeqm0O~rhU2Rmh`oBnv4FxlNNXp_GdJwL$mle)5 zykq}>XFPh+mQ8KX*szM68_hjN(Y`>Wtr!_RiDTOS2O-#g3n;a$EDcts+o=uiUNoU) z1ZdRe&>DZ<_*vs;j-SCZfIN1<{Z0%6jI>qV;<_VIBzR&Ue>?ooC_!N_nYkSl4CrMG znCwLw8V|8iq;TdA8~PcrV}f4w zZzt%XaiBdA1#Sa(w@oCdzo5cvUsU zJVa%+Zf`KWYqlxHRvP|i0+ChhpdFVy<{M##icl(*J25-MpThHe-WYGE=M$l+dg}F4 zG@3}2 zdCX@Ojc2yo)W}igdlTq*4GMPAu}0G|7Hu$8T`A7ejpr~jK4TIDXuCy|2L-Bgq+xxh(;2zc}qq;CUvkO4_?LQ!DKOV z;3WOsDuh!mY`6mHi5>xjoCZ(e+u8guQXDI4RxiZK_jflR75(xt_ILuQQz#JzAin4t zWr&+X4u_SmIK*fZG9`EAk{%RFdipRvlT)W%v5b{l&g1yrnDh? z4e-j1{8w-h2tOBHC1?yHyOp7%i$AAwR z_pyUzi%8KGX-IdFsK|c$N3S zdoKEv6tqWw!*p=;0ki&}xKQ(gi~OGYcs0;IUF3g@CZy#eRK)US*G5Yehj5Hl6uAz6 zcEJuTYH{Zug5I%NQ~P%~@#xVeHDyB0bJ2sOpgo$#ba3>Whc!3jrT$r2wrY9vJrUw< z+7d`Ehn2fXzFw335GrD|=ou0wo$zs$j59`B`GP)`VgEmL7EjF3>FsA0>nW|<2*YZu9R*OgrYPsuAd7J&BybYPm{2I%jQHg9*_~A&V=Wvrs4wUsCYL}p;m8( z5qo|D_}wHdh$o>#lduvM;9t6dkNkyGL_9KTODi()0m9%00}_`w%tknithr>U2k{($ zmOR-N8B{CXQ9R3V<)-b;2gP18O<=K?3IXVd4kqDd2O_jg4o$N}PPLg@ybi_@r$rzg zG>oVs1D9OtBHQc^WR{{vX|bdan&IA%3rp}!tJg!ODh6<>}d^4aGU1N0gP@{TXrIsmbkzpR&Q!5U2 za<5&5UWK2K`j=XlzT^qj7~Wh>{drO2KB0aE6H@;oF4P?9aZd3$350+4YayJilq=2C zgdYULH)05SVz(cFfjDzD1Sw0v;yD>l&3s(vDshqmtBoyV`-IBi;~%fY+IBYH&$vN} zmCsQN>d2rkFCn+Ivpxw#)W#F>zBGnEM};Ed2oRzB6t9RtaEj`<87~4bMFlhGQ<#z! zF?QQ^h@)TI#A%S0G5AyPYpfE6CKSYSl{=Cp9-Ov>S3g0S>LH_zyE+~I>i}#LkxWU~ zDJ32LPbY4RngTerl`jE<;a$3(;_0(&hFKXXFzM81cSLDBl)U~~9dGdCXq#HHGA7ft zyl$fP`me)KyE15akC1NqF2liBC6R^#qv*P1J=tf+{+!U+PMVUlv(M0kGW`3!vS6j| ze~fvgTNih(MSG~n^>R6EnGAoLlj#jlrO;^T-;f! zf&;RC7!_T3C$dQB`GUD7QAPpHDtt3AXcFKSjuYzpEjv%QH;M~1Qn=J@=ybeHj4w&| z9FcF}%I#9$g>GGhY?8)^?@*yeEv*6OzFZUkayI$A{V#D}&*P@}JS zKG{7&5r*uxT%5U1nDV&tCiT&^YsAgn$%Jlh4=&`$va;{u0;BmQlWfd%e9s@wdWzTi zQ38)&-2-41Ns5n>k#wTwv%kgX9k4~iI{`9fRB|bDntYsoKhLHgxmnzMu`6eCOUBO5 zklh#AJyYxhVmdZ)!gub4G1~1)02P+)HM?vYQ1#f^Vq{IZ0n1cmqjv2SWIOF_5&E!m zlTqo&o{Q{GyY?K}F5*6rT~>$|;Z@uLvdaQCXEZLu`@6>|mOMuDv&I*XpJvF8OtH~M z-jHwuu-KaXxV3~`CH8||B|#nWZmr~KcwP;Jcd1xxC+RNX^7+O?99g%?4Hu71N zLDk%q{(E#z6Bs)2dH;QQxYPumx6*&71zfPwf5-FwyXNA-NHvmFvxADWN>_D8U_EW+g7LJB&@Vt|(Lm|^j&cnF>6A-8s z!jnWLW8zI*xyStnkcwU*2)K-icLks$dNPzEXWWE6u#8?5scPbTYnQz<3O95MY=RN; zdC^bqkYW1~6As(c?nE!}xQa$=1LFDwa%PYm&54k5vnJ(IR46xeFJxzUe4 z?0#9oD9APnupK|Jp0JVJ79^$!$%9dxqveMelUPDykUR@5<#x@W9O;&>ayG8qB3pNt zh>TIIEwXU}&=LI{mC8!35HP%SuYNiOcNAJXGY~OhH*+5+$F4jn!poXM{aTB7YYYwg z=v*Jk_0ze2l1taQbZp$~4M+1WwdUhJV*_d%kwFb#DJXl2SU$kuJUlJi^<$R7%4&Ff zQ0lP&cE7DR=}F*2aQg|5Z1Z`CT^Wl;socrT$*Y%ms*SJ68+3LB&CR}9-a_T0sten- zxEqeCgPVf7 zRdxJ3Y~tSm?sj<0owuhDJ#bOe5FL1%HtZR=;Lh8=TUpQ^{etP>=qHke;pa#_4L=jT zS%yCjw7QMzLJSq%N`>WTD|Vvyph65P_9HK2(mf=z>tX}1l*2vN!~Y;uV_RCkxC?#W zgi*=CW>~K`4!<3}@OBxhe9czq*p$HjXxD&N{~p*OcGLGz|f-JQCuh*ZI!YtOTmxqP9%NxK%PzQ+=$1 z>et^kscz{@((ZonyF_zvLMIF2JL#`G*@%h`f2SxkvPxWw0WqlCvp+$vG9U7u^z|Z> zEa|x4va;xvw+QQtn9$vB!G%OgsaSusEM8&n!eU*lZ$}d<=`&Uc9Ual1{zj20rR+Bv`gswRso|H3$Ld+XBep5{ipWD=F!(r^2U%=mZX zDHy{$^8t}%#tl6vgsDYnYR1gnnlf`6^^64akBKLrO-Oz@Dq=7mD5?juuEh9l$VSh( zSqtkIxS$>7OF?^d1k=IMQ_cDXQV%;4hhY=LnO477TISZj&5f7oHMBq#Z*ugjas4%# zk+46avK3N86#oPQ#e4|u`fX^1tu}dGQQIyddZG~BZ`nk*9jkHod_tFpvrDH1cj)eZ z#tN;*xjQXQ@a9VA{gex*?a`}*_2EotM+Dm-DZUCXDjn`hy9oV8+V88=KF zh#}Zupd3V8@whT9aO#xut03Fe*QAylpPX(FdWq@G|S(^{- zbnVMdt@!NLKCP9%-lMg0%)!vgh+o8O<=_OW9{pvUguI%f?Wl;o*`Hbo3s#p_d|!?&(`8lrKlE{zm^Koh15p9tQ{9M3baJ_}Blj{q>hGQ6Ej)G>qztk{K zcJjW|Rz!G?HgFzn)27?Bn{8e~{ByVHeAyMY^fGahz$n7*L++&jz`25#jApL>O{JTI z1{$|jT_CurYCo>r49>=INKkdYCgyfln#gfvzUPtb%y{SXzgi-5-PKD0(j#4+fyz}7Cbv`rtcvU95UcY=o8 z&$%$ZPwLCn=k2=ByX}fiE1@Av!;8TQAR6FY-6t(dQPCks8hX**@b>;nk$Ntad!f)5 zXk59XB%_Y$hMnjYXd&>F72NtUs|~{&yHl(pwOHvrq*ip{j+ zSg|39L5*1nsVEYi?@-82;OFKDNp|pZj^^b(RLCiOt24I=M4o3TwHwczdqOx-Hbtm| z$NDYYc680P03IB@l?kKLPF%>1IxY(+bjR)1FV2sbai4ga(lt#-p(1u3IxxI{xm}xr z+DsDLG+8${lTMf}Rxk>QJ&^Qf5&?Kj&Se4zp{3eP`g@6K0tcgPON;1HZ&Z}Snzhrn zt@Sc+L3evUD^&oC{Ti>@3g!Hw)`WL37F1Hh3rb-JroI6B(Z`Ou2D?r@Z7=S``}fpJsE zy`cRjY%OR*(+%&1LJL&>B%~94bfq5SB3Y90EA-)(+$r&7+^oqcKt&gR_ z6UPWOo;V*HZ+*@sxnnKjnywbf)i9ytp1?&a$<-$i_a^MlMVz6D+lz{L;<%`ZCr-|C z&Ttdga*HXsx7vibSDBEwBff*UQxk~Gizn_ZP2AK3;()t)H*6A?f)Qz+MZk^)gr}Y& z*|HVpsNN!2EL31eRLFV8>@zM zbVz3;lqLJs@?aWz{4H(~$MyIvW_#7+kqJFs72jjGH13GrYI3T66{dAFS@UG9z(b|j zr&l@oNg$SMO=Pq^!CFiSD6E)FkmQ5yx+DOb`bbettkZ#KDE1EsiWfP3tKyil?J2o{j;Ujt5v_ zi9_b3)thZ`z%Wi0QXmfgh+K4Wi-=v^9>;{k2z+2?16n$`Mv;T-TLlfduALmu^`-HBUZMMZoD~+=K9ceJGd9;S zf@~oLT>pX5@m0%&>&uyt>utD5Wdy^}huaAD&}5v)*zz?Q|3*cuLZaiXxQ$NM872-# zHN!+o6ny!lH90)aACEd5kJ_tI??i=uw|G~j#j3nO3rpN*qy55L@ruPhxS_?@E$&U* z+S++s_}SM#=5Lbr#XjO`Hq07YB$mbc9qG8isa~elNwIzVJIvYGO$Q1MVYIXWAm6{Y zc_r3=2=?PN%3Z?{f^~;Rxob#f)v!L#isWxkaP+s*+?=93T^eJ(!U{{HgGt&*kmeZH z7YixSC`VXy-BQu$gG{K=Zd|0&=-z4ZVm~yVjBn6{eV&4f*eVLl`w!eeGBw(bYKKPu zCatN_$rIyIKSk4Wa`*?0`de0L4t3yv_{(+?I)7Kz_{vuz8@Upy8Q9*{zukHa&Jm_q zj|_@y4X-bzv4!#saR%($O@r^Ia~J?R#kj3mv|zBPO@06 zo)FLC8z9WZVy0%X3l%CpxPpU1HfzAhF`ZQ87kGKg7r0wR(o8wvxgKLPiNtgpkVN>f z-sckCg`LMF^K(Yq&7z}oBGeIV;v2*x(K{~J#_$0yXbgPi&t_MD#e*m7$83~}rp+=U z?0;JCdiGxwezuS=2%>6d702_vn{rc|I3gv9joQ(Smh(?k#`szVypJA7B4IfhH*5lt z0Y(t=3pIKYD5L-ZafLx9HO}4riIPTM9s}KRtk3g{70tFiI&u_^eBquhd6rVt;Qr;J#D0Z zX@?DbILc53hr>Hbm@WAmTBU@HZ`#j=z0E2X~!}&Z6Dldb)ga zQQ7P1;*;0WZd@?tj&=ud)i>i{_#gyMhe|>vTmZ$p1LJP0AS_SGA~5ELBL+#9B(lAR zL2?Xoj?qzh8QXvtb98)otr(d^&tgoGK?fjSQC4#9nekS#fyNh+EhH5|^~2@>iF?^3 zF2)15hV+Z#Z+FY+z>wfDg~;IiaFgF?Q^ex5h}vmFDIPG#Q?YO8V;H>k9~xr#-xz|| z@tp~uf0QA=cD@S_X8}kZ6qvdJPUQFi_p6q^fstfYs+Su@-$Fgamk>STw9h z*cTjOr!UqcY&kBh5hjG1BC{(p4qALHyVf4im@Ljt)OVU5u^mGPbtM*xD{* zYrBlC?J~Bun`3K-Ikt9mn`3K-IktAB8e88ka*Zu6M>y0lxWp%zPrmR+RQyrH`4)K%!B?z&T!VVLx0%|EP{5az9wy@2d&X;6=1K{j`tR#tt;0K-aRu>_tCe z@sQYt`4EvjEqdmY9B6ysW3Yh4n1(6!7a}o#ETVPKX_lB`CKJXKci;j>u84I!zf_!Q zEX8j;$}!35uJ^8&BoO@oq^7qni$%R$`qgN{e}~H0J{P5?zubkNbW}QhLv;Fv==2TI z=^LWcH$DDL#*=Bu`Ky*2&W-ngPcDp8)N^P;Mg5xm3jXSD>0JZ(WHr{R|C*Ek72Dg4glFplBpJ^>D(Cm|wQ z*Qg0qjqwc02n&f!>jAxAHQ`&5sWz6NjtzjrkI%SYr4#WkQn;fZ{g$I}A9T>G9<0W0 zQERIbtz&;GAk8VlDY$Zra7G9nI=51)H111Lu@Q{*#wK7qW1v;&ieEz#@tq!$*lDiS z={pG1FW84%Z0wS(wSTRDsgWZZ@5BO~nu}1y?=wMr^rKo!yrF4^cg!+!(s$Vz z{51(BNQoyp&W@*lpwRD--b-jgjh|E}(u=(c^jeSBd5QyX0n_H2A)3!Oyd77n{_w*} zO5^HTH5q@>@%0HE-&9Y*IXb>wcl||k z(c6pj-1@=0xgrMsf;(GFuxLILfFDfqZ#17^)U`N4q|RS___($E4^-&R(=`YOz_IxN za1LkvY=CLYt$Y7FD)&K}|2vgu{?}9@GRCWm+PX{#FY z*GI5Vf*(-4J6Rift*rAMveCEDPRoWXhs6*X%#Y`EFwmKJLNpjD;3G76ETh2A%MaCL z+j-vd4EgLlx86gUc0Ln%^T#GKy<)ul%9rco&*cYJF-rcGL=e<9+mBopN9CGQ+#* zGSbs;SupxCCJ-Fyc%BL4+=0~qk|*u`gbj zy<>3*@7iK#aYsY%n@P9&%vU=Mrb7;raOj!JYN6(^FCK1tK!v1Q=g@&VW*X-X!i&;$uS<44sT7 zG>0cpp)^t6hoYA~H*qpgA4>l8d8Xa@$aIJ~IoQ_cnc&UTu{WM);!=T(87E&|!cF)4@ONgBi|*wj(_bu9UT1-BW5~1a+FrAb#a!7*?z`R2 zjR`d7k(7A1^N^;~K&6psF7Py}BL+2cJ~6&#HE=zw@s7IU@f@Te!!NL93B6cpsQ z5k|couyr%9J&P|htL0});G3%r?_JG`1MZvVpyZ)R;AOczgrM*0`Jgrlz3Hy$Ef>j zG@}^|C53j}&)0dYMW=@cm+lIwVU#kSdpV)EOWB)~<-h2ju40Ai$^K;+^^4}%-Z7Qq zJjUje-uo<*b6yaG2&KUiN^)J;FF;tHK-;U(w2QVinzoZco2bLu0a!-Lt&(`e zv}P+hoRjtWeW}5wCfiil$Ozp=^ zeBM%iau9^__jUQ^VCfL&NANiDPMuS6QQ_~XSa~CCXpZ6iL!+(OI2x5L?@72vaAUa$ z&nEDFG@%JSh>DG0f^Pjo!9oKEnSURDYFW!bekZb1-Yr1>@H?$#WeiXG`d9^_$6ZF- z6&Mm`p+a-wcc3|1(1dVmpnHL+AmfJ3RG!A#P+-9#8j?3_DoxmilAXZo{qy2@9jkf$ z4=TFKu>MzF$%`43ww>L;#$4JyGNA*1dxu98t25$#!OIYqZl$d3OEjSp_n-pdaqK#X&hXyfpp5wn6Tc2`8Lo=CAa4Y6 zy1Y+A?Ur@AL~YSx|3=rE1ai)ZC+9bsoK>iB4oLG^XudR7Zjp#@*NYmwO+%F-KECKV zkLUA@|NW;0Fo(Ab}qw@Ph`LYa7P(fBW9(nM0a~ng2aAr<^-w>UmQ<0sr{P zGXm#(Ci%}U89&KC2^D5hiGSkMS^kp3DQ9~Mr_35Zxe)hbJa=5s+j}3rkKy|izFYAv zo?0@abo|5_g|qw~x%QWoOfB&Mpmbtj{FJj%danO`^ZIPNczTgpIB{~Jf69!~5`T&R z?850Y{3Rf0R^dc{=~?4vjGye8IIUFSoK~z$ipS3glol0&=ovuo$grWwU8#Q-uzIG0 z#yR)~@vXym5xy<>hVi`--`nwBi|?cOZooIx*c|j!men)`)nF-Ut_xMy27Oh*vYJqp zue`plvUr~4nrJ*Wlq6)=BePvBc>dKWK zo5q<2q}r9%*4I^s>KliZpFSc#568476^-{*1Q%A92WfO!g~g{MJ;m(5DFmZK&t-M< zgB7gtopuKPD(gtVI5Kw(xd>m3`iG}^jHs!(ygb;{ zRM}ipvm}LXaYQe5S#L@_)X4)E_4e|68#aKQ z-+!0l;TDvAIj6Tb2VbVwV*Hq2XIqwifG^O+(RI3SQ5j?ofmhZy`lxJ-fqB(6)gee8 zR_Cj2@-l z!Dc9KzOTW_he++yh0zPz5hs<^)YO-AmT{7nVhrTwnGXDW;4PK-${HKXQVs6hd^NbC7aN}_*F}tv zQ)`*2?(fpk=xozqCW?S6+;~iRBSH%<{w`sU9zoy5kIU{9JP0riPI2d>15=VuA-B<^ za8gk|CBd3tSt?6NWkaL$OmH>clt!WNy0ZDfM(w9-sxPB4!U#%LJn@~wVa#Y8HN{8# zLma-Qs^(Ayy<>TOZ9`2EQDySsnKv@qGsy~F%4(>jCBCY%CNp}`;}v$F3PY}-E< zc3wDDJ9no}&my|AOkerPE(gszf*WBd`q)O+S8dcU@NNYed8(*z~D=_Xb z&zYFb)@4l=b~iL@(|kp_sFOy){!s+$x`T)L|^Nz3ZWYJ-lBN~`M^ zmW{Luu)Q#^xzZ${BB-hPe?vXBHH&jApdpzZDRXPTplLXqD^-Mxis4XBX;~=L*fgAL zIu?1XBGt+>gb-|tzn;Pg!%ONX`h5#WcvNaF%sBYuqvBm^yplU4mDP<+q0+|s^5DXe zrPU1!b4r`ggBs)*kUmvkU4ePJ0!~PxqYBRn<;|7V^{0W2(;6!lHJ)(#$WdwrAx;UH zWp0O%mCR zfL9IHEhPW{HKZ9wrQG|iEv2g)^S65G=oRTQ&5o6S10rGI-tFHL(kZ`6E zcx#KzhDXQyK}Vh$ZaC&EB9k~63le)XW~eW?SXN@gh7I$L^_5>Yu2VDTlB(te3*86(ckIT2(fX@;59L2vxjk@epZ zoFlr0r>Lo@`)SB$g=y7wm9)$6G0~9-AYHIr6xH~+5t>xqqxAw|k`@1Q;y@TMZ;4No z?o;bMdc%byeTBsfbHqKBg`gU&KA?mo0?D)Dl_5}M-fu`unUoyo%Lq>vUQDZ&)AGaVB zJIb6m8WM4gQcJq>GAdP;frP8Cw8W^5y1c#uJE;5N1V)XZp%g8V{<8|FO!Chbw}n61 zBNy{~`u}#(Uu@qBYqAzJ_{RA>z6A|3qYgtVAtnnwj&X!t7)-dOwPj70j?2cZ1c8ex zN<|fnQIiNK*PLh1vexseV{Yfr7tJX7e%l|Fo8u;#kcvi+wFZP_L3v$sE$J3V2z4d3 z;!&7bvxmt)k9iLQHzSmN*>rM%7EUmOaYj<#PiYQjdmDxuAu_)bFi|);IT)jMe;l87 zhXmP={&LL?is_E6N}nF;79}bA=bF^+U#*Mu+JmaDo`)MYGJf}yn9-O3&yrcDtehLs zGMMNktTjyvLa=M&4#UkYISx%(sX3ACpJen@It3d@HZkOe@y_=VlyCXDc&BetR?*zZ z7^xh)C3VdW`=P0P%g5mc(j*Tv${% z!&NFbu*5Hj)Xa55mXNA;8aW0Myj|`{=*OBvtZj_qN%T-EHcA47TNo-D#|}k>8d*tZ z)La<8^sfT<@&#F*p}r|ICr>v2W?RugayObgD$k}(b?BQo?Q}(2(qWvNgBek}L;SrU z8NWF>F1bxFDJ>d5yA-e5a>`hjPRE@=2LoKC(S0;<)3S6?Bc~KzHO&v=GKrYX4FWd~ z(^|euz`6Mr8|XC|AEV(!)$9rnr(%5E%_^N%Jfn0{32tUhZh2IcYs5b-nmjvq(yY=+6K9-X>}T>*REA2+kc1IA8XJ_niRBv~@Rf5%JV}#LqaD7H22v?ADLhU^vTkzp zN`~@K+Zu$~Z#y2XqEwIcX~yOV5LBl=x7SN8fFykAnTm9ocx`U}7sR7w=hBH6-r#?y zcZ`Z$6kgNE{vY5)2(4pshT*>ICUKLA0viK|h>tx#TMk>Vn-~Ts0fW=y#}yBlZql)S z6qg}q1uDzRWr>^w*O(EWVLsf^L1ZgSB^?Y61O6FRK_7yxdBH};x)@P%Lr1Mpu~}3Z zY-}QL41q2SHr6L`Yh&OboLYmGB_SbSZy;N)L>mv{N0}TDAnZ?2Jtkj;kWSM}>@5$s z(DWyvzv(5Ijo^m9b0Z-ydz6c(r1Mf^NbOST{dZC6|?G2G6f%vC5jV`AuxTSkFhv z!t*?=I`sV~)i3rvD||&I>~23hZNzk`)=D+jl@Nj>IPsJuVLmr6Nudr+|5te=^#5Iw zz%tp<-~Wvq5(r4-H9vc#>Q}a$p?NqPhy0TOj1-?qi_xym)Eu3Z15_KFHgC?Q-#@nV zz(lv8-{)uq0thK2~R}#+`-oT6T~S8s+EZvjyY9mV-0`FaxVl&8m(+c6Y7<8z^bDJXl@Zx; zFIAXL!00n?i6;sYcR;zHWXBP9uhzX-b)TNYAQ?QD^$vI_7)M_rUG>o$Zm$Cu;!UW#iK9FR3|p_!H0Q3L~d*)!8nSG!sPa1**$L0TXurs zB&T8F(p|QcWS?}zs1e#RyX9cVM%pZK>QVPKW$FxUx$~%HGExy`sgD~UyruI@qh;$h z(WaO!%TIbW8S~B?OLDq<1LNhCd#CaWEA2e4_mm^ zsYa}+Qk)UQ05NmPn2_6_;3L#1=lyI$7NOG}BiL_f#Ql@{<|fXn!P*Aw=gR7PDDRl^ z&TmrY#(=&!bZYn8w7V2=JViymOi9?PvJ|De9cp`~WUOKCnD%z z?LEAo$Fupw-rliDk3I?K(2=f2dIi$2klumxs3E<*&mb*Bx*O@8NcSOq1?e$(E7ZS{ zjzv1=WWXb>LV5+#bx7|(8bkUF(z&Mq9_ezV#~gsSs3RSVwE0xPA$<<%6-dwh8Q_pU zj`SI%bA|#AX(!TsNN+j~@CSN4eTD%Z>Bj8d-nmF8jlj8ir2iO=^YTdlmDk(59clX5 z-rhY(Pb%o`?UxR}Ili~|B%~Kl!1-6CZIgO?E0ErJ7JfMu>9K`4FN^e4q&txQ5@{6a zy;FL7(+|Qr8ZTbTLfVNmfHZ$vZ*LXS4MkF!o9&tY4kzS8#mBf(SWA`dozP2gwPUS|b(I=BUF1b2Z$*lp$jIJ^=0{z34Kb_>3; zIf`Ber)}Xql4B?jcFGFDMUO;L4fyS?v|Dh@Hrg%tD7X&%E4Txk{221!5go{XHV8I@ zA$TEsh}M8Nfmea|gG<5Rf$PA!U(oKspZ|(>4^DiNc3&I>{HdeY4HpHy77yrkV&C3< z+S%8ngxHh#tT~ajGV~2WzX22b4LYy?QH%O44aS}Dh0{iroFamf=3G8YhC~s+6w1%w z^c&Ec8Gm$9<}x&CzMkmq@Y28J_$7{CPIPg|8jcu0-SH0)e=)o=X!T#AXk~vV{3YH{rrC|Ctrx%_voKE4Ri9f zIlct`3gp@IB*#x!Rv=kW^$&j|{C1zuY*Pw^mtS!iSQ14S#Q4dMUk*PGzAeTtbNmDF zKY_nG#?Ny6PWU(BACB=4I({GgV#XtBXRdrQH#@$N_WcrkM~r{O@g?xh!&!$F;~Nzp z5_c~Aui>|2$LX(KR#5PessdF94WyYmf<7#!<2z1A8~iWfAEu9w=~#P&%f}YdoO1@_ zg>R>zz}53E_|vjcbPVWp6dYY33Zxzm5Pwn?<7A=FA75zszQhk=d_0Brl9NBVm*q#o zpD>pGF2;Y>@l)WBIV*}jAIskDW@P;PVJ=0e2G1N{4@ov&d06r z^J?<9)!p#Z;Ty5%e8|+hGJFeu1H9~9>G*=9R3S?lN&NRG(AUR&-0Xa;fIoFo6s?Tu zZ*%&m!nea;9^>mA-wgjOJR7;@>}M7`z8!veZ4~`GX8%oRe=Gb4llh5+nEX~JzZ?Gc z^P=eH7=MG~--3Swes4_w^G^Q&=28z%iJ}cL`Fovw1$^oGQFM;a-=t{O#-_rb2miXy zXI^#k&G5y{neK}5D-|CS*ACwbzc|J(&<2Q;I_eKz5Q7p^>FMbWa} z1*6oEtopL0q@8>f*Peb^%*gcx>)_9aALsMBJ6G~M;G5u|isfa8%1emM%kTr)tM56+ zJ=a!b%za7?`+=k>{!;q#rtPr&bi?~KX+(dA(;{P$X-=oSAQ zkvw$j`BaG9N2Hl_1M?lO|6Cp<&9VJmK0+qN6TVAZh}rp><7?pe!talj|0}NiuY$jq zYsG$yIWZf(ikyz+q-nb|iiY{+Ul6)^+XL_`S8+ci#$T%V5VbqupZy_al`QW`x$=IE zG#}g@Mc2ptXm)w%!!`5;T+3b&^W!qt=1bvk;~H14HJl#>zj1sm{26QUGsYk3_y+is z?~S5IWA=aQ?6<)`0?&@&IsKW1j^70TnfvnhiO;|v4}VR}{v2ojHTaq9xCW2uf86Qs zLmT)H{Kgo6zvD~cm))PAuZ2HyJ@+1b`Ky(_bs>XRIBqaP6!w_cPAoenf?zhp+2A zNYvrua0whPfx{(mxC9QDz~K@&Tmt{kB@n8K8rM&!YA@T%WMZj*T}<#*xt`+Cv0Sew z!o6gk=J5j);V=m+=Y%qcmH*+8C2$|09Ea#YKllEXv?_nCxTeyU@TL6a;9Ds;&i zwZY4#{EAIFxy+Q~cn!h(1N9dhFVEWKu=(7fLd?MpT6-TyI{(iwx0NF@VQcp-6D~FU z2PW+Dsm1>1|JRuMNE#j;>X?ZJrx~1UaG}9ggR2d0G`QX1(+2k#+;8w*gGECFbsT4K zxWUl|CmNh)aIV3H23rlTHn`E?c7snF++%RR!FLT7onq`89By#5!HEW^8Jufyp}|&z zs|{{6xZU8>2KN};Z}44%MdrLe&fsu^qYX|pIL+W(gF4sx|7!(7z@O?P1SgFje^yvJ z>4Hl}gxPF)WqCHNtf;K4$X1RCOE2P;n_3ptYNBlH2+~X2p3O&Od7G|zL48YbcM}1Q z2G{fGaPq~-F0Xr($qobAnzC$lb?LDAvzkYQWmPq0Ro-_KukB7it#9|5dD>12yDX!u zt{FCern;psKFPBYU-vlG!=&nN!}v3)Tg-}XI=h~P+Z9&WGrkoZPrhin;rQ3Sjy)3tk`}VXym!ZyYgUi30T0bvSOaD8{j#)8d;>*Y|(hqCRd^|QoY^qav^`J}od-4CKx$}s8A7w=4Mk7f5={YlQB z|D0Yw3m-&(Zca9jtorresa~c@GbWwM+S+(od7jt-SbA_bbVw;l`6b8u<5vljDi5r^ z606pnZi>lqBiToNnA)DK+1KT%MkboRbXc~7@6NZASEuz&7VaD0dKeRvZRMTx_SgkL z`zARSUy^;^Uw)X{7uJU*%S|R0+D>weDq5S?&KOpcGi+qfv{lmW`TF^LQ|liq`n^7{ zTm7T&ORHZNhkvsEk?YdyPxRR;|H(FV(*3FRvlcwwhLU~d$A_T%)8zfl^{MmDdZu{Z ze}F2#ue{{J)Vf(t@>QkNbb^@&KP-Ms2gmgN&S*1RQWE$z` zwPRD-yvmB`e0gP^pu0;_R_U&k<9UtcPWq8#8yNd=>b$Y|+RK}n)6^w=-@7@reilx9 z`l%;or0SN2_>nwM);yBhjv2RdE3cE zy1fBNbSKB3soT<*2@9KbnS@=(hh+J@cnEgfK$oX{PU}eT1M7)n^*TUQ_2S;}mrHt$ znwbrPQ0spCNsU4If(DlO^XmygIh&-+DZl#K>&s_d-`G@N#=gTU#0J+5L3#a>Ygx3e zv1PtySeL&*ws}&?Okf7w{5efCMZkP(ZfXh2Wx01yE~w z&tlUj}j^Ek8qVlCR|LchMmRQKvFDb6(?YGISkg_*brMYdf>} zY3g#eYM;k16B%diUGJRN<+&Z_OaUDl9EEsqJ{hB?+I+ES9s@cf<}sBEe~xeO^32G} z+vj8!J55UI*X59N!aqt0NFJ=beU4^vs$`Bs?9xn}{2+I>G=cOiA*|OgSXY=vp!%$*_ zz@l0^r=!$=b-we>;8C(4dr+f80Po?A!Va zb{p1ULxrC@SAI73R=)W1_P(-3;rt^RZin>cn^Z{di|Ujg*@`zxlKGe7@#Px|wVcI~ z1AOaU^S=pNo~c_i_Br{|leHe(UaS@ywkShEe^1^%M{oO-@;i_fOV+-9&!GJi}`=J#y_)k!hR3zf9e0d_? zsE2DGSviI^G{SHWuBb|0qI{FF*BSt$E)VjU{pMF7lGf`tB#~Q?2Ds(%`5> GF!(RFEPZ7F literal 0 HcmV?d00001 diff --git a/vendor/cuobj/lib/libcuobjclient.so b/vendor/cuobj/lib/libcuobjclient.so new file mode 120000 index 00000000..03793109 --- /dev/null +++ b/vendor/cuobj/lib/libcuobjclient.so @@ -0,0 +1 @@ +libcuobjclient.so.1 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcuobjclient.so.1 b/vendor/cuobj/lib/libcuobjclient.so.1 new file mode 120000 index 00000000..2456d898 --- /dev/null +++ b/vendor/cuobj/lib/libcuobjclient.so.1 @@ -0,0 +1 @@ +libcuobjclient.so.1.0.0 \ No newline at end of file diff --git a/vendor/cuobj/lib/libcuobjclient.so.1.0.0 b/vendor/cuobj/lib/libcuobjclient.so.1.0.0 new file mode 100755 index 0000000000000000000000000000000000000000..17bd0810c3d6128e289b57baaf56e719ac381a48 GIT binary patch literal 408728 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

xN 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