You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

sleep.cpp 1.6 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. /**
  2. * \file dnn/test/cuda/sleep.cpp
  3. * MegEngine is Licensed under the Apache License, Version 2.0 (the "License")
  4. *
  5. * Copyright (c) 2014-2021 Megvii Inc. All rights reserved.
  6. *
  7. * Unless required by applicable law or agreed to in writing,
  8. * software distributed under the License is distributed on an
  9. * "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. */
  11. #include "../src/common/utils.h"
  12. #include "megdnn/oprs.h"
  13. #include "test/cuda/fixture.h"
  14. #include "test/cuda/utils.h"
  15. #include <chrono>
  16. #include <cstdio>
  17. #include <cuda_runtime_api.h>
  18. using namespace megdnn;
  19. using namespace test;
  20. TEST_F(CUDA, SLEEP) {
  21. auto opr = this->handle_cuda()->create_operator<megdnn::SleepForward>();
  22. auto run = [&](float time) -> double {
  23. opr->param() = {time};
  24. cuda_check(cudaDeviceSynchronize());
  25. auto t0 = std::chrono::high_resolution_clock::now();
  26. opr->exec();
  27. cuda_check(cudaDeviceSynchronize());
  28. auto t1 = std::chrono::high_resolution_clock::now();
  29. std::chrono::duration<double> diff = t1 - t0;
  30. return diff.count();
  31. };
  32. // warmv7up
  33. run(0.01);
  34. for (auto i : {0.1, 0.3}) {
  35. auto get = run(i);
  36. // sleep kernel in cuda is easily affected by the frequency change of
  37. // GPU, so we just print warn log instead assert. more refer to
  38. // XPU-226
  39. if (get < i || get > i * 2) {
  40. megdnn_log_warn("expect time between [%f, %f], got %f", i, 2 * i, get);
  41. }
  42. }
  43. }
  44. // vim: syntax=cpp.doxygen