Drop that non-standard of accessing Retu as it's bypassing all the correct layers. Signed-off-by: Felipe Balbi <balbi@xxxxxx> --- drivers/cbus/Kconfig | 7 - drivers/cbus/Makefile | 1 - drivers/cbus/retu-user.c | 424 ---------------------------------------------- drivers/cbus/retu.c | 22 --- drivers/cbus/retu.h | 5 - 5 files changed, 0 insertions(+), 459 deletions(-) delete mode 100644 drivers/cbus/retu-user.c diff --git a/drivers/cbus/Kconfig b/drivers/cbus/Kconfig index c6b39fb..9a827a2 100644 --- a/drivers/cbus/Kconfig +++ b/drivers/cbus/Kconfig @@ -49,13 +49,6 @@ config CBUS_RETU If you want Retu support, you should say Y here. -config CBUS_RETU_USER - depends on CBUS_RETU - bool "Support for Retu user space functions" - ---help--- - If you want support for Retu's user space read/write etc. functions, - you should say Y here. - config CBUS_RETU_POWERBUTTON depends on CBUS_RETU bool "Support for Retu power button" diff --git a/drivers/cbus/Makefile b/drivers/cbus/Makefile index 347c2a4..0ad112f 100644 --- a/drivers/cbus/Makefile +++ b/drivers/cbus/Makefile @@ -10,5 +10,4 @@ obj-$(CONFIG_CBUS_RETU_POWERBUTTON) += retu-pwrbutton.o obj-$(CONFIG_CBUS_RETU_RTC) += retu-rtc.o obj-$(CONFIG_CBUS_RETU_WDT) += retu-wdt.o obj-$(CONFIG_CBUS_TAHVO_USER) += tahvo-user.o -obj-$(CONFIG_CBUS_RETU_USER) += retu-user.o obj-$(CONFIG_CBUS_RETU_HEADSET) += retu-headset.o diff --git a/drivers/cbus/retu-user.c b/drivers/cbus/retu-user.c deleted file mode 100644 index c36f356..0000000 --- a/drivers/cbus/retu-user.c +++ /dev/null @@ -1,424 +0,0 @@ -/** - * drivers/cbus/retu-user.c - * - * Retu user space interface functions - * - * Copyright (C) 2004, 2005 Nokia Corporation - * - * Written by Mikko Ylinen <mikko.k.ylinen@xxxxxxxxx> - * - * This file is subject to the terms and conditions of the GNU General - * Public License. See the file "COPYING" in the main directory of this - * archive for more details. - * - * 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA - */ - -#include <linux/types.h> -#include <linux/kernel.h> -#include <linux/slab.h> -#include <linux/interrupt.h> -#include <linux/module.h> -#include <linux/init.h> -#include <linux/fs.h> -#include <linux/miscdevice.h> -#include <linux/poll.h> -#include <linux/list.h> -#include <linux/spinlock.h> -#include <linux/sched.h> -#include <linux/mutex.h> - -#include <asm/uaccess.h> - -#include "retu.h" - -#include "user_retu_tahvo.h" - -/* Maximum size of IRQ node buffer/pool */ -#define RETU_MAX_IRQ_BUF_LEN 16 - -#define PFX "retu-user: " - -/* Bitmap for marking the interrupt sources as having the handlers */ -static u32 retu_irq_bits; - -/* For allowing only one user process to subscribe to the retu interrupts */ -static struct file *retu_irq_subscr = NULL; - -/* For poll and IRQ passing */ -struct retu_irq { - u32 id; - struct list_head node; -}; - -static spinlock_t retu_irqs_lock; -static struct retu_irq *retu_irq_block; -static LIST_HEAD(retu_irqs); -static LIST_HEAD(retu_irqs_reserve); - -/* Wait queue - used when user wants to read the device */ -DECLARE_WAIT_QUEUE_HEAD(retu_user_waitqueue); - -/* Semaphore to protect irq subscription sequence */ -static struct mutex retu_mutex; - -/* This array specifies RETU register types (read/write/toggle) */ -static const u8 retu_access_bits[] = { - 1, - 4, - 3, - 3, - 1, - 3, - 3, - 0, - 3, - 3, - 3, - 3, - 3, - 3, - 3, - 4, - 4, - 3, - 0, - 0, - 0, - 0, - 1, - 3, - 3, - 3, - 3, - 3, - 3, - 3, - 3, - 3 -}; - -/* - * The handler for all RETU interrupts. - * - * arg is the interrupt source in RETU. - */ -static void retu_user_irq_handler(unsigned long arg) -{ - struct retu_irq *irq; - - retu_ack_irq(arg); - - spin_lock(&retu_irqs_lock); - if (list_empty(&retu_irqs_reserve)) { - spin_unlock(&retu_irqs_lock); - return; - } - irq = list_entry((&retu_irqs_reserve)->next, struct retu_irq, node); - irq->id = arg; - list_move_tail(&irq->node, &retu_irqs); - spin_unlock(&retu_irqs_lock); - - /* wake up waiting thread */ - wake_up(&retu_user_waitqueue); -} - -/* - * This routine sets up the interrupt handler and marks an interrupt source - * in RETU as a candidate for signal delivery to the user process. - */ -static int retu_user_subscribe_to_irq(int id, struct file *filp) -{ - int ret; - - mutex_lock(&retu_mutex); - if ((retu_irq_subscr != NULL) && (retu_irq_subscr != filp)) { - mutex_unlock(&retu_mutex); - return -EBUSY; - } - /* Store the file pointer of the first user process registering IRQs */ - retu_irq_subscr = filp; - mutex_unlock(&retu_mutex); - - if (retu_irq_bits & (1 << id)) - return 0; - - ret = retu_request_irq(id, retu_user_irq_handler, id, ""); - if (ret < 0) - return ret; - - /* Mark that this interrupt has a handler */ - retu_irq_bits |= 1 << id; - - return 0; -} - -/* - * Unregisters all RETU interrupt handlers. - */ -static void retu_unreg_irq_handlers(void) -{ - int id; - - if (!retu_irq_bits) - return; - - for (id = 0; id < MAX_RETU_IRQ_HANDLERS; id++) - if (retu_irq_bits & (1 << id)) - retu_free_irq(id); - - retu_irq_bits = 0; -} - -/* - * Write to RETU register. - * Returns 0 upon success, a negative error value otherwise. - */ -static int retu_user_write_with_mask(u32 field, u16 value) -{ - u32 mask; - u32 reg; - u_short tmp; - unsigned long flags; - - mask = MASK(field); - reg = REG(field); - - /* Detect bad mask and reg */ - if (mask == 0 || reg > RETU_REG_MAX || - retu_access_bits[reg] == READ_ONLY) { - printk(KERN_ERR PFX "invalid arguments (reg=%#x, mask=%#x)\n", - reg, mask); - return -EINVAL; - } - - /* Justify value according to mask */ - while (!(mask & 1)) { - value = value << 1; - mask = mask >> 1; - } - - spin_lock_irqsave(&retu_lock, flags); - if (retu_access_bits[reg] == TOGGLE) { - /* No need to detect previous content of register */ - tmp = 0; - } else { - /* Read current value of register */ - tmp = retu_read_reg(reg); - } - - /* Generate new value */ - tmp = (tmp & ~MASK(field)) | (value & MASK(field)); - /* Write data to RETU */ - retu_write_reg(reg, tmp); - spin_unlock_irqrestore(&retu_lock, flags); - - return 0; -} - -/* - * Read RETU register. - */ -static u32 retu_user_read_with_mask(u32 field) -{ - u_short value; - u32 mask, reg; - - mask = MASK(field); - reg = REG(field); - - /* Detect bad mask and reg */ - if (mask == 0 || reg > RETU_REG_MAX) { - printk(KERN_ERR PFX "invalid arguments (reg=%#x, mask=%#x)\n", - reg, mask); - return -EINVAL; - } - - /* Read the register */ - value = retu_read_reg(reg) & mask; - - /* Right justify value */ - while (!(mask & 1)) { - value = value >> 1; - mask = mask >> 1; - } - - return value; -} - -/* - * Close device - */ -static int retu_close(struct inode *inode, struct file *filp) -{ - /* Unregister all interrupts that have been registered */ - if (retu_irq_subscr == filp) { - retu_unreg_irq_handlers(); - retu_irq_subscr = NULL; - } - - return 0; -} - -/* - * Device control (ioctl) - */ -static long retu_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) -{ - struct retu_tahvo_write_parms par; - int ret; - - switch (cmd) { - case URT_IOCT_IRQ_SUBSCR: - return retu_user_subscribe_to_irq(arg, filp); - case RETU_IOCH_READ: - return retu_user_read_with_mask(arg); - case RETU_IOCX_WRITE: - ret = copy_from_user(&par, (void __user *) arg, sizeof(par)); - if (ret) - printk(KERN_ERR "copy_from_user failed: %d\n", ret); - par.result = retu_user_write_with_mask(par.field, par.value); - ret = copy_to_user((void __user *) arg, &par, sizeof(par)); - if (ret) - printk(KERN_ERR "copy_to_user failed: %d\n", ret); - break; - case RETU_IOCH_ADC_READ: - return retu_read_adc(arg); - default: - return -ENOIOCTLCMD; - } - return 0; -} - -/* - * Read from device - */ -static ssize_t retu_read(struct file *filp, char *buf, size_t count, - loff_t * offp) -{ - struct retu_irq *irq; - - u32 nr, i; - - /* read not permitted if neither filp nor anyone has registered IRQs */ - if (retu_irq_subscr != filp) - return -EPERM; - - if ((count < sizeof(u32)) || ((count % sizeof(u32)) != 0)) - return -EINVAL; - - nr = count / sizeof(u32); - - for (i = 0; i < nr; i++) { - unsigned long flags; - u32 irq_id; - int ret; - - ret = wait_event_interruptible(retu_user_waitqueue, - !list_empty(&retu_irqs)); - if (ret < 0) - return ret; - - spin_lock_irqsave(&retu_irqs_lock, flags); - irq = list_entry((&retu_irqs)->next, struct retu_irq, node); - irq_id = irq->id; - list_move(&irq->node, &retu_irqs_reserve); - spin_unlock_irqrestore(&retu_irqs_lock, flags); - - ret = copy_to_user(buf + i * sizeof(irq_id), &irq_id, - sizeof(irq_id)); - if (ret) - printk(KERN_ERR "copy_to_user failed: %d\n", ret); - } - - return count; -} - -/* - * Poll method - */ -static unsigned retu_poll(struct file *filp, struct poll_table_struct *pt) -{ - if (!list_empty(&retu_irqs)) - return POLLIN; - - poll_wait(filp, &retu_user_waitqueue, pt); - - if (!list_empty(&retu_irqs)) - return POLLIN; - else - return 0; -} - -static struct file_operations retu_user_fileops = { - .owner = THIS_MODULE, - .unlocked_ioctl = retu_ioctl, - .read = retu_read, - .release = retu_close, - .poll = retu_poll -}; - -static struct miscdevice retu_device = { - .minor = MISC_DYNAMIC_MINOR, - .name = "retu", - .fops = &retu_user_fileops -}; - -/* - * Initialization - * - * @return 0 if successful, error value otherwise. - */ -int retu_user_init(void) -{ - struct retu_irq *irq; - int res, i; - - irq = kzalloc(sizeof(*irq) * RETU_MAX_IRQ_BUF_LEN, GFP_KERNEL); - if (irq == NULL) { - printk(KERN_ERR PFX "kzalloc failed\n"); - return -ENOMEM; - } - - for (i = 0; i < RETU_MAX_IRQ_BUF_LEN; i++) - list_add(&irq[i].node, &retu_irqs_reserve); - - retu_irq_block = irq; - - spin_lock_init(&retu_irqs_lock); - mutex_init(&retu_mutex); - - /* Request a misc device */ - res = misc_register(&retu_device); - if (res < 0) { - printk(KERN_ERR PFX "unable to register misc device for %s\n", - retu_device.name); - kfree(irq); - return res; - } - - return 0; -} - -/* - * Cleanup. - */ -void retu_user_cleanup(void) -{ - /* Unregister our misc device */ - misc_deregister(&retu_device); - /* Unregister and disable all RETU interrupts used by this module */ - retu_unreg_irq_handlers(); - kfree(retu_irq_block); -} - -MODULE_DESCRIPTION("Retu ASIC user space functions"); -MODULE_LICENSE("GPL"); -MODULE_AUTHOR("Mikko Ylinen"); diff --git a/drivers/cbus/retu.c b/drivers/cbus/retu.c index 6e130bf..39d4fa4 100644 --- a/drivers/cbus/retu.c +++ b/drivers/cbus/retu.c @@ -396,10 +396,6 @@ static int retu_allocate_children(struct device *parent) if (!child) return -ENOMEM; - child = retu_allocate_child("retu-user", parent); - if (!child) - return -ENOMEM; - child = retu_allocate_child("retu-wdt", parent); if (!child) return -ENOMEM; @@ -464,24 +460,9 @@ static int __init retu_probe(struct platform_device *pdev) /* Register power off function */ pm_power_off = retu_power_off; -#ifdef CONFIG_CBUS_RETU_USER - /* Initialize user-space interface */ - if (retu_user_init() < 0) { - dev_err(&pdev->dev, "Unable to initialize driver\n"); - tasklet_kill(&retu->tasklet); - free_irq(irq, 0); - kfree(retu); - the_retu = NULL; - return ret; - } -#endif - ret = retu_allocate_children(&pdev->dev); if (ret < 0) { dev_err(&pdev->dev, "Unable to allocate Retu children\n"); -#ifdef CONFIG_CBUS_RETU_USER - retu_user_cleanup(); -#endif retu_write_reg(RETU_REG_IMR, 0xffff); free_irq(irq, 0); tasklet_kill(&retu->tasklet); @@ -500,9 +481,6 @@ static int __exit retu_remove(struct platform_device *pdev) irq = platform_get_irq(pdev, 0); -#ifdef CONFIG_CBUS_RETU_USER - retu_user_cleanup(); -#endif /* Mask all RETU interrupts */ retu_write_reg(RETU_REG_IMR, 0xffff); free_irq(irq, retu); diff --git a/drivers/cbus/retu.h b/drivers/cbus/retu.h index 1cc486e..ada7f2e 100644 --- a/drivers/cbus/retu.h +++ b/drivers/cbus/retu.h @@ -68,9 +68,4 @@ void retu_enable_irq(int id); void retu_disable_irq(int id); void retu_ack_irq(int id); -#ifdef CONFIG_CBUS_RETU_USER -int retu_user_init(void); -void retu_user_cleanup(void); -#endif - #endif /* __DRIVERS_CBUS_RETU_H */ -- 1.7.3.4.598.g85356 -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html