diff options
author | Zachary Turner <zturner@google.com> | 2017-05-11 00:03:52 +0000 |
---|---|---|
committer | Zachary Turner <zturner@google.com> | 2017-05-11 00:03:52 +0000 |
commit | 3a57fbd6db74b2eb5cd2789036c521f702cb323e (patch) | |
tree | 844c92ca46463cee221cf988d2cf0f8e16a5c736 /llvm/unittests/Support/ParallelTest.cpp | |
parent | ae0317e4a9f4135e900891c4fb010f42c7764400 (diff) | |
download | bcm5719-llvm-3a57fbd6db74b2eb5cd2789036c521f702cb323e.tar.gz bcm5719-llvm-3a57fbd6db74b2eb5cd2789036c521f702cb323e.zip |
[Support] Move Parallel algorithms from LLD to LLVM.
Differential Revision: https://reviews.llvm.org/D33024
llvm-svn: 302748
Diffstat (limited to 'llvm/unittests/Support/ParallelTest.cpp')
-rw-r--r-- | llvm/unittests/Support/ParallelTest.cpp | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/llvm/unittests/Support/ParallelTest.cpp b/llvm/unittests/Support/ParallelTest.cpp new file mode 100644 index 00000000000..f381631ac3a --- /dev/null +++ b/llvm/unittests/Support/ParallelTest.cpp @@ -0,0 +1,48 @@ +//===- llvm/unittest/Support/ParallelTest.cpp -----------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +/// +/// \file +/// \brief Parallel.h unit tests. +/// +//===----------------------------------------------------------------------===// + +#include "llvm/Support/Parallel.h" +#include "gtest/gtest.h" +#include <array> +#include <random> + +uint32_t array[1024 * 1024]; + +using namespace llvm; + +TEST(Parallel, sort) { + std::mt19937 randEngine; + std::uniform_int_distribution<uint32_t> dist; + + for (auto &i : array) + i = dist(randEngine); + + sort(parallel::par, std::begin(array), std::end(array)); + ASSERT_TRUE(std::is_sorted(std::begin(array), std::end(array))); +} + +TEST(Parallel, parallel_for) { + // We need to test the case with a TaskSize > 1. We are white-box testing + // here. The TaskSize is calculated as (End - Begin) / 1024 at the time of + // writing. + uint32_t range[2050]; + std::fill(range, range + 2050, 1); + for_each_n(parallel::par, 0, 2049, [&range](size_t I) { ++range[I]; }); + + uint32_t expected[2049]; + std::fill(expected, expected + 2049, 2); + ASSERT_TRUE(std::equal(range, range + 2049, expected)); + // Check that we don't write past the end of the requested range. + ASSERT_EQ(range[2049], 1u); +} |