sec_class.c 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * COPYRIGHT(C) 2014-2023 Samsung Electronics Co., Ltd. All Right Reserved.
  4. */
  5. #define pr_fmt(fmt) KBUILD_MODNAME ":%s() " fmt, __func__
  6. #include <linux/device.h>
  7. #include <linux/err.h>
  8. #include <linux/module.h>
  9. /* CAUTION : Do not be declared as external sec_class */
  10. static struct class *sec_class;
  11. static atomic_t sec_dev;
  12. static int sec_class_match_device_by_name(struct device *dev, const void *data)
  13. {
  14. const char *name = data;
  15. return sysfs_streq(name, dev_name(dev));
  16. }
  17. struct device *sec_dev_get_by_name(const char *name)
  18. {
  19. return class_find_device(sec_class, NULL, name,
  20. sec_class_match_device_by_name);
  21. }
  22. EXPORT_SYMBOL_GPL(sec_dev_get_by_name);
  23. struct device *sec_device_create(void *drvdata, const char *fmt)
  24. {
  25. struct device *dev;
  26. if (unlikely(!sec_class)) {
  27. pr_err("Not yet created class(sec)!\n");
  28. BUG();
  29. }
  30. if (IS_ERR(sec_class)) {
  31. pr_err("Failed to create class(sec) %ld\n", PTR_ERR(sec_class));
  32. BUG();
  33. }
  34. dev = device_create(sec_class, NULL, atomic_inc_return(&sec_dev),
  35. drvdata, "%s", fmt);
  36. if (IS_ERR(dev))
  37. pr_err("Failed to create device %s %ld\n", fmt, PTR_ERR(dev));
  38. else
  39. pr_debug("%s : %d\n", fmt, dev->devt);
  40. return dev;
  41. }
  42. EXPORT_SYMBOL_GPL(sec_device_create);
  43. void sec_device_destroy(dev_t devt)
  44. {
  45. if (unlikely(!devt)) {
  46. pr_err("Not allowed to destroy dev\n");
  47. } else {
  48. pr_info("%d\n", devt);
  49. device_destroy(sec_class, devt);
  50. }
  51. }
  52. EXPORT_SYMBOL_GPL(sec_device_destroy);
  53. static int __init sec_class_create(void)
  54. {
  55. sec_class = class_create(THIS_MODULE, "sec");
  56. if (IS_ERR(sec_class)) {
  57. pr_err("Failed to create class(sec) %ld\n", PTR_ERR(sec_class));
  58. return PTR_ERR(sec_class);
  59. }
  60. return 0;
  61. }
  62. core_initcall(sec_class_create);
  63. MODULE_AUTHOR("Samsung Electronics");
  64. MODULE_DESCRIPTION("sec-class");
  65. MODULE_LICENSE("GPL v2");