/* * Copyright 2008-2012 NVIDIA Corporation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in ctbbliance 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. */ #include #include #include #include #include namespace thrust { namespace system { namespace tbb { template template reference & reference ::operator=(const reference &other) { return super_t::operator=(other); } // end reference::operator=() template reference & reference ::operator=(const value_type &x) { return super_t::operator=(x); } // end reference::operator=() template __host__ __device__ void swap(reference a, reference b) { a.swap(b); } // end swap() namespace detail { // XXX circular #inclusion problems cause the compiler to believe that cpp::malloc // is not defined // WAR the problem by using adl to call cpp::malloc, which requires it to depend // on a template parameter template pointer malloc_workaround(Tag t, std::size_t n) { return pointer(malloc(t, n)); } // end malloc_workaround() // XXX circular #inclusion problems cause the compiler to believe that cpp::free // is not defined // WAR the problem by using adl to call cpp::free, which requires it to depend // on a template parameter template void free_workaround(Tag t, pointer ptr) { free(t, ptr.get()); } // end free_workaround() } // end detail inline pointer malloc(std::size_t n) { // XXX this is how we'd like to implement this function, // if not for circular #inclusion problems: // // return pointer(thrust::system::cpp::malloc(n)) // return detail::malloc_workaround(cpp::tag(), n); } // end malloc() template pointer malloc(std::size_t n) { pointer raw_ptr = thrust::system::tbb::malloc(sizeof(T) * n); return pointer(reinterpret_cast(raw_ptr.get())); } // end malloc() inline void free(pointer ptr) { // XXX this is how we'd like to implement this function, // if not for circular #inclusion problems: // // thrust::system::cpp::free(ptr) // detail::free_workaround(cpp::tag(), ptr); } // end free() } // end tbb } // end system } // end thrust