cam_common_util.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2017-2021, The Linux Foundation. All rights reserved.
  4. */
  5. #include <linux/string.h>
  6. #include <linux/types.h>
  7. #include <linux/slab.h>
  8. #include <linux/timer.h>
  9. #include <linux/completion.h>
  10. #include <linux/module.h>
  11. #include <linux/iopoll.h>
  12. #include <linux/moduleparam.h>
  13. #include "cam_common_util.h"
  14. #include "cam_debug_util.h"
  15. static uint timeout_multiplier = 1;
  16. module_param(timeout_multiplier, uint, 0644);
  17. int cam_common_util_get_string_index(const char **strings,
  18. uint32_t num_strings, const char *matching_string, uint32_t *index)
  19. {
  20. int i;
  21. for (i = 0; i < num_strings; i++) {
  22. if (strnstr(strings[i], matching_string, strlen(strings[i]))) {
  23. CAM_DBG(CAM_UTIL, "matched %s : %d\n",
  24. matching_string, i);
  25. *index = i;
  26. return 0;
  27. }
  28. }
  29. return -EINVAL;
  30. }
  31. uint32_t cam_common_util_remove_duplicate_arr(int32_t *arr, uint32_t num)
  32. {
  33. int i, j;
  34. uint32_t wr_idx = 1;
  35. if (!arr) {
  36. CAM_ERR(CAM_UTIL, "Null input array");
  37. return 0;
  38. }
  39. for (i = 1; i < num; i++) {
  40. for (j = 0; j < wr_idx ; j++) {
  41. if (arr[i] == arr[j])
  42. break;
  43. }
  44. if (j == wr_idx)
  45. arr[wr_idx++] = arr[i];
  46. }
  47. return wr_idx;
  48. }
  49. unsigned long cam_common_wait_for_completion_timeout(
  50. struct completion *complete,
  51. unsigned long timeout_jiffies)
  52. {
  53. unsigned long wait_jiffies;
  54. unsigned long rem_jiffies;
  55. if (!complete) {
  56. CAM_ERR(CAM_UTIL, "Null complete pointer");
  57. return 0;
  58. }
  59. if (timeout_multiplier < 1)
  60. timeout_multiplier = 1;
  61. wait_jiffies = timeout_jiffies * timeout_multiplier;
  62. rem_jiffies = wait_for_completion_timeout(
  63. complete, wait_jiffies);
  64. return rem_jiffies;
  65. }
  66. int cam_common_read_poll_timeout(
  67. void __iomem *addr,
  68. unsigned long delay,
  69. unsigned long timeout,
  70. uint32_t mask,
  71. uint32_t check_val,
  72. uint32_t *status)
  73. {
  74. unsigned long wait_time_us;
  75. int rc = -EINVAL;
  76. if (!addr || !status) {
  77. CAM_ERR(CAM_UTIL, "Invalid param addr: %pK status: %pK",
  78. addr, status);
  79. return rc;
  80. }
  81. if (timeout_multiplier < 1)
  82. timeout_multiplier = 1;
  83. wait_time_us = timeout * timeout_multiplier;
  84. rc = readl_poll_timeout(addr,
  85. *status, (*status & mask) == check_val, delay, wait_time_us);
  86. return rc;
  87. }
  88. int cam_common_modify_timer(struct timer_list *timer, int32_t timeout_val)
  89. {
  90. if (!timer) {
  91. CAM_ERR(CAM_UTIL, "Invalid reference to system timer");
  92. return -EINVAL;
  93. }
  94. if (timeout_multiplier < 1)
  95. timeout_multiplier = 1;
  96. CAM_DBG(CAM_UTIL, "Starting timer to fire in %d ms. (jiffies=%lu)\n",
  97. (timeout_val * timeout_multiplier), jiffies);
  98. mod_timer(timer,
  99. (jiffies + msecs_to_jiffies(timeout_val * timeout_multiplier)));
  100. return 0;
  101. }