commit-bot@chromium.org | be19b9e | 2013-06-14 17:26:54 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2013 Google Inc. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license that can be |
| 5 | * found in the LICENSE file. |
| 6 | */ |
| 7 | |
| 8 | #include <time.h> |
| 9 | #include <dirent.h> |
| 10 | #include "SkOSFile.h" |
| 11 | #include "skpdiff_util.h" |
| 12 | |
| 13 | const char* cl_error_to_string(cl_int err) { |
| 14 | switch (err) { |
| 15 | case CL_SUCCESS: return "CL_SUCCESS"; |
| 16 | case CL_DEVICE_NOT_FOUND: return "CL_DEVICE_NOT_FOUND"; |
| 17 | case CL_DEVICE_NOT_AVAILABLE: return "CL_DEVICE_NOT_AVAILABLE"; |
| 18 | case CL_COMPILER_NOT_AVAILABLE: return "CL_COMPILER_NOT_AVAILABLE"; |
| 19 | case CL_MEM_OBJECT_ALLOCATION_FAILURE: return "CL_MEM_OBJECT_ALLOCATION_FAILURE"; |
| 20 | case CL_OUT_OF_RESOURCES: return "CL_OUT_OF_RESOURCES"; |
| 21 | case CL_OUT_OF_HOST_MEMORY: return "CL_OUT_OF_HOST_MEMORY"; |
| 22 | case CL_PROFILING_INFO_NOT_AVAILABLE: return "CL_PROFILING_INFO_NOT_AVAILABLE"; |
| 23 | case CL_MEM_COPY_OVERLAP: return "CL_MEM_COPY_OVERLAP"; |
| 24 | case CL_IMAGE_FORMAT_MISMATCH: return "CL_IMAGE_FORMAT_MISMATCH"; |
| 25 | case CL_IMAGE_FORMAT_NOT_SUPPORTED: return "CL_IMAGE_FORMAT_NOT_SUPPORTED"; |
| 26 | case CL_BUILD_PROGRAM_FAILURE: return "CL_BUILD_PROGRAM_FAILURE"; |
| 27 | case CL_MAP_FAILURE: return "CL_MAP_FAILURE"; |
| 28 | case CL_INVALID_VALUE: return "CL_INVALID_VALUE"; |
| 29 | case CL_INVALID_DEVICE_TYPE: return "CL_INVALID_DEVICE_TYPE"; |
| 30 | case CL_INVALID_PLATFORM: return "CL_INVALID_PLATFORM"; |
| 31 | case CL_INVALID_DEVICE: return "CL_INVALID_DEVICE"; |
| 32 | case CL_INVALID_CONTEXT: return "CL_INVALID_CONTEXT"; |
| 33 | case CL_INVALID_QUEUE_PROPERTIES: return "CL_INVALID_QUEUE_PROPERTIES"; |
| 34 | case CL_INVALID_COMMAND_QUEUE: return "CL_INVALID_COMMAND_QUEUE"; |
| 35 | case CL_INVALID_HOST_PTR: return "CL_INVALID_HOST_PTR"; |
| 36 | case CL_INVALID_MEM_OBJECT: return "CL_INVALID_MEM_OBJECT"; |
| 37 | case CL_INVALID_IMAGE_FORMAT_DESCRIPTOR: return "CL_INVALID_IMAGE_FORMAT_DESCRIPTOR"; |
| 38 | case CL_INVALID_IMAGE_SIZE: return "CL_INVALID_IMAGE_SIZE"; |
| 39 | case CL_INVALID_SAMPLER: return "CL_INVALID_SAMPLER"; |
| 40 | case CL_INVALID_BINARY: return "CL_INVALID_BINARY"; |
| 41 | case CL_INVALID_BUILD_OPTIONS: return "CL_INVALID_BUILD_OPTIONS"; |
| 42 | case CL_INVALID_PROGRAM: return "CL_INVALID_PROGRAM"; |
| 43 | case CL_INVALID_PROGRAM_EXECUTABLE: return "CL_INVALID_PROGRAM_EXECUTABLE"; |
| 44 | case CL_INVALID_KERNEL_NAME: return "CL_INVALID_KERNEL_NAME"; |
| 45 | case CL_INVALID_KERNEL_DEFINITION: return "CL_INVALID_KERNEL_DEFINITION"; |
| 46 | case CL_INVALID_KERNEL: return "CL_INVALID_KERNEL"; |
| 47 | case CL_INVALID_ARG_INDEX: return "CL_INVALID_ARG_INDEX"; |
| 48 | case CL_INVALID_ARG_VALUE: return "CL_INVALID_ARG_VALUE"; |
| 49 | case CL_INVALID_ARG_SIZE: return "CL_INVALID_ARG_SIZE"; |
| 50 | case CL_INVALID_KERNEL_ARGS: return "CL_INVALID_KERNEL_ARGS"; |
| 51 | case CL_INVALID_WORK_DIMENSION: return "CL_INVALID_WORK_DIMENSION"; |
| 52 | case CL_INVALID_WORK_GROUP_SIZE: return "CL_INVALID_WORK_GROUP_SIZE"; |
| 53 | case CL_INVALID_WORK_ITEM_SIZE: return "CL_INVALID_WORK_ITEM_SIZE"; |
| 54 | case CL_INVALID_GLOBAL_OFFSET: return "CL_INVALID_GLOBAL_OFFSET"; |
| 55 | case CL_INVALID_EVENT_WAIT_LIST: return "CL_INVALID_EVENT_WAIT_LIST"; |
| 56 | case CL_INVALID_EVENT: return "CL_INVALID_EVENT"; |
| 57 | case CL_INVALID_OPERATION: return "CL_INVALID_OPERATION"; |
| 58 | case CL_INVALID_GL_OBJECT: return "CL_INVALID_GL_OBJECT"; |
| 59 | case CL_INVALID_BUFFER_SIZE: return "CL_INVALID_BUFFER_SIZE"; |
| 60 | case CL_INVALID_MIP_LEVEL: return "CL_INVALID_MIP_LEVEL"; |
| 61 | default: return "UNKNOWN"; |
| 62 | } |
| 63 | return "UNKNOWN"; |
| 64 | } |
| 65 | |
| 66 | |
| 67 | double get_seconds() { |
| 68 | struct timespec currentTime; |
| 69 | clock_gettime(CLOCK_REALTIME, ¤tTime); |
| 70 | return currentTime.tv_sec + (double)currentTime.tv_nsec / 1e9; |
| 71 | } |
| 72 | |
| 73 | bool get_directory(const char path[], SkTArray<SkString>* entries) { |
| 74 | // Open the directory and check for success |
| 75 | DIR* dir = opendir(path); |
| 76 | if (NULL == dir) { |
| 77 | return false; |
| 78 | } |
| 79 | |
| 80 | // Loop through dir entries until there are none left (i.e. readdir returns NULL) |
| 81 | struct dirent* entry; |
| 82 | while ((entry = readdir(dir))) { |
| 83 | // dirent only gives relative paths, we need to join them to the base path to check if they |
| 84 | // are directories. |
| 85 | SkString joinedPath = SkOSPath::SkPathJoin(path, entry->d_name); |
| 86 | |
| 87 | // We only care about files |
| 88 | if (!sk_isdir(joinedPath.c_str())) { |
| 89 | entries->push_back(SkString(entry->d_name)); |
| 90 | } |
| 91 | } |
| 92 | |
| 93 | return true; |
| 94 | } |