/home/docs/checkouts/readthedocs.org/user_builds/advanced-micro-devices-hipcub/checkouts/docs-5.5.0/hipcub/include/hipcub/backend/cub/hipcub.hpp Source File

/home/docs/checkouts/readthedocs.org/user_builds/advanced-micro-devices-hipcub/checkouts/docs-5.5.0/hipcub/include/hipcub/backend/cub/hipcub.hpp Source File#

hipCUB: /home/docs/checkouts/readthedocs.org/user_builds/advanced-micro-devices-hipcub/checkouts/docs-5.5.0/hipcub/include/hipcub/backend/cub/hipcub.hpp Source File
hipcub.hpp
1 /******************************************************************************
2  * Copyright (c) 2010-2011, Duane Merrill. All rights reserved.
3  * Copyright (c) 2011-2018, NVIDIA CORPORATION. All rights reserved.
4  * Modifications Copyright (c) 2017-2022, Advanced Micro Devices, Inc. All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions are met:
8  * * Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * * Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in the
12  * documentation and/or other materials provided with the distribution.
13  * * Neither the name of the NVIDIA CORPORATION nor the
14  * names of its contributors may be used to endorse or promote products
15  * derived from this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
18  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
20  * DISCLAIMED. IN NO EVENT SHALL NVIDIA CORPORATION BE LIABLE FOR ANY
21  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
22  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
24  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
26  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  *
28  ******************************************************************************/
29 
30 #ifndef HIPCUB_CUB_HIPCUB_HPP_
31 #define HIPCUB_CUB_HIPCUB_HPP_
32 
33 #include "../../config.hpp"
34 
35 // Block
36 #include <cub/block/block_adjacent_difference.cuh>
37 #include <cub/block/block_discontinuity.cuh>
38 #include <cub/block/block_exchange.cuh>
39 #include <cub/block/block_histogram.cuh>
40 #include <cub/block/block_load.cuh>
41 #include <cub/block/block_merge_sort.cuh>
42 #include <cub/block/block_radix_rank.cuh>
43 #include <cub/block/block_radix_sort.cuh>
44 #include <cub/block/block_raking_layout.cuh>
45 #include <cub/block/block_reduce.cuh>
46 #include <cub/block/block_run_length_decode.cuh>
47 #include <cub/block/block_scan.cuh>
48 #include <cub/block/block_shuffle.cuh>
49 #include <cub/block/block_store.cuh>
50 #include <cub/block/radix_rank_sort_operations.cuh>
51 
52 // Device functions must be wrapped so they return
53 // hipError_t instead of cudaError_t
54 #include "device/device_adjacent_difference.hpp"
55 #include "device/device_histogram.hpp"
56 #include "device/device_merge_sort.hpp"
57 #include "device/device_partition.hpp"
58 #include "device/device_radix_sort.hpp"
59 #include "device/device_reduce.hpp"
60 #include "device/device_run_length_encode.hpp"
61 #include "device/device_scan.hpp"
62 #include "device/device_segmented_radix_sort.hpp"
63 #include "device/device_segmented_reduce.hpp"
64 #include "device/device_segmented_sort.hpp"
65 #include "device/device_select.hpp"
66 #include "device/device_spmv.hpp"
67 
68 // Grid
69 #include <cub/grid/grid_even_share.cuh>
70 #include <cub/grid/grid_mapping.cuh>
71 #include <cub/grid/grid_queue.cuh>
72 // These functions must be wrapped so they return
73 // hipError_t instead of cudaError_t
74 #include "grid/grid_barrier.hpp"
75 
76 // Iterator
77 #include <cub/iterator/arg_index_input_iterator.cuh>
78 #include <cub/iterator/cache_modified_input_iterator.cuh>
79 #include <cub/iterator/cache_modified_output_iterator.cuh>
80 #include <cub/iterator/constant_input_iterator.cuh>
81 #include <cub/iterator/counting_input_iterator.cuh>
82 #include <cub/iterator/discard_output_iterator.cuh>
83 #include <cub/iterator/tex_obj_input_iterator.cuh>
84 #include <cub/iterator/tex_ref_input_iterator.cuh>
85 #include <cub/iterator/transform_input_iterator.cuh>
86 
87 // Thread
88 #include <cub/thread/thread_load.cuh>
89 #include <cub/thread/thread_operators.cuh>
90 #include <cub/thread/thread_reduce.cuh>
91 #include <cub/thread/thread_scan.cuh>
92 #include <cub/thread/thread_search.cuh>
93 #include <cub/thread/thread_sort.cuh>
94 #include <cub/thread/thread_store.cuh>
95 
96 // Warp
97 #include <cub/warp/warp_exchange.cuh>
98 #include <cub/warp/warp_load.cuh>
99 #include <cub/warp/warp_merge_sort.cuh>
100 #include <cub/warp/warp_reduce.cuh>
101 #include <cub/warp/warp_scan.cuh>
102 #include <cub/warp/warp_store.cuh>
103 
104 // Util
105 #include <cub/util_debug.cuh>
106 #include <cub/util_device.cuh>
107 #include <cub/util_macro.cuh>
108 #include <cub/util_ptx.cuh>
109 #include <cub/util_type.cuh>
110 // These functions must be wrapped so they return
111 // hipError_t instead of cudaError_t
112 #include "util_allocator.hpp"
113 
114 #endif // HIPCUB_CUB_HIPCUB_HPP_