/* * iwmc3200top - Intel Wireless MultiCom 3200 Top Driver * drivers/misc/iwmc3200top/debufs.c * * Copyright (C) 2009 Intel Corporation. All rights reserved. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License version * 2 as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301, USA. * * * Author Name: Maxim Grabarnik <maxim.grabarnink@intel.com> * - * */ #include <linux/kernel.h> #include <linux/slab.h> #include <linux/string.h> #include <linux/ctype.h> #include <linux/mmc/sdio_func.h> #include <linux/mmc/sdio.h> #include <linux/debugfs.h> #include "iwmc3200top.h" #include "fw-msg.h" #include "log.h" #include "debugfs.h" /* Constants definition */ #define HEXADECIMAL_RADIX 16 /* Functions definition */ #define DEBUGFS_ADD(name, parent) do { \ dbgfs->dbgfs_##parent##_files.file_##name = \ debugfs_create_file(#name, 0644, dbgfs->dir_##parent, priv, \ &iwmct_dbgfs_##name##_ops); \ } while (0) #define DEBUGFS_RM(name) do { \ debugfs_remove(name); \ name = NULL; \ } while (0) #define DEBUGFS_READ_FUNC(name) \ ssize_t iwmct_dbgfs_##name##_read(struct file *file, \ char __user *user_buf, \ size_t count, loff_t *ppos); #define DEBUGFS_WRITE_FUNC(name) \ ssize_t iwmct_dbgfs_##name##_write(struct file *file, \ const char __user *user_buf, \ size_t count, loff_t *ppos); #define DEBUGFS_READ_FILE_OPS(name) \ DEBUGFS_READ_FUNC(name) \ static const struct file_operations iwmct_dbgfs_##name##_ops = { \ .read = iwmct_dbgfs_##name##_read, \ .open = iwmct_dbgfs_open_file_generic, \ .llseek = generic_file_llseek, \ }; #define DEBUGFS_WRITE_FILE_OPS(name) \ DEBUGFS_WRITE_FUNC(name) \ static const struct file_operations iwmct_dbgfs_##name##_ops = { \ .write = iwmct_dbgfs_##name##_write, \ .open = iwmct_dbgfs_open_file_generic, \ .llseek = generic_file_llseek, \ }; #define DEBUGFS_READ_WRITE_FILE_OPS(name) \ DEBUGFS_READ_FUNC(name) \ DEBUGFS_WRITE_FUNC(name) \ static const struct file_operations iwmct_dbgfs_##name##_ops = {\ .write = iwmct_dbgfs_##name##_write, \ .read = iwmct_dbgfs_##name##_read, \ .open = iwmct_dbgfs_open_file_generic, \ .llseek = generic_file_llseek, \ }; /* Debugfs file ops definitions */ /* * Create the debugfs files and directories * */ void iwmct_dbgfs_register(struct iwmct_priv *priv, const char *name) { struct iwmct_debugfs *dbgfs; dbgfs = kzalloc(sizeof(struct iwmct_debugfs), GFP_KERNEL); if (!dbgfs) { LOG_ERROR(priv, DEBUGFS, "failed to allocate %zd bytes\n", sizeof(struct iwmct_debugfs)); return; } priv->dbgfs = dbgfs; dbgfs->name = name; dbgfs->dir_drv = debugfs_create_dir(name, NULL); if (!dbgfs->dir_drv) { LOG_ERROR(priv, DEBUGFS, "failed to create debugfs dir\n"); return; } return; } /** * Remove the debugfs files and directories * */ void iwmct_dbgfs_unregister(struct iwmct_debugfs *dbgfs) { if (!dbgfs) return; DEBUGFS_RM(dbgfs->dir_drv); kfree(dbgfs); dbgfs = NULL; }