edac_stub.c 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. /*
  2. * common EDAC components that must be in kernel
  3. *
  4. * Author: Dave Jiang <djiang@mvista.com>
  5. *
  6. * 2007 (c) MontaVista Software, Inc.
  7. * 2010 (c) Advanced Micro Devices Inc.
  8. * Borislav Petkov <bp@alien8.de>
  9. *
  10. * This file is licensed under the terms of the GNU General Public
  11. * License version 2. This program is licensed "as is" without any
  12. * warranty of any kind, whether express or implied.
  13. *
  14. */
  15. #include <linux/module.h>
  16. #include <linux/edac.h>
  17. #include <linux/atomic.h>
  18. #include <linux/device.h>
  19. int edac_op_state = EDAC_OPSTATE_INVAL;
  20. EXPORT_SYMBOL_GPL(edac_op_state);
  21. atomic_t edac_handlers = ATOMIC_INIT(0);
  22. EXPORT_SYMBOL_GPL(edac_handlers);
  23. int edac_err_assert = 0;
  24. EXPORT_SYMBOL_GPL(edac_err_assert);
  25. static atomic_t edac_subsys_valid = ATOMIC_INIT(0);
  26. int edac_report_status = EDAC_REPORTING_ENABLED;
  27. EXPORT_SYMBOL_GPL(edac_report_status);
  28. static int __init edac_report_setup(char *str)
  29. {
  30. if (!str)
  31. return -EINVAL;
  32. if (!strncmp(str, "on", 2))
  33. set_edac_report_status(EDAC_REPORTING_ENABLED);
  34. else if (!strncmp(str, "off", 3))
  35. set_edac_report_status(EDAC_REPORTING_DISABLED);
  36. else if (!strncmp(str, "force", 5))
  37. set_edac_report_status(EDAC_REPORTING_FORCE);
  38. return 0;
  39. }
  40. __setup("edac_report=", edac_report_setup);
  41. /*
  42. * called to determine if there is an EDAC driver interested in
  43. * knowing an event (such as NMI) occurred
  44. */
  45. int edac_handler_set(void)
  46. {
  47. if (edac_op_state == EDAC_OPSTATE_POLL)
  48. return 0;
  49. return atomic_read(&edac_handlers);
  50. }
  51. EXPORT_SYMBOL_GPL(edac_handler_set);
  52. /*
  53. * handler for NMI type of interrupts to assert error
  54. */
  55. void edac_atomic_assert_error(void)
  56. {
  57. edac_err_assert++;
  58. }
  59. EXPORT_SYMBOL_GPL(edac_atomic_assert_error);
  60. /*
  61. * sysfs object: /sys/devices/system/edac
  62. * need to export to other files
  63. */
  64. struct bus_type edac_subsys = {
  65. .name = "edac",
  66. .dev_name = "edac",
  67. };
  68. EXPORT_SYMBOL_GPL(edac_subsys);
  69. /* return pointer to the 'edac' node in sysfs */
  70. struct bus_type *edac_get_sysfs_subsys(void)
  71. {
  72. int err = 0;
  73. if (atomic_read(&edac_subsys_valid))
  74. goto out;
  75. /* create the /sys/devices/system/edac directory */
  76. err = subsys_system_register(&edac_subsys, NULL);
  77. if (err) {
  78. printk(KERN_ERR "Error registering toplevel EDAC sysfs dir\n");
  79. return NULL;
  80. }
  81. out:
  82. atomic_inc(&edac_subsys_valid);
  83. return &edac_subsys;
  84. }
  85. EXPORT_SYMBOL_GPL(edac_get_sysfs_subsys);
  86. void edac_put_sysfs_subsys(void)
  87. {
  88. /* last user unregisters it */
  89. if (atomic_dec_and_test(&edac_subsys_valid))
  90. bus_unregister(&edac_subsys);
  91. }
  92. EXPORT_SYMBOL_GPL(edac_put_sysfs_subsys);