mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-11 08:14:27 +08:00
733476cf20
This was really dumb - reference counting for the main EDAC sysfs object. While we could've simply registered it as the first thing in the module init path and then hand it around to what needs it. Do that and rip out all the code around it, thus simplifying the whole handling significantly. Move the edac_subsys node back to edac_module.c. Signed-off-by: Borislav Petkov <bp@suse.de>
69 lines
1.6 KiB
C
69 lines
1.6 KiB
C
/*
|
|
* common EDAC components that must be in kernel
|
|
*
|
|
* Author: Dave Jiang <djiang@mvista.com>
|
|
*
|
|
* 2007 (c) MontaVista Software, Inc.
|
|
* 2010 (c) Advanced Micro Devices Inc.
|
|
* Borislav Petkov <bp@alien8.de>
|
|
*
|
|
* This file is licensed under the terms of the GNU General Public
|
|
* License version 2. This program is licensed "as is" without any
|
|
* warranty of any kind, whether express or implied.
|
|
*
|
|
*/
|
|
#include <linux/module.h>
|
|
#include <linux/edac.h>
|
|
#include <linux/atomic.h>
|
|
#include <linux/device.h>
|
|
|
|
int edac_op_state = EDAC_OPSTATE_INVAL;
|
|
EXPORT_SYMBOL_GPL(edac_op_state);
|
|
|
|
atomic_t edac_handlers = ATOMIC_INIT(0);
|
|
EXPORT_SYMBOL_GPL(edac_handlers);
|
|
|
|
int edac_err_assert = 0;
|
|
EXPORT_SYMBOL_GPL(edac_err_assert);
|
|
|
|
int edac_report_status = EDAC_REPORTING_ENABLED;
|
|
EXPORT_SYMBOL_GPL(edac_report_status);
|
|
|
|
static int __init edac_report_setup(char *str)
|
|
{
|
|
if (!str)
|
|
return -EINVAL;
|
|
|
|
if (!strncmp(str, "on", 2))
|
|
set_edac_report_status(EDAC_REPORTING_ENABLED);
|
|
else if (!strncmp(str, "off", 3))
|
|
set_edac_report_status(EDAC_REPORTING_DISABLED);
|
|
else if (!strncmp(str, "force", 5))
|
|
set_edac_report_status(EDAC_REPORTING_FORCE);
|
|
|
|
return 0;
|
|
}
|
|
__setup("edac_report=", edac_report_setup);
|
|
|
|
/*
|
|
* called to determine if there is an EDAC driver interested in
|
|
* knowing an event (such as NMI) occurred
|
|
*/
|
|
int edac_handler_set(void)
|
|
{
|
|
if (edac_op_state == EDAC_OPSTATE_POLL)
|
|
return 0;
|
|
|
|
return atomic_read(&edac_handlers);
|
|
}
|
|
EXPORT_SYMBOL_GPL(edac_handler_set);
|
|
|
|
/*
|
|
* handler for NMI type of interrupts to assert error
|
|
*/
|
|
void edac_atomic_assert_error(void)
|
|
{
|
|
edac_err_assert++;
|
|
}
|
|
EXPORT_SYMBOL_GPL(edac_atomic_assert_error);
|