cam_debug_util.c 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2017-2021, The Linux Foundation. All rights reserved.
  4. * Copyright (c) 2022 Qualcomm Innovation Center, Inc. All rights reserved.
  5. */
  6. #include <linux/io.h>
  7. #include <linux/slab.h>
  8. #include <linux/module.h>
  9. #include <linux/debugfs.h>
  10. #include "cam_trace.h"
  11. #include "cam_debug_util.h"
  12. unsigned long long debug_mdl;
  13. module_param(debug_mdl, ullong, 0644);
  14. /* 0x0 - only logs, 0x1 - only trace, 0x2 - logs + trace */
  15. uint debug_type;
  16. module_param(debug_type, uint, 0644);
  17. uint debug_priority;
  18. module_param(debug_priority, uint, 0644);
  19. uint debug_drv;
  20. module_param(debug_drv, uint, 0644);
  21. struct camera_debug_settings cam_debug;
  22. struct dentry *cam_debugfs_root;
  23. void cam_debugfs_init(void)
  24. {
  25. struct dentry *tmp;
  26. if (!cam_debugfs_available()) {
  27. cam_debugfs_root = NULL;
  28. CAM_DBG(CAM_UTIL, "debugfs not available");
  29. return;
  30. }
  31. if (cam_debugfs_root) {
  32. CAM_WARN(CAM_UTIL, "already created debugfs root");
  33. return;
  34. }
  35. tmp = debugfs_create_dir("camera", NULL);
  36. if (IS_ERR_VALUE(tmp)) {
  37. CAM_ERR(CAM_UTIL, "failed to create debugfs root folder (rc=%d)", PTR_ERR(tmp));
  38. return;
  39. }
  40. cam_debugfs_root = tmp;
  41. CAM_DBG(CAM_UTIL, "successfully created debugfs root");
  42. }
  43. void cam_debugfs_deinit(void)
  44. {
  45. if (!cam_debugfs_available())
  46. return;
  47. debugfs_remove_recursive(cam_debugfs_root);
  48. cam_debugfs_root = NULL;
  49. }
  50. int cam_debugfs_create_subdir(const char *name, struct dentry **subdir)
  51. {
  52. struct dentry *tmp;
  53. if (!cam_debugfs_root) {
  54. CAM_WARN(CAM_UTIL, "debugfs root not created");
  55. *subdir = NULL;
  56. return -ENODEV;
  57. }
  58. if (!subdir) {
  59. CAM_ERR(CAM_UTIL, "invalid subdir pointer %pK", subdir);
  60. return -EINVAL;
  61. }
  62. tmp = debugfs_create_dir(name, cam_debugfs_root);
  63. if (IS_ERR_VALUE(tmp)) {
  64. CAM_ERR(CAM_UTIL, "failed to create debugfs subdir (name=%s, rc=%d)", name,
  65. PTR_ERR(tmp));
  66. return PTR_ERR(tmp);
  67. }
  68. *subdir = tmp;
  69. return 0;
  70. }
  71. int cam_debugfs_lookup_subdir(const char *name, struct dentry **subdir)
  72. {
  73. if (!cam_debugfs_root) {
  74. CAM_WARN(CAM_UTIL, "debugfs root not created");
  75. *subdir = NULL;
  76. return -ENODEV;
  77. }
  78. if (!subdir) {
  79. CAM_ERR(CAM_UTIL, "invalid subdir pointer %pK", subdir);
  80. return -EINVAL;
  81. }
  82. *subdir = debugfs_lookup(name, cam_debugfs_root);
  83. return (*subdir) ? 0 : -ENOENT;
  84. }
  85. const struct camera_debug_settings *cam_debug_get_settings(void)
  86. {
  87. return &cam_debug;
  88. }
  89. static int cam_debug_parse_cpas_settings(const char *setting, u64 value)
  90. {
  91. if (!strcmp(setting, "camnoc_bw")) {
  92. cam_debug.cpas_settings.camnoc_bw = value;
  93. } else if (!strcmp(setting, "mnoc_hf_0_ab_bw")) {
  94. cam_debug.cpas_settings.mnoc_hf_0_ab_bw = value;
  95. } else if (!strcmp(setting, "mnoc_hf_0_ib_bw")) {
  96. cam_debug.cpas_settings.mnoc_hf_0_ib_bw = value;
  97. } else if (!strcmp(setting, "mnoc_hf_1_ab_bw")) {
  98. cam_debug.cpas_settings.mnoc_hf_1_ab_bw = value;
  99. } else if (!strcmp(setting, "mnoc_hf_1_ib_bw")) {
  100. cam_debug.cpas_settings.mnoc_hf_1_ib_bw = value;
  101. } else if (!strcmp(setting, "mnoc_sf_0_ab_bw")) {
  102. cam_debug.cpas_settings.mnoc_sf_0_ab_bw = value;
  103. } else if (!strcmp(setting, "mnoc_sf_0_ib_bw")) {
  104. cam_debug.cpas_settings.mnoc_sf_0_ib_bw = value;
  105. } else if (!strcmp(setting, "mnoc_sf_1_ab_bw")) {
  106. cam_debug.cpas_settings.mnoc_sf_1_ab_bw = value;
  107. } else if (!strcmp(setting, "mnoc_sf_1_ib_bw")) {
  108. cam_debug.cpas_settings.mnoc_sf_1_ib_bw = value;
  109. } else if (!strcmp(setting, "mnoc_sf_icp_ab_bw")) {
  110. cam_debug.cpas_settings.mnoc_sf_icp_ab_bw = value;
  111. } else if (!strcmp(setting, "mnoc_sf_icp_ib_bw")) {
  112. cam_debug.cpas_settings.mnoc_sf_icp_ib_bw = value;
  113. } else {
  114. CAM_ERR(CAM_UTIL, "Unsupported cpas sysfs entry");
  115. return -EINVAL;
  116. }
  117. return 0;
  118. }
  119. ssize_t cam_debug_sysfs_node_store(struct device *dev,
  120. struct device_attribute *attr, const char *buf, size_t count)
  121. {
  122. int rc = 0;
  123. char *local_buf = NULL, *local_buf_temp = NULL;
  124. char *driver;
  125. char *setting = NULL;
  126. char *value_str = NULL;
  127. u64 value;
  128. CAM_INFO(CAM_UTIL, "Sysfs debug attr name:[%s] buf:[%s] bytes:[%d]",
  129. attr->attr.name, buf, count);
  130. local_buf = kmemdup(buf, (count + sizeof(char)), GFP_KERNEL);
  131. local_buf_temp = local_buf;
  132. driver = strsep(&local_buf, "#");
  133. if (!driver) {
  134. CAM_ERR(CAM_UTIL,
  135. "Invalid input driver name buf:[%s], count:%d",
  136. buf, count);
  137. goto error;
  138. }
  139. setting = strsep(&local_buf, "=");
  140. if (!setting) {
  141. CAM_ERR(CAM_UTIL, "Invalid input setting buf:[%s], count:%d",
  142. buf, count);
  143. goto error;
  144. }
  145. value_str = strsep(&local_buf, "=");
  146. if (!value_str) {
  147. CAM_ERR(CAM_UTIL, "Invalid input value buf:[%s], count:%d",
  148. buf, count);
  149. goto error;
  150. }
  151. rc = kstrtou64(value_str, 0, &value);
  152. if (rc < 0) {
  153. CAM_ERR(CAM_UTIL, "Error converting value:[%s], buf:[%s]",
  154. value_str, buf);
  155. goto error;
  156. }
  157. CAM_INFO(CAM_UTIL,
  158. "Processing sysfs store for driver:[%s], setting:[%s], value:[%llu]",
  159. driver, setting, value);
  160. if (!strcmp(driver, "cpas")) {
  161. rc = cam_debug_parse_cpas_settings(setting, value);
  162. if (rc)
  163. goto error;
  164. } else {
  165. CAM_ERR(CAM_UTIL, "Unsupported driver in camera debug node");
  166. goto error;
  167. }
  168. kfree(local_buf_temp);
  169. return count;
  170. error:
  171. kfree(local_buf_temp);
  172. return -EPERM;
  173. }
  174. static inline void __cam_print_to_buffer(char *buf, const size_t buf_size, size_t *len,
  175. unsigned int tag, enum cam_debug_module_id module_id, const char *fmt, va_list args)
  176. {
  177. size_t buf_len = *len;
  178. buf_len += scnprintf(buf + buf_len, (buf_size - buf_len), "\n%-8s: %s:\t",
  179. CAM_LOG_TAG_NAME(tag), CAM_DBG_MOD_NAME(module_id));
  180. buf_len += vscnprintf(buf + buf_len, (buf_size - buf_len), fmt, args);
  181. *len = buf_len;
  182. }
  183. void cam_print_to_buffer(char *buf, const size_t buf_size, size_t *len, unsigned int tag,
  184. unsigned long long module_id, const char *fmt, ...)
  185. {
  186. va_list args;
  187. va_start(args, fmt);
  188. __cam_print_to_buffer(buf, buf_size, len, tag, module_id, fmt, args);
  189. va_end(args);
  190. }
  191. static void __cam_print_log(int type, const char *fmt, va_list args)
  192. {
  193. va_list args1, args2;
  194. va_copy(args1, args);
  195. va_copy(args2, args1);
  196. if ((type & CAM_PRINT_LOG) && (debug_type != 1))
  197. vprintk(fmt, args1);
  198. if ((type & CAM_PRINT_TRACE) && (debug_type != 0)) {
  199. /* skip the first character which is used by printk to identify the log level */
  200. trace_cam_log_debug(fmt + sizeof(KERN_INFO) - 1, &args2);
  201. }
  202. va_end(args2);
  203. va_end(args1);
  204. }
  205. void cam_print_log(int type, const char *fmt, ...)
  206. {
  207. va_list args;
  208. if (!type)
  209. return;
  210. va_start(args, fmt);
  211. __cam_print_log(type, fmt, args);
  212. va_end(args);
  213. }