x86/iosf: Add debugfs support
Allows access to the iosf sideband through debugfs. Signed-off-by: David E. Box <david.e.box@linux.intel.com> Link: http://lkml.kernel.org/r/1409175640-32426-3-git-send-email-david.e.box@linux.intel.com Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
This commit is contained in:
parent
aa8e4f22ab
commit
8dc12f933c
@ -22,6 +22,8 @@
|
|||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
#include <linux/spinlock.h>
|
#include <linux/spinlock.h>
|
||||||
#include <linux/pci.h>
|
#include <linux/pci.h>
|
||||||
|
#include <linux/debugfs.h>
|
||||||
|
#include <linux/capability.h>
|
||||||
|
|
||||||
#include <asm/iosf_mbi.h>
|
#include <asm/iosf_mbi.h>
|
||||||
|
|
||||||
@ -187,6 +189,75 @@ bool iosf_mbi_available(void)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(iosf_mbi_available);
|
EXPORT_SYMBOL(iosf_mbi_available);
|
||||||
|
|
||||||
|
/********************** debugfs begin ****************************/
|
||||||
|
static u32 dbg_mdr;
|
||||||
|
static u32 dbg_mcr;
|
||||||
|
static u32 dbg_mcrx;
|
||||||
|
|
||||||
|
static int mcr_get(void *data, u64 *val)
|
||||||
|
{
|
||||||
|
*val = *(u32 *)data;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int mcr_set(void *data, u64 val)
|
||||||
|
{
|
||||||
|
u8 command = ((u32)val & 0xFF000000) >> 24,
|
||||||
|
port = ((u32)val & 0x00FF0000) >> 16,
|
||||||
|
offset = ((u32)val & 0x0000FF00) >> 8;
|
||||||
|
int err;
|
||||||
|
|
||||||
|
*(u32 *)data = val;
|
||||||
|
|
||||||
|
if (!capable(CAP_SYS_RAWIO))
|
||||||
|
return -EACCES;
|
||||||
|
|
||||||
|
if (command & 1u)
|
||||||
|
err = iosf_mbi_write(port,
|
||||||
|
command,
|
||||||
|
dbg_mcrx | offset,
|
||||||
|
dbg_mdr);
|
||||||
|
else
|
||||||
|
err = iosf_mbi_read(port,
|
||||||
|
command,
|
||||||
|
dbg_mcrx | offset,
|
||||||
|
&dbg_mdr);
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
DEFINE_SIMPLE_ATTRIBUTE(iosf_mcr_fops, mcr_get, mcr_set , "%llx\n");
|
||||||
|
|
||||||
|
static struct dentry *iosf_dbg;
|
||||||
|
static void iosf_sideband_debug_init(void)
|
||||||
|
{
|
||||||
|
struct dentry *d;
|
||||||
|
|
||||||
|
iosf_dbg = debugfs_create_dir("iosf_sb", NULL);
|
||||||
|
if (IS_ERR_OR_NULL(iosf_dbg))
|
||||||
|
return;
|
||||||
|
|
||||||
|
/* mdr */
|
||||||
|
d = debugfs_create_x32("mdr", 0660, iosf_dbg, &dbg_mdr);
|
||||||
|
if (IS_ERR_OR_NULL(d))
|
||||||
|
goto cleanup;
|
||||||
|
|
||||||
|
/* mcrx */
|
||||||
|
debugfs_create_x32("mcrx", 0660, iosf_dbg, &dbg_mcrx);
|
||||||
|
if (IS_ERR_OR_NULL(d))
|
||||||
|
goto cleanup;
|
||||||
|
|
||||||
|
/* mcr - initiates mailbox tranaction */
|
||||||
|
debugfs_create_file("mcr", 0660, iosf_dbg, &dbg_mcr, &iosf_mcr_fops);
|
||||||
|
if (IS_ERR_OR_NULL(d))
|
||||||
|
goto cleanup;
|
||||||
|
|
||||||
|
return;
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
debugfs_remove_recursive(d);
|
||||||
|
}
|
||||||
|
/********************** debugfs end ****************************/
|
||||||
|
|
||||||
static int iosf_mbi_probe(struct pci_dev *pdev,
|
static int iosf_mbi_probe(struct pci_dev *pdev,
|
||||||
const struct pci_device_id *unused)
|
const struct pci_device_id *unused)
|
||||||
{
|
{
|
||||||
@ -217,11 +288,14 @@ static struct pci_driver iosf_mbi_pci_driver = {
|
|||||||
|
|
||||||
static int __init iosf_mbi_init(void)
|
static int __init iosf_mbi_init(void)
|
||||||
{
|
{
|
||||||
|
iosf_sideband_debug_init();
|
||||||
return pci_register_driver(&iosf_mbi_pci_driver);
|
return pci_register_driver(&iosf_mbi_pci_driver);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __exit iosf_mbi_exit(void)
|
static void __exit iosf_mbi_exit(void)
|
||||||
{
|
{
|
||||||
|
debugfs_remove_recursive(iosf_dbg);
|
||||||
|
|
||||||
pci_unregister_driver(&iosf_mbi_pci_driver);
|
pci_unregister_driver(&iosf_mbi_pci_driver);
|
||||||
if (mbi_pdev) {
|
if (mbi_pdev) {
|
||||||
pci_dev_put(mbi_pdev);
|
pci_dev_put(mbi_pdev);
|
||||||
|
Loading…
Reference in New Issue
Block a user