cregit-Linux how code gets into the kernel

Release 4.14 drivers/edac/edac_module.c

Directory: drivers/edac
/*
 * edac_module.c
 *
 * (C) 2007 www.softwarebitmaker.com
 *
 * 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.
 *
 * Author: Doug Thompson <dougthompson@xmission.com>
 *
 */
#include <linux/edac.h>

#include "edac_mc.h"
#include "edac_module.h"


#define EDAC_VERSION "Ver: 3.0.0"

#ifdef CONFIG_EDAC_DEBUG


static int edac_set_debug_level(const char *buf, struct kernel_param *kp) { unsigned long val; int ret; ret = kstrtoul(buf, 0, &val); if (ret) return ret; if (val > 4) return -EINVAL; return param_set_int(buf, kp); }

Contributors

PersonTokensPropCommitsCommitProp
Borislav Petkov60100.00%1100.00%
Total60100.00%1100.00%

/* Values of 0 to 4 will generate output */ int edac_debug_level = 2; EXPORT_SYMBOL_GPL(edac_debug_level); module_param_call(edac_debug_level, edac_set_debug_level, param_get_int, &edac_debug_level, 0644); MODULE_PARM_DESC(edac_debug_level, "EDAC debug level: [0-4], default: 2"); #endif /* * edac_op_state_to_string() */
char *edac_op_state_to_string(int opstate) { if (opstate == OP_RUNNING_POLL) return "POLLED"; else if (opstate == OP_RUNNING_INTERRUPT) return "INTERRUPT"; else if (opstate == OP_RUNNING_POLL_INTR) return "POLL-INTR"; else if (opstate == OP_ALLOC) return "ALLOC"; else if (opstate == OP_OFFLINE) return "OFFLINE"; return "UNKNOWN"; }

Contributors

PersonTokensPropCommitsCommitProp
Dave Jiang6098.36%150.00%
Doug Thompson11.64%150.00%
Total61100.00%2100.00%

/* * sysfs object: /sys/devices/system/edac * need to export to other files */ static struct bus_type edac_subsys = { .name = "edac", .dev_name = "edac", };
static int edac_subsys_init(void) { int err; /* create the /sys/devices/system/edac directory */ err = subsys_system_register(&edac_subsys, NULL); if (err) printk(KERN_ERR "Error registering toplevel EDAC sysfs dir\n"); return err; }

Contributors

PersonTokensPropCommitsCommitProp
Borislav Petkov35100.00%1100.00%
Total35100.00%1100.00%


static void edac_subsys_exit(void) { bus_unregister(&edac_subsys); }

Contributors

PersonTokensPropCommitsCommitProp
Borislav Petkov14100.00%1100.00%
Total14100.00%1100.00%

/* return pointer to the 'edac' node in sysfs */
struct bus_type *edac_get_sysfs_subsys(void) { return &edac_subsys; }

Contributors

PersonTokensPropCommitsCommitProp
Borislav Petkov13100.00%1100.00%
Total13100.00%1100.00%

EXPORT_SYMBOL_GPL(edac_get_sysfs_subsys); /* * edac_init * module initialization entry point */
static int __init edac_init(void) { int err = 0; edac_printk(KERN_INFO, EDAC_MC, EDAC_VERSION "\n"); err = edac_subsys_init(); if (err) return err; /* * Harvest and clear any boot/initialization PCI parity errors * * FIXME: This only clears errors logged by devices present at time of * module initialization. We should also do an initial clear * of each newly hotplugged device. */ edac_pci_clear_parity_errors(); err = edac_mc_sysfs_init(); if (err) goto err_sysfs; edac_debugfs_init(); err = edac_workqueue_setup(); if (err) { edac_printk(KERN_ERR, EDAC_MC, "Failure initializing workqueue\n"); goto err_wq; } return 0; err_wq: edac_debugfs_exit(); edac_mc_sysfs_exit(); err_sysfs: edac_subsys_exit(); return err; }

Contributors

PersonTokensPropCommitsCommitProp
Doug Thompson6668.04%555.56%
Borislav Petkov1515.46%111.11%
Alexey Khoroshilov1212.37%111.11%
Rob Herring33.09%111.11%
Mauro Carvalho Chehab11.03%111.11%
Total97100.00%9100.00%

/* * edac_exit() * module exit/termination function */
static void __exit edac_exit(void) { edac_dbg(0, "\n"); /* tear down the various subsystems */ edac_workqueue_teardown(); edac_mc_sysfs_exit(); edac_debugfs_exit(); edac_subsys_exit(); }

Contributors

PersonTokensPropCommitsCommitProp
Doug Thompson1862.07%337.50%
Joe Perches310.34%112.50%
Rob Herring310.34%112.50%
Borislav Petkov310.34%112.50%
Mauro Carvalho Chehab26.90%225.00%
Total29100.00%8100.00%

/* * Inform the kernel of our entry and exit points */ subsys_initcall(edac_init); module_exit(edac_exit); MODULE_LICENSE("GPL"); MODULE_AUTHOR("Doug Thompson www.softwarebitmaker.com, et al"); MODULE_DESCRIPTION("Core library routines for EDAC reporting");

Overall Contributors

PersonTokensPropCommitsCommitProp
Borislav Petkov18544.79%315.79%
Doug Thompson13833.41%631.58%
Dave Jiang6315.25%210.53%
Alexey Khoroshilov122.91%15.26%
Rob Herring61.45%15.26%
Mauro Carvalho Chehab61.45%526.32%
Joe Perches30.73%15.26%
Total413100.00%19100.00%
Directory: drivers/edac
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.