edac_stub.c 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  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. #include <asm/edac.h>
  20. int edac_op_state = EDAC_OPSTATE_INVAL;
  21. EXPORT_SYMBOL_GPL(edac_op_state);
  22. atomic_t edac_handlers = ATOMIC_INIT(0);
  23. EXPORT_SYMBOL_GPL(edac_handlers);
  24. int edac_err_assert = 0;
  25. EXPORT_SYMBOL_GPL(edac_err_assert);
  26. static atomic_t edac_subsys_valid = ATOMIC_INIT(0);
  27. int edac_report_status = EDAC_REPORTING_ENABLED;
  28. EXPORT_SYMBOL_GPL(edac_report_status);
  29. static int __init edac_report_setup(char *str)
  30. {
  31. if (!str)
  32. return -EINVAL;
  33. if (!strncmp(str, "on", 2))
  34. set_edac_report_status(EDAC_REPORTING_ENABLED);
  35. else if (!strncmp(str, "off", 3))
  36. set_edac_report_status(EDAC_REPORTING_DISABLED);
  37. else if (!strncmp(str, "force", 5))
  38. set_edac_report_status(EDAC_REPORTING_FORCE);
  39. return 0;
  40. }
  41. __setup("edac_report=", edac_report_setup);
  42. /*
  43. * called to determine if there is an EDAC driver interested in
  44. * knowing an event (such as NMI) occurred
  45. */
  46. int edac_handler_set(void)
  47. {
  48. if (edac_op_state == EDAC_OPSTATE_POLL)
  49. return 0;
  50. return atomic_read(&edac_handlers);
  51. }
  52. EXPORT_SYMBOL_GPL(edac_handler_set);
  53. /*
  54. * handler for NMI type of interrupts to assert error
  55. */
  56. void edac_atomic_assert_error(void)
  57. {
  58. edac_err_assert++;
  59. }
  60. EXPORT_SYMBOL_GPL(edac_atomic_assert_error);
  61. /*
  62. * sysfs object: /sys/devices/system/edac
  63. * need to export to other files
  64. */
  65. struct bus_type edac_subsys = {
  66. .name = "edac",
  67. .dev_name = "edac",
  68. };
  69. EXPORT_SYMBOL_GPL(edac_subsys);
  70. /* return pointer to the 'edac' node in sysfs */
  71. struct bus_type *edac_get_sysfs_subsys(void)
  72. {
  73. int err = 0;
  74. if (atomic_read(&edac_subsys_valid))
  75. goto out;
  76. /* create the /sys/devices/system/edac directory */
  77. err = subsys_system_register(&edac_subsys, NULL);
  78. if (err) {
  79. printk(KERN_ERR "Error registering toplevel EDAC sysfs dir\n");
  80. return NULL;
  81. }
  82. out:
  83. atomic_inc(&edac_subsys_valid);
  84. return &edac_subsys;
  85. }
  86. EXPORT_SYMBOL_GPL(edac_get_sysfs_subsys);
  87. void edac_put_sysfs_subsys(void)
  88. {
  89. /* last user unregisters it */
  90. if (atomic_dec_and_test(&edac_subsys_valid))
  91. bus_unregister(&edac_subsys);
  92. }
  93. EXPORT_SYMBOL_GPL(edac_put_sysfs_subsys);